1.寄存器:最快的存储区, 由编译器根据需求进行分配,我们在程序中无法控制.
2. 栈:存放基本类型的变量数据和对象的引用,但对象本身不存放在栈中,而是存放在堆(new 出来的对象)或者常量池中(字符串常量对象存放在常量池中。)
3. 堆:存放所有new出来的对象。
4. 静态域:存放静态成员(static定义的)
5. 常量池:存放字符串常量和基本类型常量(public static final)。
6. 非RAM存储:硬盘等永久存储空间
这里我们主要关心栈,堆和常量池,对于栈和常量池中的对象可以共享,对于堆中的对象不可以共享。栈中的数据大小和生命周期是可以确定的,当没有引用指向数据时,这个数据就会消失。堆中的对象的由垃圾回收器负责回收,因此大小和生命周期不需要确定,具有很大的灵活性。
对于字符串:其对象的引用都是存储在栈中的,如果是编译期已经创建好(直接用双引号定义的)的就存储在常量池中,如果是运行期(new出来的)才能确定的就存储在堆中。对于equals相等的字符串,在常量池中永远只有一份,在堆中有多份。
如以下代码:
Java代码
1.String s1 = "china";
2.String s2 = "china";
3.String s3 = "china";
4.String ss1 = new String("china");
5.String ss2 = new String("china");
6.String ss3 = new String("china");
对于通过new产生一个字符串(假设为”china”)时,会先去常量池中查找是否已经有了”china”对象,如果没有则在常量池中创建一个此字符串对象,然后堆中再创建一个常量池中此”china”对象的拷贝对象。这也就是有道面试题:String s = new String(“xyz”);产生几个对象?一个或两个,如果常量池中原来没有”xyz”,就是两个。
对于基础类型的变量和常量:变量和引用存储在栈中,常量存储在常量池中。
如以下代码:
Java代码
1.int i1 = 9;
2.int i2 = 9;
3.int i3 = 9;
4.public static final int INT1 = 9;
5.public static final int INT2 = 9;
6.public static final int INT3 = 9;
对于成员变量和局部变量:成员变量就是方法外部,类的内部定义的变量;局部变量就是方法或语句块内部定义的变量。局部变量必须初始化。
形式参数是局部变量,局部变量的数据存在于栈内存中。栈内存中的局部变量随着方法的消失而消失。
成员变量存储在堆中的对象里面,由垃圾回收器负责回收。
如以下代码:
Java代码
1.class BirthDate {
2. private int day;
3. private int month;
4. private int year;
5. public BirthDate(int d, int m, int y) {
6. day = d;
7. month = m;
8. year = y;
9. }
10. 省略get,set方法………
11.}
12.
13.public class Test{
14. public static void main(String args[]){
15.int date = 9;
16. Test test = new Test();
17. test.change(date);
18. BirthDate d1= new BirthDate(7,7,1970);
19. }
20.
21. public void change1(int i){
22. i = 1234;
23. }
对于以上这段代码,date为局部变量,i,d,m,y都是形参为局部变量,day,month,year为成员变量。下面分析一下代码执行时候的变化:
1. main方法开始执行:int date = 9;
date局部变量,基础类型,引用和值都存在栈中。
2. Test test = new Test();
test为对象引用,存在栈中,对象(new Test())存在堆中。
3. test.change(date);
i为局部变量,引用和值存在栈中。当方法change执行完成后,i就会从栈中消失。
4. BirthDate d1= new BirthDate(7,7,1970);
d1 为对象引用,存在栈中,对象(new BirthDate())存在堆中,其中d,m,y为局部变量存储在栈中,且它们的类型为基础类型,因此它们的数据也存储在栈中。 day,month,year为成员变量,它们存储在堆中(new BirthDate()里面)。当BirthDate构造方法执行完之后,d,m,y将从栈中消失。
5.main方法执行完之后,date变量,test,d1引用将从栈中消失,new Test(),new BirthDate()将等待垃圾回收。
原博客地址:http://blog.csdn.net/yuan22003/article/details/6822221
相关推荐
### Java中变量的存储位置详解 #### 一、概述 在Java编程语言中,了解不同变量的存储位置是非常重要的,因为它直接关系到程序的性能优化和内存管理。本篇文章将详细解析Java中变量的存储位置及其特点,并通过具体的...
设置此变量的目的主要是为了让系统知道JDK的位置,以便于其他程序能够找到并使用JDK中的工具和库。 **配置步骤:** 1. **确定JDK安装路径:** 在本例中,JDK的安装路径为`C:\Program Files\Java\jdk1.6.0_45`。 ...
在计算机科学领域中,环境变量是操作系统为应用程序提供的一个标准接口,用于存储系统级别的设置信息。对于Java开发者而言,正确配置Java环境变量是确保Java程序能够正常运行的基础。本文将详细介绍如何在Windows...
Java环境变量配置是Java开发中不可或缺的一环,它使得操作系统能够找到Java开发工具集(JDK)的位置,进而运行Java程序。本教程将详细介绍如何通过一键配置的方式设置Java环境变量,以便于开发者更加高效地进行Java...
- 在系统变量中找到名为Path的变量,选中后点击“编辑”,在变量值的末尾添加%JAVA_HOME%\bin和%JAVA_HOME%\jre\bin(确保路径之间用分号隔开)。 - 新建一个名为ClassPath的系统变量,变量值填写.;%JAVA_HOME%\lib;...
- 存储位置:成员变量和类变量存储在堆内存中,而局部变量存储在栈内存中。 - 生命周期:成员变量和类变量的生命周期与对象或类的生命周期相关,局部变量的生命周期与方法调用相关。 - 访问权限:成员变量和类变量...
- 遍历每行输出,找到等号位置,并将字符串分为键值对,存储到 `Properties` 对象中。 4. **返回结果**: - 返回包含所有环境变量的 `Properties` 对象。 5. **主函数**: - 创建 `Test` 类实例并调用 `getEnv...
这意味着,不论创建多少个对象,静态变量只在内存中占用一个存储单元,所有的对象都共享这个单一的存储位置。因此,对静态变量的修改会影响到所有对象。静态变量可以通过类名直接访问,例如`Static_Demo.j`,而无需...
环境变量是在操作系统中存储特定信息的变量,比如`JAVA_HOME`指向Java开发工具的安装路径,`PATH`包含了系统能够找到可执行文件的目录路径。在Java的上下文中,`JAVA_HOME`和`PATH`是两个非常关键的环境变量。 1. *...
Java环境变量一键配置脚本是Java开发中必不可少的工具,它极大地简化了Java开发者在不同操作系统上设置环境变量的过程。通常,配置Java环境变量包括设置`JAVA_HOME`、`PATH`和`CLASSPATH`等系统变量,这些变量对正确...
- **目的**:通过设置`JAVA_HOME`、`PATH`和`CLASSPATH`等关键环境变量,使得系统能够识别Java开发工具的位置,从而在需要时调用相应的Java命令。 #### 知识点二:JAVA_HOME环境变量的配置 - **定义**:`JAVA_HOME...
**PATH**环境变量存储了一系列路径,用于指示操作系统在哪些目录中查找可执行文件。在设置了JAVA_HOME之后,为了确保在命令行中可以全局访问Java编译器和解释器,你需要更新PATH环境变量,添加`%JAVA_HOME%\bin`路径...
在IT领域,尤其是在Java开发中,正确配置环境变量是确保应用程序能够顺利运行的关键步骤之一。本文将基于给定的文件信息,深入解析“java配置环境变量”的重要性、具体步骤以及其背后的逻辑。 ### 重要性 环境变量...
JAVA_HOME变量用于存储Java开发工具集(JDK)的安装路径。它的设置确保系统能够找到Java的编译器`javac`和其他工具,如`javadoc`和`jar`。在Windows中,你可以通过编辑系统的环境变量设置来定义JAVA_HOME,将其值设...
在Windows操作系统中,环境变量是用来存储系统和用户应用程序所需配置信息的变量,例如Java的安装路径、Java开发工具(JDK)的位置等。这些变量包括JAVA_HOME、PATH和CLASSPATH,它们对于Java程序的执行至关重要。 ...