为什么要有static关键字
- 想要创建一个存储区域在存储数据,它可以不依赖于对象存在,即使是多个对象也共享的同一种数据。
- 另外一种是,希望这个数据或者方法即使不创建对象也能调用。
static重要的用途就是在不创建对象的前提下,调用哪个方法
高精度数字
- BigInteger和BigDecimal速度相对int和float速度慢一些,但是精度更高。
- BigInteger 支持任意精度的整数。也就是说,我们可精确表示任意大小的整数值,同时在运算过程中不会丢失任何信息。
- BigDecimal 支持任意精度的定点数字。例如,可用它进行精确的币值计算
六种内存分配方式
寄存器。这是最快的保存区域,因为它位于和其他所有保存方式不同的地方:处理器内部。然而,寄存器的数量十分有限,所以寄存器是根据需要由编译器分配。我们对此没有直接的控制权,也不可能在自己的程序里找到寄存器存在的任何踪迹。
堆栈。驻留于常规 RAM(随机访问存储器)区域,但可通过它的“堆栈指针”获得处理的直接支持。堆栈指针若向下移,会创建新的内存;若向上移,则会释放那些内存。这是一种特别快、特别有效的数据保存方式,仅次于寄存器。创建程序时, Java 编译器必须准确地知道堆栈内保存的所有数据的“长度”以及“存在时间”。这是由于它必须生成相应的代码,以便向上和向下移动指针。这一限制无疑影响了程序的灵活性,所以尽管有些 Java 数据要保存在堆栈里—— 特别是对象句柄,但 Java 对象并不放到其中。
堆。一种常规用途的内存池(也在 RAM 区域),其中保存了 Java 对象。和堆栈不同,“内存堆”或“堆”( Heap)最吸引人的地方在于编译器不必知道要从堆里分配多少存储空间,也不必知道存储的数据要在堆里停留多长的时间。因此,用堆保存数据时会得到更大的灵活性。要求创建一个对象时,只需用new 命令编制相关的代码即可。执行这些代码时,会在堆里自动进行数据的保存。当然,为达到这种灵活性,必然会付出一定的代价:在堆里分配存储空间时会花掉更长的时间!
静态存储。这儿的“静态”( Static)是指“位于固定位置”(尽管也在 RAM 里)。程序运行期间,静态存储的数据将随时等候调用。可用 static 关键字指出一个对象的特定元素是静态的。但 Java 对象本身永远都不会置入静态存储空间。
常数存储。常数值通常直接置于程序代码内部。这样做是安全的,因为它们永远都不会改变。有的常数需要严格地保护,所以可考虑将它们置入只读存储器( ROM)。
非 RAM 存储。若数据完全独立于一个程序之外,则程序不运行时仍可存在,并在程序的控制范围之外。其中两个最主要的例子便是“流式对象”和“固定对象”。对于流式对象,对象会变成字节流,通常会发给另一台机器。而对于固定对象,对象保存在磁盘中。即使程序中止运行,它们仍可保持自己的状态不变。对于这些类型的数
成员变量初始化顺序
static修饰的变量自上而下的初始化一遍,并且只是第一遍初始化
成员变量自上而下初始化
构造器顺序为:
- static修饰的变量自上而下的初始化一遍,并且只是第一遍初始化
- 成员变量自上而下初始化
- 构造器
形式参数和实际参数的区别
int storage(String s) {
return s.length() * 2;
}
上面的s就是形式参数
语句中s是实际参数
javadoc注释注意要点
注意 javadoc 只能为 public(公共)和 protected(受保护)成员处理注释文档。“ private”(私有)和“友好”(详见 5 章)成员的注释会被忽略,我们看不到任何输出(也可以用-private 标记包括 private 成员)。这样做是有道理的,因为只有 public 和 protected 成员才可在文件之外使用,这是客户程序员的希望。
private关键字补充
将一个类的默认构造器定义为private,可以不让其他类继承这个类。
目前已知两种防止其他类继承自己的方法,上面将默认构造器定义成private是一种,还有一种是定义成final类。
final修饰基本数据类型和引用数据类型的异同
修饰基本数据类型时,会将值编程一个常数,不可改变
修饰引用数据类型时,必须将引用初始化,并且该引用不能再指向另一个对象。