Java中声明、定义、赋值、初始化、变量、引用、创建的区别
在编程开发的过程中,我们经常会接触到定义、声明、创建、赋值、初始化、变量、引用这些词,深挖下去,这些词的细微区别到底是啥,下面这些语句又有什么区别?
int a;
int a=1;
a=2;
String s;
String s=null;
String s=“123”;
String s=new String("123);
变量
- 变量分普通变量和引用型变量
- 由基本数据类型定义的变量称为普通变量,由类、数字、接口类型定义的变量称为引用型变量
声明
例:int a;
类 对象名;
- 声明的对象是一个变量,字面上理解是说明的意思,意为向编译器说明有这个变量的存在
- 向编译器说明这个变量的类型和名字的过程就叫声明
- 声明不需要分配储存空间,只作用于编译器
定义
例:int a=0;;
类 对象名=new 类();
- 声明变量并进行初始化的过程叫做定义,定义的方式包括声明、引用、创建、初始化
- 它与声明的区别在于是否分配存储空间
- 定义不是一个狭隘的词,还用在函数的定义和类的定义中
初始化
- 从无到有叫初始化
- 在定义变量时的赋值或引用的过程即为初始化,可理解为第一次赋值或引用
赋值
- 普通变量值传递的过程
- 区别与初始化是值的覆盖,也就是对于已经定义好的变量,重新给出值
- 普通变量赋值可以不断更新栈中存储的数据,而对象引用用的是同一块堆内存
引用
例:类 对象名=new 类();
int [] arr=new int[1];
- 变量名 = 对象;这个=的过程就是引用;也称变量名指向一个对象
- 注意创建的变量名储存在栈中,而引用是指向堆内存,栈中存的是堆内存的首地址,也就是指针,因此,普通类型变量只在栈区占用一块内存,而引用类型变量要在栈区和堆区各占一块内存。
- 引用的是对象,这个对象可以由数组,类,接口创建,它们共同特点是都存储在堆内存中
创建
- 形式:new 类();
- 对于引用型变量,在内存中new(开辟)空间的过程称为创建,开辟的内存空间为堆内存
理清它们之间的区别之后,下面这些面试题应该就能轻易对答了
- int a;
声明了一个类型为int,变量名为a的普通变量;
- int a=1;
定义了一个类型为int,变量名为a,初始化值为1的普通变量;
- a=2;
给已经声明了的变量a赋值为2;
- String s;
声明了一个类型为String 类,变量名为s的引用型变量
- String s=null;
定义了一个类型为String 类,变量名为s的引用型变量,初始化值为空;
- String s=“123”;
"123"存储在String 常量池中,s指向存储"123"的地址
(常量池:常量池在编译期间就将一部分数据存放于该区域,包含以final修饰的基本数据类型的常量值、String字符串) - String s=new String(“123”);
定义了一个类型为String 类,变量名为s的引用型变量,创建一个String对象初始化值为"123"
对于变量声明是否分配地址的解释:
首先栈中的数据共享:已存在的值不会再次创建
int a = 3;
int b = 3;
编译器先处理 int a = 3;首先它会在栈中创建一个变量为 a 的引用,然后查找有没有字面值为3的地址,没找到,就开辟一个存放3这个字面值的地址,然后将 a 指向3的地址。接着处理 int b = 3;在创建完 b 这个引用变量后,由于在栈中已经有3这个字面值,便将 b 直接指向3的地址。这样,就出现了 a 与 b 同时均指向3的情况。同理Java中引用数据类型变量的内存分配是在创建对象时进行的。
附加:
int a=2;a是基本数据类型变量,存在栈中。2是基本数据类型常量,存在常量池中。
String a=“2”;a是对象的引用,存在栈中。“2”是字符串常量,存在长,常量池中。