array[]:由 JVM 本身内部管理的特殊类
2024-09-18 15:44:45
我们学习 java数据结构的第一种方式是通过数组。在 java 在中间,数组是一个类,一个对象,object 子级(所有类都是这样)。然而,这是一门语言待遇特殊的课程。
编译器和数组的语法及其处理方法不同于常见的类和对象 jvm(java 虚拟机)直接管理。这包括数组的分配、操作和访问。这个类别在源代码中直接找不到。
java 将数组自动视为这一特殊类别的例子。
如果您操作以下代码,您将看到以下输出:
public class main { public static void main(string[] args) { int[] intarray = new int[5]; system.out.println(intarray.getclass().getname()); system.out.println(intarray.getclass().getsuperclass()); } }
[我 类 java.lang.object
这个类名“[i“只是一个自动生成的符号名,jvm用它来表示一个整数组(int[])。每种类型都有自己的符号名称:
括号“[”表示尺寸。一维数组用[表示,二维数组用[表示,三维数组用[[[...等等。
宣言指定对象的数据类型和大小对于声明和初始化数组非常重要:
int[] intarray = new int[5]; //array de tamanho 5 char[] chararray = new char[]{'a', 'b', 'c'}; //o compilador entende que é um array de tamanho 3 double[] doublearray = {1.2, 1.3, 1.4, 1.5}; //o compilador entende que é um array de tamanho 4
java允许您将方括号放置在变量名中,而不是类型,例如:int intarray[] = new int[5]。但是,不建议这样做,因为它偏离了惯例。
存储在数组中的数据可以在内存中“连续”分配,即由 jvm 按顺序分配。为了访问数据,需要使用索引,并且在 java 中数组的第一个索引始终是 0。
例如,访问上述内容 chararray 中的字母“a",你需要通过 chararray[0] 来搜索它。字母“b”依次位于 chararray[1] 中,字母“c”位于 chararray[2] 中。如果您尝试访问数组中不存在的索引,您将收到“indexoutofbounce”错误。例如,如果我试图访问, chararray[3] 中的值。
一旦声明中定义了数组的大小,就永远不会改变。如果我声明的话 chararray 有 3 如果是一个元素,它就不会包含更多的元素。少一点“是”...更多的“不”。
这是附录。数组中未填充的值将采用与数组类型相同的默认值。例如,在整数组中,将使用空值 0 填充。在布尔数组中使用 false 填充。带有字符串数组 null。
就像大小一样,数组的类型不能改变。但如果不同类型的数组是相同类型的子类型,则可以复制它们。令人困惑,对吧?一个例子可以帮助你:integer 和 double 是 number 子类型。所以...
integer[] integerarray = {1, 2, 3}; number[] numberarray = intgerarray;
编译器接受了这个代码。然而,需要谨慎。如果我们在这里这样做,我们将犯一个编译错误:
numberArray[0] = 1.2;
这是因为integeraray和numberararay指向同一个内存空间。虽然 numberarray 支持 double 但作为它的第一个元素, integerarray 不支持,所以,numberarray 不“允许”更改索引值 0。
记忆数组总能存储相同类型的数据,接受基元和对象。若数组由整数组成,则不接受 char、double、float、string..,只接受整数值。
数组本身就是一个类(虽然是特殊类),所以存储在堆上。这样,数组就存储了一个包含在数组中输入值的内存地址。
原始数组分配连续的内存块直接存储值,而对象数组存储对位于内存其他位置的对象的引用(指针)。
这意味着原始类型的数组(如 int(如[])和对象数组(如 string[])它们都存储在堆上。对于基本类型的数组,数组元素的值也直接存储在堆上,与数组本身相邻。对于对象数组,这些引用对象可以分布在堆上的不同位置。
方法所有数组类别都有长度和克隆方法。第一个返回数组的大小,第二个将数组复制到另一个数组(指向相同内存地址的指针)。
但是,作为 object 类(以及 java 子类中的所有类),数组也有超类方法:tostring、equals 和 hashcode。
然而,在幕后使用数组是现实生活中最常见的事情。虽然数组是高性能的,但迭代它们的元素要复杂得多,有些类别在数组上抽象,这使得程序员的生活更容易。
array 类就是这种情况(大写字母)。它基本上将数组包装在标准中 java 在类中,并提供了一系列非常简单的实现方法来处理数据。 array 类别还有另一个强大的优势:它使用动态分配,因此更容易处理集合 - 毕竟,我们很少知道我们可能需要的数组的确切大小。 array 类别可以根据需要扩展收集的大小,程序员不需要创建更大的新数组(带有小写字母),并从以前的数组(突然变得太小)复制数据。
数组也是 list、stack 和 queue 等级基础(它们基本上是包装,包括处理数据的好方法)。
你有没有想过? string 是一个抽象 char 数组的类?
以上是array[]:由 JVM 更多关于图灵教育的其他相关文章,请关注内部管理特殊类别的详细内容!