6. Java变量类型
在java语言中,所有的变量在使用前必须声明,声明变量的基本格式如下:
type identifier [ = value][, identifier [= value] ...] ;
格式说明:
- type:数据类型
- identifier:变量名,可以使用逗号 , 隔开来声明多个同类型变量
java支持的变量类型有:
- 局部变量:定义在方法、构造方法或语句块中的变量,作用域只限于当前方法、构造方法或语句块中。局部变量必须在使用前声明,并且不能被访问修饰符修饰。
- 成员变量:定义在类中、方法之外的变量,作用域为整个类,可以被类中的任何方法、构造方法和语句块访问。成员变量可以被访问修饰符修饰。
- 静态变量:定义在类中、方法之外的变量,并且使用
static关键字修饰,作用域为整个类,可以被类中的任何方法、构造方法和语句块访问,静态变量的值在程序运行期间只有一个副本。静态变量可以被访问修饰符修饰。 - 参数变量: 方法定义时声明的变量,作为调用该方法时传递给方法的值。参数变量的作用域只限于方法内部。
示例:
public class RunoobTest{
//成员变量
private int instanceVar;
//静态变量
private static int staticVar;
public void method(int paramVar){
//局部变量
int localVar = 10;
//使用变量
instanceVar = localVar;
staticVar = paramVar;
System.out.println("成员变量: " + instanceVar);
System.out.println("静态变量: " + staticVar);
System.out.println("参数变量: " + paramVar);
System.out.println("局部变量: " + localVar);
}
public static void main(String[] args){
RunoobTest v = new RunoobTest();
v.menthod(20);
}
}
Java参数变量
Java 中的参数变量是指在方法或构造函数中声明的变量,用于接收传递给方法或构造函数的值。参数变量与局部变量类似,但它们只在方法或构造函数被调用时存在,并且只能在方法或构造函数内部使用。
在调用方法时,我们必须为参数变量传递值,这些值可以是常量、变量或表达式。
方法参数变量的值传递方式有两种:值传递和引用传递。
- 值传递:在方法调用时,传递的是实际参数的值的副本。当参数变量被赋予新的值时,只会修改副本的值,不会影响原始值。Java 中的基本数据类型都采用值传递方式传递参数变量的值。
- 引用传递:在方法调用时,传递的是实际参数的引用(即内存地址)。当参数变量被赋予新的值时,会修改原始值的内容。Java 中的对象类型采用引用传递方式传递参数变量的值。
Java局部变量
- 局部变量声明在方法,构造方法或者语句块中
- 局部变量在方法、构造方法、或者语句块被执行的时候创建,当它们执行完成后,变量将会被销毁。
- 局部变量必须在使用前声明,并且不能被访问修饰符修饰,因为它们的作用域已经被限制在了声明它们的方法、代码块或构造函数中。
- 局部变量只在声明它的方法、构造方法或者语句块中可见,不能被其他方法或代码块访问。
- 局部变量是在栈上分配的。
- 局部变量没有默认值,所以局部变量被声明后,必须经过初始化,才可以使用。
局部变量必须在使用之前进行初始化,否则编译器会报错。初始化可以在声明时或后面的代码中进行。如果在声明时未初始化,变量将被赋予默认值,如 int 类型的变量默认为 0,boolean 类型的变量默认为 false,引用类型的变量默认为 null。
局部变量只在声明它的方法、构造方法或语句块内可见,其他方法、构造方法或语句块不能访问该局部变量。当方法、构造方法或语句块执行完毕后,局部变量将被销毁,其占用的内存也会被释放。
成员变量(实例变量)
-
成员变量声明在一个类中,但在方法、构造方法和语句块之外
-
当一个对象被实例化之后,每个成员变量的值就跟着确定了
-
成员变量在对象创建的时候创建,在对象销毁的时候被销毁
-
成员变量的值至少应该被一个方法、构造方法或者语句块引用,使得外部能够通过这些方式获取实例变量信息
-
成员变量可以声明在使用前或者使用后
-
访问修饰符可以修饰成员变量
-
成员变量对于类中的方法、构造方法或者语句块是可见的。一般情况下应该把成员变量设置为私有,通过访问修饰符可以使得成员变量对子类可见
-
成员变量具有默认值,数值型变量的默认值是0,布尔型变量的默认值是 false,引用类型变量的默认值是 null。变量的值可以在声明时指定,也可以在构造方法中指定
-
成员变量可以直接通过变量名访问,但是在静态方法以及其它类中,就应该使用完全限定名:
ObjectReference.VariableName
成员变量的声明语法为:
accessModifier type variableName
- accessModifier 表示访问修饰符,可以是public、protected、private或默认访问级别(没有显式指定访问修饰符)
- type 表示变量的类型
- variableName 表示变量的名称
与局部变量不同,成员变量的值在创建对象时被分配,即使未对其进行初始化,也会被赋予默认值,例如 int 类型的变量默认值为 0,boolean 类型的变量默认值为 false。
成员变量可以通过对象访问,也可以通类名访问(如果时静态成员变量)。如果没有显示初始化成员变量,将会被赋予默认值。可以在构造函数或者其它方法中初始化成员变量,或者通过对象或类名访问并且设置值。
示例:
public class RunoobTest{
private int a; //私有成员变量
public String b ="Hello!"; //共有成员变量
public static void main(String[] args){
RunoobTest obj = new RunoobTest(); //创建对象
obj.a = 10; //访问成员变量a,设置值为10
System.out.println("a = " + obj.a);
obj.b = "World!";
System.out.println("b = " + obuj.b);
}
}
类变量(静态变量)
java中的静态变量是指类中定义的一个变量,它与类相关而不是与实例相关,无论创建多少个类实例,静态变量在内存中只有一份拷贝,被所有实例共享。
静态变量在类加载时被创建,整个程序运行期间都存在。
定义方式
静态变量的定义方式是在类中使用 static 关键字修饰变量,通常也称为类变量。
访问方式
由于静态变量是与类相关的,因此可以通过类名来访问静态变量,也可以通过实例名来访问静态变量。
生命周期
静态变量的生命周期与程序的生命周期一样长,即它们在类加载时被创建,在整个程序运行期间都存在,直到程序结束才会被销毁。因此,静态变量可以用来存储整个程序都需要使用的数据,如配置信息、全局变量等。
初始化时机
静态变量在类加载时被初始化,其初始化顺序与定义顺序有关。
如果一个静态变量依赖于另一个静态变量,那么它必须在后面定义。
常量与静态变量的区别
常量也是与类相关的,但它是用 final 关键字修饰的变量,一旦被赋值就不能再修改。
与静态变量不同的是,常量在编译时就已经确定了它的值,而静态变量的值可以在运行时改变。
静态变量是与类相关的变量,具有唯一性和共享性,可以用于存储整个程序都需要使用的数据,但需要注意初始化时机和与常量的区别。
静态变量的访问修饰符
静态变量的访问修饰符可以是 public、protected、private 或者默认的访问修饰符(即不写访问修饰符)。
需要注意的是,静态变量的访问权限与实例变量不同,因为静态变量是与类相关的,不依赖于任何实例。
静态变量的线程安全性
由于静态变量是共享的,所以需要注意其线程安全性。多个线程同时对静态变量进行读写操作可能会导致数据不一致或者出现静态条件。因此,在多线程环境中使用静态变量时需要进行同步操作或者使用线程安全的方式访问。
命名规则
静态变量的命名规范与实例变量相同,一般采用驼峰命名法,并且要用 static 关键字明确标识。
public static int MAX_COUNT = 100;
静态变量的使用场景
- 存储全局状态或配置信息
- 计数器或统计信息
- 缓存数据或共享资源
- 工具类的常量或方法
- 单例模式中的实例变量
示例:
public class AppConfig {
//静态变量+常量
public static final String APP_NAME = "MyApp";
public static final String APP_VERSION = "1.0.0";
public static final String DATABASE_URL = "jdbc:mysql://localhost:3306/mydb";
public static void main(String[] args) {
System.out.println("Application name: " + AppConfig.APP_NAME);
System.out.println("Application version: " + AppConfig.APP_VERSION);
System.out.println("Database URL: " + AppConfig.DATABASE_URL);
}
}