第1个回答 推荐于2018-02-28
你理解混了。
我们要看你这句int a处于什么地方,如果是在方法内部中被执行到,也就是说是局部变量,就会在栈内存中分配内存,由于是int型,所以就是4字节,也就是32bit,long类型的才会是64bit。
而你说的表示地址我们称为堆内存。创建的对象以及对象中的方法和数据是存储在堆内存中的。JVM会在栈内存中建立对象的引用,然后当执行到new语句时,在堆内存中创建对象,这时就将这个对象的类型以及这块区域的内存地址值赋给引用,然后进行对象中数据的初始化。也就是说,对象的引用存储在栈内存中,存放的是类型以及hash值,如Integer@0xff67。而对象里的内容实际上是存储在堆内存中的。
如果你这句int a只是在某个对象内作为成员变量,那么根本不会涉及到栈内存。a就存储在它所在的那个对象的堆内存中。明白了么?
java的内存区分,除了栈内存、堆内存,还有方法区以及字符串的串池等。如果你有兴趣,可以去搜搜看。骚年,努力吧!本回答被网友采纳
第2个回答 2014-09-18
确实会占用,你的理解是正确的。Java变量在内存中的储存分为引用和值两部分。就基本类型的局部变量而言,如果两个变量具有相同的值,那么他们就是指向相同地址的不同引用。比如int a = 5;int b = 5;那么a和b在内存中占有不同的引用所在的空间,但指向相同的值(即5)所在的空间。但是,关注一个未初始化的变量是否占有内存意义是不大的,因为Java语言规定,要使用变量,变量必须初始化(即使是看似可以不初始化的成员变量,其声明时仍然有默认的初始值)。从业务逻辑的角度上来看,未初始化的变量也是无法被使用的。因此一般情况下我们会笼统地将变量的引用和变量的值所占的空间统一起来看,不会单纯地分开来看。如果两个引用指向同一个对象,我们会认为两个引用使用的是同一个地址,而不会细节到两个不同的引用地址和一个值地址。
如果说的不对还请见谅,希望能解决你的疑惑。
第3个回答 2019-12-06
要看你这句int a处于什么地方,如果是在方法内部中被执行到,也就是说是局部变量,就会在栈内存中分配内存,由于是int型,所以就是4字节,也就是32bit,long类型的才会是64bit。
而你说的表示地址我们称为堆内存。创建的对象以及对象中的方法和数据是存储在堆内存中的。JVM会在栈内存中建立对象的引用,然后当执行到new语句时,在堆内存中创建对象,这时就将这个对象的类型以及这块区域的内存地址值赋给引用,然后进行对象中数据的初始化。也就是说,对象的引用存储在栈内存中,存放的是类型以及hash值,如Integer@0xff67。而对象里的内容实际上是存储在堆内存中的。
如果你这句int a只是在某个对象内作为成员变量,那么根本不会涉及到栈内存。a就存储在它所在的那个对象的堆内存中。明白了么?
第4个回答 2014-09-18
看不懂你说什么,不过好像大致没错,你说的这种情况和普通对象类似.
简单说,栈存的是地址,堆存的是具体数据
你说的没有赋值的基本类型,比如方法中的基本类型就这样的情况
不过不赋处置,编译器都过不了
不赋初值的不是你说的这种情况