时间:2021-05-19
数组
用于存储一组同一数据类型数据的容器
数组会对放入其中的数据自动编号,编号是从0开始的---下标
定义格式
数据类型[] 数组名 = new 数据类型[数组的大小];---可以先声明再初始化
int[] arr = new int[5];---定义了一个最多能存储5的整数的数组
arr[3] = 4;
arr[3]---通过数组名[下标]的形式来获取数组元素或者给对应的位置赋值
数据类型[] 数组名 = new 数据类型[]{元素1,元素2……};
int[] arr = new int[]{2,5,1,6,8};---在定义好数组中的初始元素的同时定义好了数组的大小,不能在改变大小
数据类型[] 数组名 = {元素1,元素2……};---不可以先声明再初始化
int[] arr = {2,5,3,6,1,8,9};
内存
栈内存、堆内存、方法区、本地方法栈(和其他语言交互)、寄存器(汇编)
栈内存
可以用于存储变量,栈内存对存入其中的变量不会自动赋值,变量在使用完成之后会立即移出栈内存释放空间
堆内存
用于存储对象的,堆内存对于存入其中的元素会自动的赋予初始值---byte/short/int-0,long-0L;float-0.0f,double-0.0,char- ‘\u0000',boolean-false,引用数据类型的默认值都是null,对象使用完成之后不会立即移出堆内存,而是在不定的某个时刻被回收
数组的应用
1. 获取数组元素---数组名[下标]
2. 获取数组的长度---数组名.length
3. 遍历数组---通过获取对应下标来获取对应位置上的元素----O(n)
for(int i : arr){----增强for循环。把数组中的每个元素作为单独的变量来使用
System.out.println(i);
}
4. 数组元素排序
Arrays.sort(arr);---会自动对数组排序,默认是升序排列
5. 获取数组元素的最值---遍历
6. 获取元素的位置---遍历
如果元素有序,可以使用折半查找---O(log2n)
7. 数组的反转
8. 数组的扩容--数组的复制
int[] arr = {1,2,4,6,1};
int[] arr2 = new int[8];
System.arraycopy(源数组,源数组中的起始下标,目标数组,存放的起始下标,复制的元素的个数);
源数组 = Arrays.copyOf(源数组,扩容之后的长度);
arr = Arrays.copyOf(arr,2);
int[] arr2 = new int[2];
if(扩容之后的长度 < arr.length){
System.arraycopy(arr,0,arr2,0,扩容之后的长度)
} else {
System.arraycopy(arr,0,arr2,0,arr.length)
}
arr = arr2;
注意:
如果下标超过范围,编译无错,运行时会出现ArrayIndexOutOfBoundsException---下标越界异常
以上这篇浅谈Java数组的一些使用方法及堆栈存储就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持。
声明:本页内容来源网络,仅供用户参考;我单位不保证亦不表示资料全面及准确无误,也不保证亦不表示这些资料为最新信息,如因任何原因,本网内容或者用户因倚赖本网内容造成任何损失或损害,我单位将不会负任何法律责任。如涉及版权问题,请提交至online#300.cn邮箱联系删除。
Java中的List就是一种集合对象,将所有的对象集中到一起存储。List里面可以放任意的java对象,也可以直接放值。使用方法很简单,类似于数组。使用List
本文实例讲述了JavaScript把数组作为堆栈使用的方法。分享给大家供大家参考。具体如下:JavaScript把数组作为堆栈使用的代码范例,支持堆栈常用的pu
本文实例讲述了Java二维数组简单定义与使用方法。分享给大家供大家参考,具体如下:Java的二维数组是先创建一个一维数组,然后该数组的元素再引用另外一个一维数组
java中的可变参数使用方法可变参数时Java1.5新增的方法,可变参数方法接收0个或者多个指定类型的参数,可变参数机制通过先创建一个数组,数组的大小为在调用位
java中OkHttp的使用方法及实例概述准备研究Retrofit,而它是依赖OkHttp的,所以先使用一下OkHttp,不深究源码,只探究使用方法。以后有机会