一文读懂java变量类型
前言
在学习和使用Java编程语言时,理解变量类型是至关重要的基础知识。Java是一种静态类型语言,强调变量必须先声明其类型,才能进行后续操作。因此,对于初学者来说,了解Java中不同的变量类型及其特性是迈向编程成功的第一步。
本文旨在帮助大家快速、简洁地了解Java的变量类型,从而提升对编程语言的理解和应用能力。无论您是初学者还是有一定经验的开发者,我相信这篇文章将对您有所帮助。
在接下来的内容中,我将全面涵盖Java中的基本数据类型、引用数据类型以及如何声明和使用不同类型的变量。通过清晰的说明、实例代码和有趣的示意图,我将简化复杂的概念,使小伙伴们能够轻松掌握并运用Java的各种变量类型。
有哪些变量类型?
按照访问权限划分:
- 局部变量:只在其所在的范围内有效 - 方法中的局部变量
 
  public void exampleMethod() {int num = 10; // 在方法内部声明并初始化局部变量numSystem.out.println(num); // 输出结果为10}
- 构造函数中的局部变量
 public class ExampleClass {public ExampleClass() {int num = 20; // 在构造函数内部声明并初始化局部变量numSystem.out.println(num); // 输出结果为20}}
- 代码块中的局部变量
 public void exampleMethod() {{int num = 30; // 在代码块内部声明并初始化局部变量numSystem.out.println(num); // 输出结果为30}}
- for循环中的局部变量
 public void exampleMethod() {for (int i = 0; i < 5; i++) {int num = i; // 在for循环内部声明并初始化局部变量numSystem.out.println(num); // 输出结果依次为0, 1, 2, 3, 4}}
- 类变量:用关键字 static 在类中定义的变量,被所有对象共享,也称为静态变量 - 类方法中的类变量
 
 public class ExampleClass {private static int count; // 在类中声明类变量countpublic static void incrementCount() {count++; // 在类方法中使用类变量count}public static void main(String[] args) {incrementCount(); // 调用类方法修改类变量countSystem.out.println(count); // 输出结果为1}}
- 构造函数中的类变量
 public class ExampleClass {private static int count; // 在类中声明类变量countpublic ExampleClass() {count++; // 在构造函数中使用类变量count}public static void main(String[] args) {ExampleClass obj1 = new ExampleClass(); // 创建对象实例,调用构造函数ExampleClass obj2 = new ExampleClass(); // 创建另一个对象实例,调用构造函数System.out.println(count); // 输出结果为2,因为两次构造函数调用都修改了类变量count}}- 实例变量: 在类中定义的变量,每个对象都有自己的一份 - 在实例方法中使用实例变量
 
  public class ExampleClass {private int count; // 在类中声明实例变量countpublic void incrementCount() {count++; // 在实例方法中使用实例变量count}public static void main(String[] args) {ExampleClass obj = new ExampleClass(); // 创建对象实例obj.incrementCount(); // 调用实例方法修改实例变量countSystem.out.println(obj.count); // 输出结果为1,访问对象实例的实例变量count}}
- 构造函数中的实例变量
 public class ExampleClass {private int count; // 在类中声明实例变量countpublic ExampleClass() {count = 10; // 在构造函数中初始化实例变量count}public static void main(String[] args) {ExampleClass obj = new ExampleClass(); // 创建对象实例System.out.println(obj.count); // 输出结果为10,访问对象实例的实例变量count}}
- 被 final 关键字 修饰的变量: 当一个变量被 final 修饰时,它表示该变量是一个常量,一旦赋值后就不能再改变 ,因此final 修饰符可以用于实例变量、局部变量和方法参数,但无法用于类(因为类无法被继承)。 - final实例变量
 
 public class ExampleClass {private final int count; // 声明一个 final 实例变量public ExampleClass() {count = 10; // 在构造函数中为 final 实例变量赋值}public static void main(String[] args) {ExampleClass obj = new ExampleClass(); // 创建对象实例// obj.count = 20; // 错误!无法修改 final 实例变量的值System.out.println(obj.count); // 输出结果为10}}
- final 局部变量
 public class ExampleClass {public static void main(String[] args) {final int number = 5; // 声明一个 final 局部变量// number = 10; // 错误!无法修改 final 局部变量的值System.out.println(number); // 输出结果为5}}
常规分类
- 基本数据类型 - 整数类型:byte、short、int、long
- 浮点数类型:float、double
- 字符类型:char
- 布尔类型:boolean
 
- 引用数据类型 - 类:使用关键字 class 定义的自定义类型。
- 接口:使用关键字 interface 定义的接口类型。
- 数组:使用关键字 [] 创建的一组具有相同类型的数据元素。
 
- 特殊类型 - null 类型:表示变量不引用任何对象。
- void 类型:表示方法没有返回值。
 
如何声明和使用
整数类型:
javaCopy Codebyte byteVariable = 127;
short shortVariable = 32767;
int intVariable = 2147483647;
long longVariable = 9223372036854775807L; // 注意:long类型的值后面需要加上"L"表示长整型System.out.println(byteVariable);
System.out.println(shortVariable);
System.out.println(intVariable);
System.out.println(longVariable);
浮点数类型:
javaCopy Codefloat floatVariable = 3.14f; // 注意:float类型的值后面需要加上"f"表示单精度浮点数
double doubleVariable = 3.1415926535;System.out.println(floatVariable);
System.out.println(doubleVariable);
字符类型:
javaCopy Codechar charVariable = 'A';
String stringVariable = "Hello";System.out.println(charVariable);
System.out.println(stringVariable);
布尔类型:
javaCopy Codeboolean booleanVariable = true;System.out.println(booleanVariable);
引用数据类型(类、接口、数组):
javaCopy Codeclass MyClass {// 类定义
}interface MyInterface {// 接口定义
}int[] intArray = {1, 2, 3, 4, 5}; // 创建一个整数类型的数组MyClass myObject = new MyClass(); // 创建一个类的实例MyInterface myInterface = new MyInterface() {// 匿名内部类实现接口
};
特殊类型:
javaCopy CodeObject nullObject = null; // null类型void myVoidMethod() {// void类型方法,无返回值
}
初始化位置、作用范围
+---------------+-------------+-------------------+-----------------+
|   变量类型     | 初始化位置   |      作用范围      |    变量类型      |
+---------------+-------------+-------------------+-----------------+
|  局部变量      | 方法、构造   |   声明所在的方法    | 基本类型或引用   |
|               | 函数或代码   |   或代码块中可见    | 类型            |
|               | 块          |                   |                 |
+---------------+-------------+-------------------+-----------------+
|  类变量        | 类中声明     | 所有方法、构造函数  | 基本类型或引用   |
|               |             | 和代码块都可访问    | 类型            |
|               |             |                   |                 |
+---------------+-------------+-------------------+-----------------+
|  final 变量   | 声明或构造    | 与上下文相关       | 基本类型或引用    |
|               | 函数中初始化  |                  | 类型             |
+---------------+-------------+-------------------+-----------------+
|  实例变量      | 类中声明     | 对象实例可访问      | 基本类型或引用   |
|               |             |                   | 类型            |
+---------------+-------------+-------------------+-----------------+
他们的相同点和不同点
相同点
-  声明位置: - 局部变量、类变量、final 修饰的变量和实例变量都是在类的内部进行声明。
- 它们都需要指定变量的类型和名称。
 
-  访问修饰符: - 局部变量、类变量、final 修饰的变量和实例变量都可以使用访问修饰符来限制对其的访问(例如,public、private、protected)。
 
-  变量类型:局部变量、类变量、final 修饰的变量和实例变量可以是任何基本类型或引用类型。 不同点 - 初始化位置: - 局部变量:在方法、构造函数或代码块中声明,并且在使用前进行初始化。
- 类变量:在类中声明,可以在声明时初始化或在静态代码块中初始化。
- final 修饰的变量:可以在声明时初始化或在构造函数中初始化。
- 实例变量:在类中声明,可以在声明时初始化或在构造函数中初始化。
 
- 作用范围: - 局部变量:只在其所在的方法、构造函数或代码块中可见。
- 类变量:整个类中的所有方法、构造函数和代码块都可以访问类变量。
- final 修饰的变量:与其它变量类型类似,作用范围取决于其所在的上下文。
- 实例变量:每个类的实例(对象)都有自己的实例变量副本,只能通过对象进行访问。
 
 
- 初始化位置: 
总结
局部变量、类变量、被 final 关键字修饰的变量和实例变量在初始化位置和作用范围上有所不同。
-  它们都是在类的内部进行声明,并且可以使用访问修饰符来限制对其的访问。 
-  变量类型可以是任何基本类型或引用类型。 变量之间的 持久性和作用范围的 大小关系(final可以是局部变量、实例变量或类变量 这里不做比较) 

按作用范围从小到大排序,可以按照以下顺序:
- 局部变量:局部变量的作用范围限制在声明它的方法、构造函数或代码块内部。它们只能在声明所在的范围内使用,超出范围后就无法访问。
- 实例变量:实例变量是定义在类中、方法之外的变量。每个类的实例都拥有自己的实例变量副本,在整个类的所有成员方法中都可以访问和修改这些变量。
- 类变量(静态变量):类变量属于整个类而不是特定的实例。它们在类加载时被初始化,并且在整个类的所有实例之间共享相同的值。类变量可以通过类名直接访问。
按持久性从小到大分类变量可以按照以下顺序:
- 局部变量:局部变量的生命周期仅限于包含它们的方法、构造函数或代码块的执行过程。当方法执行完毕或代码块结束时,局部变量将被销毁。
- 实例变量:实例变量属于类的实例,并且在创建对象时被初始化。它们在对象被销毁之前一直存在,即对象存在,实例变量也存在。
- 类变量(静态变量):类变量属于整个类而不是特定的实例。它们在类加载时被初始化,且在整个程序运行期间都存在。即使没有创建类的实例,类变量也可以被访问。
与线程安全相关知识点
-  static 变量 
 当多个线程同时访问和修改类变量时,可能会出现以下线程安全问题:- 竞态条件(Race Condition):如果多个线程同时对类变量进行写操作或读写操作,可能导致不可预测的结果。例如,一个线程正在修改类变量的值,而另一个线程同时在读取该变量的值,可能导致读取到不一致或过时的数据。
- 内存可见性问题(Visibility Problem):当一个线程修改了类变量的值后,其他线程可能无法立即感知到这个变化。这是因为每个线程都有自己的工作内存,它们可能将类变量的副本保存在各自的工作内存中。因此,其他线程可能仍然访问的是旧值。
- 并发更新问题(Concurrent Update Problem):当多个线程同时对类变量进行修改时,可能会导致数据不一致性。例如,多个线程同时递增一个类变量的值,最终结果可能不符合预期。
 如图所示:
  
 要解决类变量的线程安全问题,可以采取以下措施: - 使用同步机制:通过使用关键字 synchronized 或使用锁(如 ReentrantLock)来保证同一时间只有一个线程能够访问类变量,从而避免竞态条件和内存可见性问题。
- 使用原子操作:可以使用原子类(如 AtomicInteger)来执行对类变量的原子操作,保证线程安全。
- 避免共享:如果类变量不需要共享,并且每个线程都需要拥有自己的副本,可以将类变量声明为局部变量或实例变量,以避免线程安全问题。
 需要根据具体情况选择适当的线程安全措施,并在设计和编写代码时考虑到多线程环境下的并发访问问题。
 
-  局部变量 
在局部变量中引用了一个对象,且该对象本身存在线程安全问题,那么在访问该对象时仍然需要采取适当的同步措施,以避免线程安全问题的发生。
例如:引入形参或者有返回值的情况下就会有线程安全问题
 解决方法与上面类似,需要采取适当的同步机制。
相信有一定基础的小伙伴已经发现了,final关键字修饰的变量可以是 : 成员变量 类变量 局部变量
不过作者认为final关键字修饰的变量比较特殊,就拿出来和其他变量一起介绍啦。
相关文章:
 
一文读懂java变量类型
前言 在学习和使用Java编程语言时,理解变量类型是至关重要的基础知识。Java是一种静态类型语言,强调变量必须先声明其类型,才能进行后续操作。因此,对于初学者来说,了解Java中不同的变量类型及其特性是迈向编程成功的…...
 
解决windows下git操作提示用户名密码错误的问题
当代码从一个平台切换到另一个平台的时候,需要做两步操作,第一步就是更新git的仓库地址,在项目的.git/config文件里面修改,这一步做完之后,就可以推送代码到新的仓库了,这里就是重点来了。 一般第一次推动代…...
 
ESP32开发:Clion配置IDF
IDF环境搭建 使用安装包安装IDF 可以通过安装包进行安装,如下图: 下载链接如下:https://dl.espressif.cn/dl/esp-idf/?idf4.4 安装好后,IDF会添加环境变量IDF_TOOLS_PATH,如果要安装多个IDF,为了防止冲…...
 
伦敦金的走势高低的规律
伦敦金市场是一个流动性很强的市场,其价格走势会在诸多因素的影响下,出现反复的上下波动,如果投资者能够在这些高低走势中找到一定的规律,在相对有利的时机入场和离场,就能够通过不断的交易,累积大量的财富…...
 
【C#-1】C#调用matlab生成的dll库
matlab打包dll 1、matlab示例程序: function untitled4(x)z peaks(x);figuresurf(z) end 2、输入deploytool打包matlab程序,具体如下: 3、拷贝 打包成功后,将生成for_redistribution_files_only文件夹中的dll文件拷贝到C#程序…...
MATLAB中pdist和pdist2的区别
一、pdist 和 pdist2 是MATLAB中用于计算距离矩阵的两个不同函数,它们的区别在于输入和输出以及一些计算选项。 pdist: pdist函数用于计算一组点之间的距离。 输入:通常接受一个矩阵,矩阵的每一行代表一个数据点,矩阵的列代表数据…...
 
直播平台源码开发搭建APP的DASH协议:流媒体技术其中一环
在直播平台源码APP中,有着许许多多、多种多样的功能,比如短视频功能,帮助我们去获取信息,看到全世界用户身边发生的事情或是他们的生活;又比如直播功能,为用户提供了实时的娱乐享受,还让一些用户…...
【前端】js解码base64
【前端】js解码base64 //不会乱码 function strTob(base64) {// 对base64转编码var decode atob(base64)decode escape(decode)// 编码转字符串var str decodeURIComponent(decode)return str } atob 中文乱码的解决方案 decode escape(decode) // 编码转字符串 v…...
 
Apipost:API开发者的协同工作神器
在当今快速发展的数字化时代,API已成为企业与开发者实现数据互通、应用集成的重要桥梁。然而,随着API数量的不断增加,API开发、调试、测试、文档等工作也变得越来越复杂。为了解决这一痛点,一款名为Apipost的API协同研发工具应运而…...
 
照片动起来软件有哪些?试试这几个
照片动起来软件有哪些?将照片动起来可以让照片更加生动有趣,让人们更容易吸引到你的照片。在社交媒体和短视频的时代,人们需要更多的方式来吸引别人的注意力。让照片动起来可以让你的照片变得更加生动、更加有趣,让人们更容易停留…...
【LeetCode】146.LRU缓存
题目 请你设计并实现一个满足 LRU (最近最少使用) 缓存 约束的数据结构。 实现 LRUCache 类: LRUCache(int capacity) 以 正整数 作为容量 capacity 初始化 LRU 缓存int get(int key) 如果关键字 key 存在于缓存中,则返回关键字的值,否则…...
 
2021-2023顶会190+篇ViT高分论文总结(通用ViT、高效ViT、训练transformer、卷积transformer等)
今天分享近三年(2021-2023)各大顶会中的视觉Transformer论文,有190篇,涵盖通用ViT、高效ViT、训练transformer、卷积transformer等细分领域。 全部论文原文及开源代码文末直接领取 General Vision Transformer(通用V…...
 
堆相关例子-最大线段重合问题
问题描述 给定很多线段,每个线段都有两个数[start, end], 表示线段开始位置和结束位置,左右都是闭区间 规定: 1)线段的开始和结束位置一定都是整数值 2)线段重合区域的长度必须>1 返回线段最多重合…...
Ztree的日常使用记录
1. 树节点名称中使用超文本标签 view.nameIsHTML设置为true即可 var setting {view: {nameIsHTML: true},check: {enable: true},data : {simpleData : {enable : true}} }; 2. 使用自定义的title显示 view.showTitle设置为true, 在data.key中声明title对应的字段名即可 …...
 
PYTHON 3.10中文版官方文档
大家好,我是涛哥。 很多问我涛哥学习Python看啥,一般我都会建议多看看官方文档,因为官方文档真的周到了,啥内容都有,比如新手安装,标准库, AIP参考手册,常见FAQ问题,太…...
 
TLS协议深度解析:挖掘现代网络安全防御的底层技术
正常简单的通讯 1、服务器生成一对密钥,公钥A、私钥A 2、浏览器请求服务器时,服务器把公钥A传给浏览器 3、浏览器随机生成一个对称加密的密码S,用公钥A加密后传给服务器 4、服务器接收后,用私钥A解密,得到密钥S 5、浏…...
python的time各种用法
1、time Python的time模块提供了许多用于处理时间的功能。以下是一些常用的time模块的函数及其用法,并附有示例: time():返回当前时间的时间戳(自1970年1月1日00:00:00起的秒数)。 import timecurrent_time time.t…...
Vue中使用vue-router
Vue中使用vue-router 1. 安装vue-router2. 创建路由页面3. 创建router文件4. 挂载router5. 使用 1. 安装vue-router npm install vue-router3.6.5 --save2. 创建路由页面 HomeView.vue <template><div>home</div> </template><script>export …...
 
uni-app之android原生插件开发
一 插件简介 1.1 当HBuilderX中提供的能力无法满足App功能需求,需要通过使用Andorid/iOS原生开发实现时,可使用App离线SDK开发原生插件来扩展原生能力。 1.2 插件类型有两种,Module模式和Component模式 Module模式:能力扩展&…...
 
javaee spring aop实现事务 项目结构
spring配置文件 <?xml version"1.0" encoding"UTF-8"?> <beans xmlns"http://www.springframework.org/schema/beans"xmlns:xsi"http://www.w3.org/2001/XMLSchema-instance"xmlns:context"http://www.springframewo…...
变量 varablie 声明- Rust 变量 let mut 声明与 C/C++ 变量声明对比分析
一、变量声明设计:let 与 mut 的哲学解析 Rust 采用 let 声明变量并通过 mut 显式标记可变性,这种设计体现了语言的核心哲学。以下是深度解析: 1.1 设计理念剖析 安全优先原则:默认不可变强制开发者明确声明意图 let x 5; …...
 
遍历 Map 类型集合的方法汇总
1 方法一 先用方法 keySet() 获取集合中的所有键。再通过 gey(key) 方法用对应键获取值 import java.util.HashMap; import java.util.Set;public class Test {public static void main(String[] args) {HashMap hashMap new HashMap();hashMap.put("语文",99);has…...
 
STM32F4基本定时器使用和原理详解
STM32F4基本定时器使用和原理详解 前言如何确定定时器挂载在哪条时钟线上配置及使用方法参数配置PrescalerCounter ModeCounter Periodauto-reload preloadTrigger Event Selection 中断配置生成的代码及使用方法初始化代码基本定时器触发DCA或者ADC的代码讲解中断代码定时启动…...
 
让AI看见世界:MCP协议与服务器的工作原理
让AI看见世界:MCP协议与服务器的工作原理 MCP(Model Context Protocol)是一种创新的通信协议,旨在让大型语言模型能够安全、高效地与外部资源进行交互。在AI技术快速发展的今天,MCP正成为连接AI与现实世界的重要桥梁。…...
06 Deep learning神经网络编程基础 激活函数 --吴恩达
深度学习激活函数详解 一、核心作用 引入非线性:使神经网络可学习复杂模式控制输出范围:如Sigmoid将输出限制在(0,1)梯度传递:影响反向传播的稳定性二、常见类型及数学表达 Sigmoid σ ( x ) = 1 1 +...
 
【开发技术】.Net使用FFmpeg视频特定帧上绘制内容
目录 一、目的 二、解决方案 2.1 什么是FFmpeg 2.2 FFmpeg主要功能 2.3 使用Xabe.FFmpeg调用FFmpeg功能 2.4 使用 FFmpeg 的 drawbox 滤镜来绘制 ROI 三、总结 一、目的 当前市场上有很多目标检测智能识别的相关算法,当前调用一个医疗行业的AI识别算法后返回…...
Java 二维码
Java 二维码 **技术:**谷歌 ZXing 实现 首先添加依赖 <!-- 二维码依赖 --><dependency><groupId>com.google.zxing</groupId><artifactId>core</artifactId><version>3.5.1</version></dependency><de…...
使用Matplotlib创建炫酷的3D散点图:数据可视化的新维度
文章目录 基础实现代码代码解析进阶技巧1. 自定义点的大小和颜色2. 添加图例和样式美化3. 真实数据应用示例实用技巧与注意事项完整示例(带样式)应用场景在数据科学和可视化领域,三维图形能为我们提供更丰富的数据洞察。本文将手把手教你如何使用Python的Matplotlib库创建引…...
 
C/C++ 中附加包含目录、附加库目录与附加依赖项详解
在 C/C 编程的编译和链接过程中,附加包含目录、附加库目录和附加依赖项是三个至关重要的设置,它们相互配合,确保程序能够正确引用外部资源并顺利构建。虽然在学习过程中,这些概念容易让人混淆,但深入理解它们的作用和联…...
 
手机平板能效生态设计指令EU 2023/1670标准解读
手机平板能效生态设计指令EU 2023/1670标准解读 以下是针对欧盟《手机和平板电脑生态设计法规》(EU) 2023/1670 的核心解读,综合法规核心要求、最新修正及企业合规要点: 一、法规背景与目标 生效与强制时间 发布于2023年8月31日(OJ公报&…...
