数组的定义和原理-创新互联
目录
创新互联公司2013年成立,是专业互联网技术服务公司,拥有项目网站制作、成都网站设计网站策划,项目实施与项目整合能力。我们以让每一个梦想脱颖而出为使命,1280元良庆做网站,已为上家服务,为良庆各地企业和个人服务,联系电话:18982081108一、数组的定义
方式一
方式二
方式三
二、数组的原理
JVM的内存划分
运行原理
三、数组的常见操作异常
数组越界异常
数组空指针异常
一、数组的定义
数组:数组表示的是一串连续的存储空间。数组既可以存储基本数据类型,也可以存储引用数据类型。
方式一数组存储的数据类型[ ] 数组名字 = new 数组存储的数据类型[长度];
举例:定义可以存储5个整数的数组容器
int[] arr = new int[5];
注意:数组有定长特性,长度一旦指定,不可更改。
方式二数据类型[ ] 数组名 = new 数据类型[ ]{元素1,元素2,元素3...};
举例:定义存储1,2,3,4,5整数的数组容器
int[] arr = new int[]{1,2,3,4,5};
方式三数据类型[ ] 数组名 = {元素1,元素2,元素3...};
举例:定义存储1,2,3,4,5整数的数组容器
int[] arr = {1,2,3,4,5};
二、数组的原理
JVM的内存划分想搞清楚数组的原理首先要清楚JVM的内存划分
区域名称 | 作用 |
寄存器 | 给CPU使用的 |
本地方法区 | JVM在使用操作系统功能的时候使用,如native修饰的内容 |
方法区 | 存储可以运行的class文件 |
堆内存 | 存储对象或数组(由new创建的都存储在堆内存中) |
栈内存 | 方法运行时使用的内存 |
注意:所有的函数(方法)都必须在栈内存运行,JVM只会运行处于栈内存顶部的函数,而函数被加载到栈内存的动作称为函数的压栈(入栈),函数执行完之后就会从栈中消失称为函数的弹栈(出栈)
public static void main(String[] args) {
int[] arr = new int[5];
System.out.println(arr[0]);
}
运行原理此时程序的执行流程(原理)
①:main方法进入方法栈执行
②:创建数组:JVM会在堆内存中开辟空间,存储数组
③:数组在内存中会有自己的内存地址,以十六位进制表示
④:数组中有五个元素,默认索引是0
⑤:JVM将数组的内存地址赋值给引用类型变量arr
⑥:变量arr保存的的是数组内存中的地址,而不是一个具体数值,因此称为引用数据类型
三、数组的常见操作异常 数组越界异常数组中赋值5个元素,索引是0,1,2,3,4,没有5索引,因此我们不能访问数组中不存在的索引,程序运行后会抛出数组越界异常(ArrayIndexOutOfBoundsException)
public static void main(String[] args) {
int[] arr = {1,2,3,4,5};
System.out.println(arr[5]);
}
数组空指针异常arr = null这行代码,意味着变量arr将不会再保持数组的内存地址,也就不允许再操作数组了,因此运行时会抛空指针异常(NullPointerException
)
public static void main(String[] args) {
int[] arr = {1,2,3,4,5};
arr = null;
System.out.println(arr[0]);
}
你是否还在寻找稳定的海外服务器提供商?创新互联www.cdcxhl.cn海外机房具备T级流量清洗系统配攻击溯源,准确流量调度确保服务器高可用性,企业级服务器适合批量采购,新人活动首月15元起,快前往官网查看详情吧
本文标题:数组的定义和原理-创新互联
URL地址:http://scyanting.com/article/hcipi.html