标签:类型 存储分配 byte 灵活 最快 清理 引用 编程 运行
2.1用应用操作对象
String s;
这里所创建的只是引用,并不是对象。如果此时向s发送一个消息,就会返回一个运行时错误。这是因为此时s没有和任何事物关联。因此,一种安全的做法是:创建一个引用的同时便进行初始化。
2.2必须由你创建所有对象
一旦创建了一个引用,就希望它能与一个新的对象相关联。通常用new操作符来实现这一目的。
String s = new String("asdf");
2.2.1存储到什么地方
1)寄存器。这是最快的存储区,因为它不同于其他存储区的地方——处理器内部。但是寄存器的数量及其有限,所以寄存器根据需求进行分配。你不能直接控制,也不能在程序中感觉到寄存器存在的任何迹象。
2)堆栈。位于通用RAM(随机访问存储器)中,但通过堆栈指针可以从处理器那里获取直接支持。堆栈指针向下移动,则分配新的内存;若向上移动,则释放那些内存。这是一种快速有效的分配存储方法,仅次于寄存器。创建程序时,Java系统必须知道存储在堆栈内所有项的确切生命周期,以便上下移动堆栈指针。这一约束限制了Java代码的灵活性,所以虽然某些Java数据存储在堆栈中——特别是对象引用,但是Java对象并不存储于其中。
3)堆。一种通用的内存池(也位于RAM区),用于存放所以的Java对象。堆不同于堆栈的好处是:编译器不需要知道存储的数据在堆里存活的多长时间。当需要一个对象时,只需要new写一行简单的代码,当执行这行代码时,会自动在堆里进行存储分配。当然,这种灵活性必须要付出相应的代价:用堆进行存储分配和清理可能用比堆栈进行存储分配需要更多的时间。
4)常量存储。常量值通常直接存放在程序代码内部,这样做是安全的,因为它们永远不会被改变。有时,在嵌入式系统中,常量本身会和其它部分隔离开,所以在这种情况下,可以选择将其存放在ROM(只读存储器)中。
5)非RAM存储。如果数据完全存活于程序之外,那么他可以不受程序的任何控制,在程序没有运行时也可以存在。其中两个基本的例子是流对象和持久化对象。在流对象中,对象转换为字节流,通常被发送给另一台机器。在“持久化对象”中,对象被存放于磁盘上,因此,即使程序终止,它们任可以保持自己的状态。Java提供了轻量级的持久化支持,而诸如JDBC和Hibernate这样的机制提供了更复杂的对数据库中存储和读取对象信息的支持。
2.2.2特例:基本类型
基本类型 | 大小 | 最小值 | 最大值 | 包装器类型 |
boolean | —— | —— | —— | Boolean |
char | 16bit | Unicode 0 | Unicode 216-1 | Character |
byte | 8bit | -128 | 127 | Byte |
short | 16bit | -215 | 215-1 | Short |
int | 32bit | -231 | 231-1 | Integer |
long | 64bit | -263 |
-263-1 |
Long |
float | 32bit | IEEE754 | IEEE754 | Float |
double | 64bit | IEEE754 | IEEE754 | Double |
void | —— | —— | —— | Void |
高精度数字
Java提供了两个用于高精度计算的类:BigInteger和BigDecimal。虽然它们大体上属于“包装器类”的范畴,但二者没有对应的基本类型。
BigInteger支持任意精度的整数。
BigDecimal支持任何精度的定点数。例如,可以用它进行精确的货币计算。
2.4.1字段和方法
基本成员默认值
基本类型 | 默认值 |
boolean | false |
char | ‘\uoooo‘(null) |
byte | (byte)0 |
short | (short)0 |
int | 0 |
long | 0L |
float | 0.0f |
double | 0.0d |
标签:类型 存储分配 byte 灵活 最快 清理 引用 编程 运行
原文地址:https://www.cnblogs.com/zhongli1/p/10012731.html