Java学习日志 - 一篇文章解释清楚Java的引用数据类型
yund56 2025-05-06 16:34 10 浏览
在 Java 中,数据类型分为两大类:基本数据类型(primitive types)和引用数据类型(reference types)。
引用数据类型
引用数据类型是指那些变量存储的是对象的地址(内存位置),而不是对象本身。具体来说,引用数据类型包括:
- 类(Class)
- 接口(Interface)
- 数组(Array)
- 枚举(Enum)
- 记录(Record)
这类数据类型的变量其实存储的是对内存中实际对象的引用。引用数据类型的变量和对象之间的关系可以类比为“指针”和“数据”的关系(尽管 Java 本身没有显式的指针概念)。
引用数据类型的特点
- 存储的是对象的地址:引用数据类型的变量存储的是对象在内存中的地址(即引用),而不是对象的实际数据。
- 指向堆中的对象:引用数据类型的对象是存储在 Java 堆(heap)内存区域中的,变量只会存储该对象的引用(地址)。
- 可以为 null:引用数据类型的变量可以指向一个对象,也可以为 null,表示该变量没有引用任何对象。
引用数据类型的组成部分
1.类(Class)
在 Java 中,类是定义对象的模板。当我们定义一个类时,我们实际上定义了对象的结构和行为。类可以包含字段(属性)和方法(行为)。
class Person {
String name;
int age;
}
当我们声明 Person 类型的变量时,它会存储的是 Person 对象的引用。
Person p1 = new Person(); // p1 存储的是 Person 对象的引用
p1.name = "Alice";
p1.age = 25;
2.接口(Interface)
接口定义了一组方法的签名,类可以实现接口。接口本身不能直接实例化,但可以声明接口类型的变量,这些变量会引用实现了接口的对象。
interface Animal {
void sound();
}
class Dog implements Animal {
public void sound() {
System.out.println("Woof");
}
}
Animal myAnimal = new Dog(); // myAnimal 是 Animal 类型的引用,指向 Dog 对象
3.数组(Array)
数组是一个特殊的对象,能够存储相同类型的多个数据项。在 Java 中,数组本身是引用数据类型。
int[] numbers = new int[5]; // numbers 是一个数组类型的引用,指向数组对象
虽然数组看起来像基本数据类型(因为我们访问它们的元素时通常是通过索引),但它们的存储结构在内存中是作为对象存在的。
4.枚举(Enum)
Java 中的枚举类型也被视为引用数据类型。枚举通常用于表示一组常量。它实际上是一个特殊的类。
enum Day { MONDAY, TUESDAY, WEDNESDAY }
Day today = Day.MONDAY; // today 是一个枚举类型的引用
5. 记录类(Record)
- 引入于 Java 14,用于简化不可变数据类的定义。
示例:
public record Point(int x, int y) {}
引用数据类型与基本数据类型的比较
特点 | 基本数据类型 | 引用数据类型 |
存储的内容 | 变量直接存储数据 | 变量存储的是对象的内存地址(引用) |
默认值 | 对应类型的默认值(如 0, false, null 等) | 默认值是 null |
是否可以为 null | 不能为 null | 可以为 null |
存储位置 | 栈(stack) | 堆(heap) |
内存分配方式 | 由编译器在栈上分配 | 在堆内存中动态分配 |
引用数据类型的内存模型
- 栈(Stack):用于存储方法调用和局部变量。基本数据类型的变量会存储在栈中。
- 堆(Heap):用于存储对象实例。当你创建一个对象时,它会在堆上分配内存,引用数据类型的变量会指向这个堆上的对象。
例子:
class Car {
String model;
int year;
}
public class Main {
public static void main(String[] args) {
Car car1 = new Car(); // car1 存储的是对象引用
car1.model = "Toyota";
car1.year = 2020;
Car car2 = car1; // car2 现在引用相同的对象
car2.year = 2022;
System.out.println(car1.year); // 输出 2022,car1 和 car2 引用的是同一个对象
}
}
在这个例子中,car1 和 car2 是引用类型的变量,它们指向堆内存中的同一个 Car 对象。
总结
引用数据类型在 Java 中主要是用来存储对象的引用(地址)。它们不同于基本数据类型,后者直接存储数据。理解引用数据类型的工作原理对于更深入地掌握 Java 编程非常重要,尤其是在对象创建、内存管理和Garbage回收方面。
相关推荐
- Excel表格带单位求和不用愁!2个高效小技巧,轻松搞定!
-
我是【桃大喵学习记】,欢迎大家关注哟~,每天为你分享职场办公软件使用技巧干货!——首发于微信号:桃大喵学习记最近有小伙伴私信提问了个问题:“Excel表格数据带单位,如何快速求和?”。相信很多新手小伙...
- [office] Excel中Sumproduct函数的使用方法-
-
Excel中Sumproduct函数的使用方法-SUMPRODUCT和SUMIFS是Excel的两个最强大的函数,用于从表中返回过滤的数据。SUMPRODUCT功能更强大,但SUMIFS更快。您可以...
- SUMPRODUCT函数:关于多条件求和,不仅仅是SUMIFS,我也行!
-
文章最后有彩蛋!好礼相送!SUMPRODUCT函数,作为excel函数公式中的常用功能之一,运用及其广泛。结合它能够处理数据的功能,函数哥将它称之为多条件求和的函数,你可能有疑问了。SUMIF和SUM...
- Excel函数公式大全之利用MMULT函数计算两个数组矩阵的乘积
-
各位Excel天天学的小伙伴们大家好,欢迎收看Excel天天学出品的excel2019函数公式大全课程。今天我们依旧要学习的是Excel函数中的数学函数MMULT函数,计算两个数组的矩阵乘积。今天这个...
- Excel中的这个“万能函数”你用过吗?一个顶四个,简单又实用
-
Hello,大家好,今天跟大家分享一个Excel中的最强大的求和函数,它就是——SUMPRODUCT函数,很多人都将其称之为“万能函数”,条件求和,条件计数等一些常用的功能他就能轻松搞定,逻辑也非常的...
- 根据关键字条件求和,SUMPRODUCT函数思路清晰!
-
1职场实例小伙伴们大家好,今天我们来讲解一个关于根据关键字进行条件求和的职场真实案例,这是公众号粉丝后台留言咨询的一个问题,下面我们来通过几组简单的数据还原一下真实的办公情景。如下图所示:A列为一列地...
- Excel-万能PRODUCT函数
-
sumproduct除了可以计算乘积之和,还可以实现单条件求和(代替sumif),多条件求和(代替sumifs),单条件计数(代替countif),多条件计数(代替countifs)我总结了一个通用的...
- Excel“王者”级求和函数SUMPRODUCT,职场必学!
-
我是【桃大喵学习记】,欢迎大家关注哟~,每天为你分享职场办公软件使用技巧干货!日常工作中我们经常需要对Excel数据求和、计数,今天就跟大家分享一下Excel“王者”级求和函数SUMPRODUCT,灵...
- SUMPRODUCT函数满足“或”的要求,实现多条件求和!
-
1职场实例小伙伴们大家好,今天我们来继续讲解Excel使用中非常实用且强大的函数:SUMPRODUCT函数,上一次我们讲到了SUMPRODUCT函数实现类似SUMIFS函数多条件求和的功能。而今天我们...
- 整列数据相乘再相加sumproduct函数#excel技巧
-
今天分享一下像这种表格,我想求它的消费,也就是用它的数量去乘以单价去加上。下一个的数量乘以单价要加上,下一个数量乘以单价。如果小白会这样一步一步的去算,去单价去乘以数量,然后加上单价去乘以数量,一个一...
- 双向多条件求和,sumifs彻底不行了,但是sumproduct却能轻松搞定
-
今天我们来解决一个困扰很多Excel新手的问题,它就双向求和,所谓的双向,就是两个方向,如下图所示,我们想要根据【项目】与【费用类别】来实现动态求和效果。【项目】与【费用类别】在数据源中,一个是纵横的...
- Excel函数之Sumproduct,7个经典用法,你真的都了解吗?
-
什么是sumproduct函数以及其基本操作原理?sumproduct函数主要用于对数组中的数值进行相乘后再求和,。该函数最多支持255个参数(数组),这些数组可以是数字单元格引用或区域。它的工作流程...
- WPS-Excel表格sumproduct函数一次性算出相乘相加总额
-
excel表格单纯相加或者相乘大家都会应用,但是有时候我们需要算出相乘相加的总额,这种计算也是可以一次性算出的。今天来教大家怎样在WPS表格中,让数据一次性算出相乘相加的总额,会了这个小技巧,会方便很...
- 大神级Sumproduct公式这么好用,1分钟学会!
-
在工作中,一般用不到Sumprodct函数公式,但是真的好用,我们举工作中的3个场景来说明。1、快速相乘相加如下所示,我们各种商品有一个单价,然后对应有一些数量,我们现在需要快速汇总总金额数据有没有小...
- 万能函数Sumproduct,除了求和和计数外,还可以排名
-
在众多的Excel函数中,能同时完成求和、计数以及排名功能的函数不多,其中Sumproduct就是其中一个。一、万能函数Sumproduct:功能及语法结构。功能:返回相应区域数组乘积的和。语法结...
- 一周热门
- 最近发表
-
- Excel表格带单位求和不用愁!2个高效小技巧,轻松搞定!
- [office] Excel中Sumproduct函数的使用方法-
- SUMPRODUCT函数:关于多条件求和,不仅仅是SUMIFS,我也行!
- Excel函数公式大全之利用MMULT函数计算两个数组矩阵的乘积
- Excel中的这个“万能函数”你用过吗?一个顶四个,简单又实用
- 根据关键字条件求和,SUMPRODUCT函数思路清晰!
- Excel-万能PRODUCT函数
- Excel“王者”级求和函数SUMPRODUCT,职场必学!
- SUMPRODUCT函数满足“或”的要求,实现多条件求和!
- 整列数据相乘再相加sumproduct函数#excel技巧
- 标签列表
-
- filter函数js (37)
- filter函数excel用不了 (73)
- 商城开发 (40)
- 影视网站免费源码最新版 (57)
- 影视资源api接口 (46)
- 网站留言板代码大全 (56)
- java版软件下载 (52)
- java教材电子课本下载 (48)
- java技术的电子书去哪看 (33)
- 0基础编程从什么开始学 (50)
- java是用来干嘛的 (51)
- it入门应该学什么 (55)
- java线上课程 (55)
- 学java的软件叫什么软件 (38)
- 程序开发软件有哪些 (53)
- 软件培训 (59)
- 机器人编程代码大全 (50)
- 少儿编程教程免费 (45)
- 新代系统编程教学 (61)
- 共创世界编程网站 (38)
- 亲测源码 (36)
- 三角函数积分公式表 (35)
- 函数的表示方法 (34)
- 表格乘法的公式怎么设置 (34)
- sumif函数的例子 (34)