一、数组定义
type[] =arryname;
type arrname=[];
以上是java中数组的定义的两种方式;建议使用第一个。因为她的可读性比较高,有更好的语义。
type[]与type类型完全不同,因为前者是引用类型,二后者是数据类型。
数组是一个引用类型的变量,在开始定义时候,还没指向一个确定的有效的内存空间。所以接下来我们要对数组进行初始化。
二、数组的初始化
java中数组必须要初始化,不能之开辟空间但是不进行初始化。初始值的获取有两种
第一:系统自己分配。
第二:程序员自己分配。
1.静态初始化(由系统来分配数组的长度)
arrayname=new type[]{1,3,4,5....};
type [] arrayname={1,2,3,4...}
这里的type就是数组元素的数据类型,这里面的值的类型也要与type一样。第二种是简化的初始化,不过这个需要在数组的定义和初始化完成后才能简化。
2.动态初始化(指定长度)
arrayname=new type[length];
这里需要自己输入一个int类型的length长度。与之前一样,数组中值的类型与定义的保持一致。
int[]prices=new int[5];
//定义和初始化同时完成,使用动态初始化
//在初始化的时候,元素的类型是定义数组时类型的子类
Object [] books=new String[3];
3.使用动态初始化数组时的值
1.整型(byte,short,char,int)数组元素的值为0
2.浮点型(float,double)数组的初始值为0.0
3.字符型(char)数组元素的值为"\u0000".
4.布尔类型(boolean)数组元素的值为false
三、使用数组
java的数组索引值是从0开始的,最大索引长度为数组长度-1,由此可知通过java中的arraname.length可以得到数组的长度,所以我们可以通过for循环来操作数组。
我们可以完成2道练习题:1.给定一个数组,通过for循环来实现,从大到小来排序
public class Test{
public static void main(String[] args){
int [] arr={1,2,3,4,5};
for (int i=0,j=arr.length;i<j;i++,j--){
int temp=arr[i];arr[i]=arr[j];arr[j]=temp;
}
//打印出结果
for (int=0;i<arr.length;i++){
System.out.print(arr[i]+"")
}
}
}
因为题目中的要求是,从大到小来排序,我们可以理解为在数组中第一个索引与最后一个索引互换,直到俩个索引值相等取消互换。i是第一个j是最后一个,每一个循环后i自增1j自减1,直到两个相等时,结束循环。
2.给定一个数组,要求每一次运行时,得到的结果都是不一样的。与上一题相似,只不过是要在指定的数组长度中,生成随机的索引值。
public class test4 {
import java.util.Random;
public static void main(String[] args) {
int[]arr={1,2,3,4,5};
Random r= new Random();
int num= r.nextln(arr.length);
for (int i=0;i<arr.length;i++){
int temp=arr[i];arr[num]=arr[j];arr[j]=temp;
//实现交换数字
}
//打印出结果
for (int j =0 ;j<arr.length;j++){
System.out.print(arr[j]+" ")}
//这里不使用println 可以把结果打印在一行上
}
}
四、总结
以上就是java数组的基础使用部分,下一期会深入介绍java数组中内存的知识。