Java数组深入
Java数组深入
内存中的数组
前边提到:数组是一种引用类型,数组引用变量只是一个引用,当它指向有效内存的时候才可以通过数组变量来访问数组元素,也就是说数组变量和数组元素在内存中是分开放的。
可以这么理解,一个人名就是一个引用变量,通过这个人名找到这个人,获取他的所有信息,就是通过引用变量访问其真实对象的过程。
例如数组int[]arr中arr是一个数组引用变量,但他并没有初始化,也就是说没有指向一块内存,所以它并不能被使用。int[]arr = new int[3]; 而这个语句则明确申请了一块三个int(12个字节)空间的内存,并让arr这个数组引用变量去指向他,以此来访问实际的数组对象。
那么,这两个东西在内存中具体在哪呢?
实际的数组对象被存在堆(heap)内存中。
数组引用变量如果是局部变量,就被存在栈(stack)内存中。
Java中的堆和栈
所有的方法中定义的局部变量都会逐个放入栈内存中,方法结束,栈内存就会销毁。
而每创建一个对象,就会被保存到堆内存中,以便反复利用,即运行时数据区,不会随方法的结束销毁,意味着,方法结束后,还可能有另一个引用变量正在指向它。注意:只有当一个对象没有任何引用变量引用它时,才会变成垃圾,被系统的垃圾回收器自动回收。
所以:想要让一个数组彻底变成“垃圾”,直接将数组变量赋值null。
如下:
int[]arr = new int[3];
arr = null;
arr[1]=0;//java.lang.NullPointerException
具体关于Java中的垃圾回收机制,以后再具体的进行总结,待补充。。
基本类型初始化
前边也提到,数组如果没有进行初始化,是不能够使用它的,那么初始化的过程在内存中又是如何体现的呢,基本类型的初始化和引用类型的初始化又有何不同呢。
对于基本数组而言,数组元素的值直接存储在对应的数组元素中。所以初始化数组时,先为数组分配内存空间,然后直接把数组元素的值放到对应的位置上。
public class Test1
{
public static void main(String[] args)
{
//定义一个int[]类型的数组变量
int[] arr;
//动态初始化数组,整型默认为0
arr = new int[4];
//利用for循环给数组每个元素赋值
for(int i = 0;i<arr.length;i++) arr[i]=i;
//打印显示数组结果
for(int i:arr) System.out.print(i+" ");//0 1 2 3
}
}
定义数组变量
动态初始化
赋值
引用类型数组的初始化
欸,数组本身就是引用类型,创建的数组元素又是引用类型,数组元素还指着另外一块内存,那里才装着有效数据。
我们知道,类是引用类型的其中一种,所以下面通过建立一个全是类的数组,关于数组,应该很快就要开始学习并总结啦,所以这块还是先肤浅地谈一谈,有待补充。
class Hero
{
public int defenseVal;
public int attackVal;
}
public class Test
{
public static void main(String[] args)
{
//定义一个students数组变量,其类型是Hero[]
Hero[] heros;
//动态初始化
heros = new Hero[2];
//创建一个Hero实例,并让Zed变量指向该实例
Hero Zed = new Hero();
//为Zed赋攻击力和防御力属性
Zed.attackVal = 95;
Zed.defenseVal = 5;
//让数组的第一个元素指向实例Zed
heros[0]=Zed;
//发现Zed和heros[0]指向同一片内存。
System.out.println(heros[0].attackVal==Zed.attackVal);
}
}
定义数组变量
动态初始化
创建实例
赋值
Java数组深入的更多相关文章
- Java 数组
数组对于每一门编程语言来说都是重要的数据结构之一,当然不同语言对数组的实现及处理也不尽相同. Java语言中提供的数组是用来存储固定大小的同类型元素. 你可以声明一个数组变量,如numbers[100 ...
- 第5章 Java数组
1.什么是数组 数组可以想象成一个巨大的盒子,这个盒子里面存放的是同一个数据类型的数据 例如:int[] scores = {78,68,94,93}; 2.如何使用Java中的数组 2.1申明数组 ...
- Java 数组基础
数组 数组(Array):相同类型数据的集合. 定义数组 方式1(推荐,更能表明数组类型) type[] 变量名 = new type[数组中元素的个数]; 比如: int[] a = new int ...
- Java数组及其内存分配
几乎所有的程序设计语言都支持数组.Java也不例外.当我们需要多个类型相同的变量的时候,就考虑定义一个数组.在Java中,数组变量是引用类型的变量,同时因为Java是典型的静态语言,因此它的数组也是静 ...
- [转载]Java数组扩容算法及Java对它的应用
原文链接:http://www.cnblogs.com/gw811/archive/2012/10/07/2714252.html Java数组扩容的原理 1)Java数组对象的大小是固定不变的,数组 ...
- Java数组技巧攻略
Java数组技巧攻略 0. 声明一个数组(Declare an array) String[] aArray = new String[5]; String[] bArray = {" ...
- Java数组扩容算法及Java对它的应用
1)Java数组对象的大小是固定不变的,数组对象是不可扩容的.利用数组复制方法可以变通的实现数组扩容.System.arraycopy()可以复制数组.Arrays.copyOf()可以简便的创建数组 ...
- Java数组与vector互转
Java数组与vector互转 /* Object[] object1 = null ; //数组定义 Vector<Object> object2;//Vector定义 object2 ...
- 比较Java数组,ArrayList,LinkedList,Vector 性能比较
public class PerformanceTester { public static final int TIMES=100000; public static abstract class ...
- Java数组的12个常用方法
以下是12个关于Java数组最常用的方法,它们是stackoverflow得票最高的问题. 声明一个数组 String[] aArray = new String[5]; String[] bArra ...
随机推荐
- Mybatis和Mysql的Datetime的一些问题
Mysql的时间类型 时间类型有time, date, datetime, timestamp 如Mysql官方文档所述: time 没有date,date没有time,datetime是date和t ...
- 设置和获取html里面的内容.html
<!DOCTYPE html> <html> <head> <meta charset="UTF-8"> <title> ...
- Nginx、WSGI、 uWSGI、 uwsgi的区别
当我们部署完一个应用程序,浏览网页时具体的过程是怎样的呢?首先我们得有一个 Web 服务器来处理 HTTP 协议的内容,Web 服务器获得客户端的请求,交给应用程序,应用程序处理完,返回给 Web 服 ...
- 面向对象的7个设计原则->开车理解->贴近生活
设计模式在我们的开发中是不可或缺的一部分,很多人会说,我没用那些设计模式啊,我也开发的挺好的,其实不然,我们在开发中都用到了这些设计模式,只不过我们并没有在意这些,今天我就用开车的方法来解释一下我们的 ...
- API gateway 之 kong 基本操作 (三)
一.演示环境准备 1.nginx配置 [root@nginx conf.d]# pwd /etc/nginx/conf.d [root@nginx conf.d]# ls conf_bak kong_ ...
- UVA12433 【Rent a Car】
这题应该算是比较难的一道网络流的题,(但却在我校OJ考试上出现了),但是大家只要能理解此图的建边方式就行. 假设有5天的租车需求,虚拟出2*n+2 即 12个节点,0为源点,12为汇点. 1,源点到1 ...
- 【PyTorch教程】P2. Python编辑器的选择、安装及配置
温馨提示:为了更好的教程体验,提供视频.阅读地址 Youtube: https://www.youtube.com/playlist?list=PLgAyVnrNJ96CqYdjZ8v9YjQvCBc ...
- [考试反思]0918csp-s模拟测试46:残存
我... 行吧大概说说. T1打的n2dp,什么随机化什么改变读入顺序都能AC. 没想优化.打了个链表优化dp.不知为何WA了. T2读错题,死了. T3的50分暴力没来得及优化感觉思路很神仙(然而并 ...
- 20190820 Tue 集训总结&NOIP模拟 27
低谷度过了? 但是skyh阿卡了,还是反衬出我的辣鸡. T1知道要sort,却忘了判重,正解不如暴力分高,555. T2成功化出正解柿子,然后化过头了,化出了无法DP的柿子. 果然不够强,大神们一眼就 ...
- Flink中发送端反压以及Credit机制(源码分析)
上一篇<Flink接收端反压机制>说到因为Flink每个Task的接收端和发送端是共享一个bufferPool的,形成了天然的反压机制,当Task接收数据的时候,接收端会根据积压的数据量以 ...