标签:color lock 出现 必须 空间 排列组合 其他 基本类型 dem
数组的定义
数组是相同类型数据的有序集合。数组描述的是相同类型的若干个数据,按照一定的先后次序排列组合而成。其中,每一个数据称作一个元素,每个元素可以通过一个索引(下标)来访问它们。数组的三个基本特点:
1. 长度是确定的。数组一旦被创建,它的大小就是不可以改变的。
2. 其元素必须是相同类型,不允许出现混合类型。
3. 数组类型可以是任何数据类型,包括基本类型和引用类型。
数组变量属引用类型,数组也可以看成是对象,数组中的每个元素相当于该对象的成员变量。数组本身就是对象,Java中对象是在堆中的,因此数组无论保存原始类型还是其他对象类型,数组对象本身是在堆中存储的。
数组的声明
1. 声明的时候并没有实例化任何对象,只有在实例化数组对象时,JVM才分配空间,这时才与长度有关。
2. 声明一个数组的时候并没有数组真正被创建。
3. 构造一个数组,必须指定长度。
创建基本类型一维数组 demo:
public class Test {
public static void main(String args[]) {
int[] s = null; // 声明数组;
s = new int[10]; // 给数组分配空间;
for (int i = 0; i < 10; i++) {
s[i] = 2 * i + 1;//给数组元素赋值;
System.out.println(s[i]);
}
}
}
基本类型数组内存分配图:
创建引用类型一维数组demo:
class Man{
private int age;
private int id;
public Man(int id,int age) {
super();
this.age = age;
this.id = id;
}
}
public class AppMain {
public static void main(String[] args) {
Man[] mans; //声明引用类型数组;
mans = new Man[10]; //给引用类型数组分配空间;
Man m1 = new Man(1,11);
Man m2 = new Man(2,22);
mans[0]=m1;//给引用类型数组元素赋值;
mans[1]=m2;//给引用类型数组元素赋值;
}
}
引用类型数组内存分配图:
数组的初始化:
·静态初始化:
除了用new关键字来产生数组以外,还可以直接在定义数组的同时就为数组元素分配空间并赋值。
静态初始化数组 demo:
int[] a = { 1, 2, 3 };// 静态初始化基本类型数组;
Man[] mans = { new Man(1, 1), new Man(2, 2) };// 静态初始化引用类型数组;
·动态初始化:
数组定义与为数组元素分配空间并赋值的操作分开进行。
动态初始化数组 demo:
int[] a1 = new int[2];//动态初始化数组,先分配空间;
a1[0]=1;//给数组元素赋值;
a1[1]=2;//给数组元素赋值;
·数组的默认初始化:
数组是引用类型,它的元素相当于类的实例变量,因此数组一经分配空间,其中的每个元素也被按照实例变量同样的方式被隐式初始化。
默认初始化 demo:
int a2[] = new int[2]; // 默认值:0,0
boolean[] b = new boolean[2]; // 默认值:false,false
String[] s = new String[2]; // 默认值:null, null
数组的遍历:
数组元素下标的合法区间:[0, length-1]。我们可以通过下标来遍历数组中的元素,遍历时可以读取元素的值或者修改元素的值。
数组的遍历 demo:
public class Test {
public static void main(String[] args) {
int[] a = new int[4];
//初始化数组元素的值
for(int i=0;i<a.length;i++){
a[i] = 100*i;
}
//读取元素的值
for(int i=0;i<a.length;i++){
System.out.println(a[i]);
}
}
}
一个综合的例子:
package cn.ftf.o1;
/**
* 测试数组
* @author 房廷飞
*
*/
public class TextArrays {
public static void main(String[] args) {
int[] arr01=new int[10];//声明数组和大小,此时是空的
String[] arr02=new String[4];
//通过遍历为对象赋值
for(int i=0;i<arr01.length;i++) {
arr01[i]=i*10;
}
//打印一下
for(int i=0;i<arr01.length;i++) {
System.out.println(arr01[i]);
}
User[] arr03=new User[3];
//初始化User类型
arr03[0]=new User(1001,"房廷飞0");
arr03[1]=new User(1002,"房廷飞1");
arr03[2]=new User(1003,"房廷飞2");
//遍历打印User对象的name
for(int i=0;i<arr03.length;i++) {
System.out.println(arr03[i].getName());
}
}
}
class User{
private int id;
private String name;
//右键自动创建构造器
//右键自动生成set,get方法
public int getId() {
return id;
}
public User(int id, String name) {
super();
this.id = id;
this.name = name;
}
public void setId(int id) {
this.id = id;
}
public String getName() {
return name;
}
public void setName(String name) {
this.name = name;
}
}
2019-03-14 23:36:29 房廷飞 期待明天更好的自己!
标签:color lock 出现 必须 空间 排列组合 其他 基本类型 dem
原文地址:https://www.cnblogs.com/fangtingfei/p/10534421.html