简要说明一维动态数组的构造和使用方法

2025-10-10 09:13:28

1、数组是用来存储多个相同类型数据的集合

 详细解释:

1. 数组元素的数据类型必须一致 

2. 会开辟连续内存空间,存储数据元素,我们可以通过下标访问数组中的元素 

3. 数组也是引用数据类型 

4. 数组元素可以是基本数据类型,也可以是引用数据类型 

2、在Java中,可以使用以下格式来定义一个数组。

如下数据类型[] 数组名 = new 数据类型[元素个数或数组长度];

 int[] x = new int[100]; 

上述语句就相当于在内存中定义了100个int类型的变量,第一个变量的名称为x[0],第二个变量的名称为x[1],以此类推,第100个变量的名称为x[99],这些变量的初始值都是0。为了更好地理解数组的这种定义方式,可以将上面的一句代码分成两句来写,具体如下: 

int[] x; // 声明一个int[]类型的变量 

x = new int[100]; // 创建一个长度为100的数组

简要说明一维动态数组的构造和使用方法

3、通过内存图来详细地说明数组在创建过程中内存的分配情况。

第一行代码 int[] x; 声明了一个变量x,该变量的类型为int[],即一个int类型的数组。变量x会占用一块内存单元,它没有被分配初始值。内存中的状态如下图所示。 

第二行代码 x = new int[100]; 创建了一个数组,将数组的地址赋值给变量x。在程序运行期间可以使用变量x来引用数组,这时内存中的状态会发生变化,如下图所示。 

描述了变量x引用数组的情况。该数组中有100个元素,初始值都为0。数组中的每个元素都有一个索引(也可称为角标),要想访问数组中的元素可以通过“x[0]、x[1]、……、x[98]、x[99]”的形式。需要注意的是,数组中最小的索引是0,最大的索引是“数组的长度-1”。在Java中,为了方便我们获得数组的长度,提供了一个length属性,在程序中可以通过“数组名.length”的方式来获得数组的长度,即元素的个数。

简要说明一维动态数组的构造和使用方法

1、给数组变量赋值

① 静态初始化

在初始化数组时有一种方式叫做静态初始化,就是在定义数组的同时就为数组的每个元素赋值。数组的静态初始化有两种方式,具体格式如下: 

1、 数据类型[ ] 数组名 = new 数据类型[ ]{元素,元素,……}; 

2、 数据类型[ ] 数组名 = {元素,元素,元素,……}; 

建议使用这种int[] arr={10,45,6,89,100}; // √int[] arr2=new int[] {1,2,3,4,5};

② 动态初始化

如果在使用数组时,不想使用这些默认初始值,也可以显式地为这些元素赋值。 在定义数组时只指定数组的长度,由系统自动为元素赋初值的方式称作动态初始化。 数据类型[] 数组名=new 数据类型[长度]; //系统会自动为元素赋默认值

2、一维数组应用(冒泡排序)

优点:稳定。缺点:慢,每次只能比较相邻两个数据。

 0 1 2 3 4 5 6 7 每轮比较的次数 

100,40, 60, 87, 34, 11, 56, 0第1轮

 40 60 87 34 11 56 0 【100】 7次第2轮 

40 60 34 11 56 0 【87】 6次第3轮 

40 34 11 56 0 【60】 5次 第4轮 

34 11 40 0 【56】 4次 第5轮 

11 34 0 【40】 3次第6轮 

11 0 【34】 2次第7轮

 0 【11】 1次 

总结: 比较了length-1轮

简要说明一维动态数组的构造和使用方法

3、有兴趣的可以玩玩它的内存分配:

程序为了提高效率,对数据进行不同的空间分配,主要有5个区域: 

1、堆:存放的是所有new出来的东西(包括成员变量);每个变量都有默认值;堆内存使用之后就成了垃圾。 

2、栈:存放的是局部变量;

3、方法区:(后面补充) 

4、本地方法区:和系统相关;native 

5、寄存器:供CPU使用

简要说明一维动态数组的构造和使用方法

声明:本网站引用、摘录或转载内容仅供网站访问者交流或参考,不代表本站立场,如存在版权或非法内容,请联系站长删除,联系邮箱:site.kefu@qq.com。
猜你喜欢