时间:2021-05-20
1.数组中存储元素的类型是统一的,每一个元素在内存中所占用的空间大小是相同的,知道数组的首元素的内存地址,要查找的元素只要知道下标,就可以快速的计算出偏移量,通过首元素内存地址加上偏移量,就可以快速计算出要查找元素的内存地址。通过内存地址快速定位该元素,所以数组查找元素的效率较高。
2.随机的对数组进行增删元素,当增加元素的时候,为了保证数组中元素在空间存储上是有序的,所以被添加元素位置后面的所有元素都要向后移动,删除元素也是,后面所有的元素要向前移动,所以数组的增删元素效率很低。
3.初始化一维数组,有两种方式:
(1)静态初始化;
(2)动态初始化。
package com.bjpowernode.java_learning;public class D66_1_ { public static void main(String[] args) { //静态初始化一个int类型的一维数组 int[] a1 = {10,22,21}; //取得第一个元素 System.out.println("第一个元素:" + a1[0]); System.out.println("最后一个元素:" + a1[2]); System.out.println("最后一个元素:" + a1[a1.length-1]); //去的个数 System.out.println("数组中的的元素个数为:"+a1.length); //遍历一维数组 for(int i = 0;i<a1.length;i++) { System.out.println(a1[i]); } //将第二个元素改为100 a1[1] = 100; System.out.println("==================="); for(int i= 0;i<a1.length;i++) { System.out.println(a1[i]); } }}上面是使用静态初始化一维数组,下面演示动态初始化一维数组
int[] a2 = new int[4]; //引用类型的数组 Object[] objs = new Object[3]; for(int index=0;index<objs.length;index++) { Object o = objs[index]; //o.toString();//注意空指针异常 System.out.println(o);//null null null这里就没有出现空指针异常,这是因为pirintln //这个函数的源码里面对这种空指针做了筛选,可以见源码下面看一下println的源码是如何处理这种空指针异常的
1.无论是动态初始化还是静态初始化,最终的内存分布都是一样的。
2.如果在创建数组的时候,知道数组中应该存储什么数据,这个时候当然采用静态初始化方式。如果在创建数组的时候,无法预测到数组中存储什么数据,只是先开辟空间,则使用动态初始化方式。
以下两种初始化方式都是可以的
int a3[] = {12,12,45};int [] a3 = {12,12,45};D66_ArryInitialMethods.java
https://github.com/ruigege66/Java/blob/master/D66_ArryInitialMethods.java
以上就是Java 数组的两种初始化方式的详细内容,更多关于Java 数组初始化的资料请关注其它相关文章!
声明:本页内容来源网络,仅供用户参考;我单位不保证亦不表示资料全面及准确无误,也不保证亦不表示这些资料为最新信息,如因任何原因,本网内容或者用户因倚赖本网内容造成任何损失或损害,我单位将不会负任何法律责任。如涉及版权问题,请提交至online#300.cn邮箱联系删除。
数组数组(Array):相同类型数据的集合。Java数组初始化的两种方法:静态初始化:程序员在初始化数组时为数组每个元素赋值;动态初始化:数组初始化时,程序员只
数组的初始化有两种方式静态初始化:初始化时由程序员显示置顶每个数组的初始值,由系统决定数组长度。如:int[]a1=newint[]{1,2,3,4};动态初始
Java中初始化块详解在Java中,有两种初始化块:静态初始化块和非静态初始化块.静态初始化块:使用static定义,当类装载到系统时执行一次.若在静态初始化块
数组的初始化可以分为两种:1、静态初始化2、动态初始化静态初始化:例:String[]str=newString[]{"A","B","C"};Stringst
(一)List两种初始化方式 //方式一 ListmyList=newArrayList(); //方式二 ListmyList=newLinked