摘要:注本文首发于公众号,可长按或扫描下面的小心心来订阅关于构造器与初始化无参构造器默认构造器自己未写编译器帮忙自动创建的若自行定义了构造器无论参数有否,编译器便停止默认创建动作类里的对象引用默认初始化为,基本类型初始化为构造器也是类的静态方法四
注: 本文首发于 My 公众号 CodeSheep ,可 长按 或 扫描 下面的 小心心 来订阅 ↓ ↓ ↓关于构造器与初始化
无参构造器 = 默认构造器 = 自己未写编译器帮忙自动创建的
若自行定义了构造器(无论参数有否),编译器便停止默认创建动作
类里的对象引用默认初始化为null,基本类型初始化为0
构造器也是类的静态方法!!!
四种常见初始化方式:
自动初始化:无法被阻止的,先于构造器,即所谓的基本类型赋空值(0),对象赋null
指定初始化:定义类成员的时候直接赋初始值
初始化子句:(匿名内部类的初始化的必需品!且一定先于构造器执行)
public class Example { int i; int j; { i = 1; j = 2; } }
构造器初始化:在构造器中对成员赋上值
静态域的初始化:
java中的static关键字是只能用于域,而不能用于普通的局部变量
未赋值过的类的静态域默认有初值:(object=null、基本数据类型 = 0)
静态子句的概念:包含有多个静态域初始化的的语句块,举例:
class Cups { Static cup cup1; Static cup cup2; static { // 静态子句 cup1 = new Cup(1); cup2 = new Cup(2) } }
数组的初始化:
java是不允许定义数组时指定数组大小的
所有数组都有一个固定成员length
对象数组初始化方法:
形式1:只能被用在数组定义处,比较受限 Integer[] a = { new Integer(1), new Integer(2), 3, // 会被自动包装 } 形式2:可用于任何地方,典型在函数传参时:如:Example.func( new Ingeger[] { new Integer(1), new Integer(2), 3 } ) Integer[] b = new Ingeger[] { new Integer(1), new Integer(2), 3, // 会被自动包装 }
可变参数列表
public class Example { static void f( int i, String... trailing ) { ... for( String s : trailing ) ... } public static void main( String[] args ) { f( 1, "one" ); f( 1, "one", "tow" ); f( 1 ); } }
特别注意:
若函数参数只使用可变函数列表这将会使重载变得难以理解,解决办法是:(1)要么在参数中加一个非可变参数;(2)要么只在重载方法的一个版本上使用可变参数;(3)不要尝试这种做法
初始化的顺序:
static成员先于non-static
类成员定义顺序=初始化顺序(即使变量散布于类方法之间)
某个成员先定义,然后再在构造器中初始化,其值的就先被编译器赋空值(null和0),然后再被赋上具体值,这个是有个先后关系的!
关于this当以object来调用方法时,编译器会将该对象的引用作为第一个参数来传给方法:object.func(1) = Class.func(object,1)
注意类的static方法无this,且static方法内部不可调用非static方法,反过来ok
this可以用来在constructor中调用constructor,举例:
// 利用this实现constructor中调用constructor public class Example { int _i = 0; String s = ""; Example( int i ) { this._i = i; } Example( String s, int i ) { this(i); // 该句必须在最开始,且this()这种只能使用一次 this._s = s; } }关于重载
关于清理(finalize终结处理 和 jvm垃圾回收)java重载唯一规则:独一无二的参数列表
永远不要幻想以返回值区分重载
关于jvm的垃圾回收,有几点必须记住的:
对象可能不被垃圾回收
垃圾回收并不等于C++中的destructor
垃圾回收只与内存有关
java允许在类中创建一个名为finalize()的方法做终结处理,但该函数一般不是来给你做内存释放这类动作的!
建议: 如果是进行除释放存储空间之外的清理工作(如关闭文件句柄等),还是由程序员来明确地调用某个恰当的方法关于枚举类型
java中enum也是一个类,拥有自己的方法
举例:
// 定义一个枚举类型 public enum Spiciness { NOT, MILD, MEDIUM } // 使用枚举类型 Spiciness howHot = Spiciness.MEDIUM; System.out.println(howHot); // ① 打印 MEDIUM for( Spiciness s : Spiciness.values() ) { System.out.println( s + ", ordinal " + s.ordinal() ); } // output: // NOT, ordinal 0 // MILD, ordinal 1 // MEDIUM, ordinal 2 Spiciness exam = Spiciness.MILD; switch( exam ) { case NOT: ... case MILD: // 所以这个case一定会走到这个分支! ... case MEDIUM: ... default: ... }
由上面的例子可以看出:
编译器自动在enum中添加了tostring()方法,所以上面的①处可以打印出MEDIUM
编译器自动在enum中创建了ordinal()方法用来表示某个enum常量的声明顺序
编译器自动在enum中创建了static的values()方法,用来按照enum常量的声明顺序来生成由这些常量值所构成的数组
switch和enum是绝配啊!
文章版权归作者所有,未经允许请勿转载,若此文章存在违规行为,您可以联系管理员删除。
转载请注明本文地址:https://www.ucloud.cn/yun/68138.html
摘要:非内部类通过一个特殊的链接到其外围类的对象,而类型的内部类无此引用。 showImg(https://segmentfault.com/img/remote/1460000012925199); 用thinkpad打字确实很爽啊! Thinking in java系列博文目录: Java编程思想学习录(连载之:一切都是对象) Java编程思想学习录(连载之:初始化与清理) Java...
摘要:系列博文目录编程思想学习录连载之一切都是对象编程思想学习录连载之初始化与清理编程思想学习录连载之内部类编程思想学习录连载之异常本篇文章将讲述关于异常的相关知识注本文首发于公众号,可长按或扫描下面的小心心来订阅基本概念使用异常来提供一致性的错 showImg(https://segmentfault.com/img/remote/1460000013228854); Thinking ...
摘要:前端技术栈还是非常庞大的,为了能够借助已经存在的轮子来造出一辆车,所以我选择了进行实践。状态的管理的状态管理依靠完成,用其来管理的所有组件状态。私有云客户端打造主页面首先是主页面,可以打开任何一个云主机系统的页面看,基本类似。 showImg(https://segmentfault.com/img/remote/1460000013930354); 【利用K8S技术栈打造个人私有...
摘要:前端技术栈还是非常庞大的,为了能够借助已经存在的轮子来造出一辆车,所以我选择了进行实践。状态的管理的状态管理依靠完成,用其来管理的所有组件状态。私有云客户端打造主页面首先是主页面,可以打开任何一个云主机系统的页面看,基本类似。 showImg(https://segmentfault.com/img/remote/1460000013930354); 【利用K8S技术栈打造个人私有...
摘要:将用户命令通过接口传送给,从而进行资源的增删改等操作。要使用编写应用程序,当下大多语言都可以很方便地去实现请求来操作的接口从而控制和查询资源,但本文主要是利用已有的客户端来更加优雅地实现的资源控制。 showImg(https://segmentfault.com/img/remote/1460000013517345); 【利用K8S技术栈打造个人私有云系列文章目录】 利用K8S...
阅读 3392·2023-04-25 22:45
阅读 1237·2021-11-11 16:54
阅读 2759·2019-08-30 15:44
阅读 3154·2019-08-30 15:44
阅读 1609·2019-08-30 13:55
阅读 914·2019-08-29 18:45
阅读 1160·2019-08-29 17:25
阅读 978·2019-08-29 12:59