java数组
-
- 数组
-
- 1.数组的定义(声明)
- 2.数组的赋值(初始化)
- 3.数组元素的访问
- 4.数组元素的遍历(轮询)
- 5.基本数据类型和引用数据类型在内存结构上的区别
- 需求 容器(变量 数组)
-
- 1.创建一个数组 用来存储1-100之间的偶数
- 2.数组练习
-
- 0.创建一个数组来存储1-100的奇数
- 1.给定两个数组a{1,2,3,4} b{5,6,7,8} 将两个数组内的元素对应位置调换
- 2.给定一个数组a{1,2,3,4,5,6}将两个数组中的元素头尾对应互换位置
- 3.给定一个数组a{1,2,3,4,5,6}计算所有数组元素的平均值
- 4.给定一个数组a{1,2,5,7,9,0,2,4,6,8}找寻数组中的最大值和最小值
- 5.给定两个数组a{1,2,3} b{4,5}合并两个数组(创建一个新的数组5长度)
- 6.给定一个数组a{1,2,3,9,4,5}按照数组中的最大值的位置,将数组拆分成两个{1,2,3}{4,5}
- 7.给定一两数组a{1,2,3,0,0,4,5,0,6,0,7}去掉数组中的0元素(创建一个新的数组 非零元素挑出来)
- 8.创建一个数组 存储2-100之间的素数(质数)
- 9.数组元素的排序(冒泡 选择 插入 快速 希尔 堆排序 桶排序 归并排序 递归...
- 10.用户的登录认证(用数组当做小数据库 存值 用户验证)
数组
数组是一组数据类型相同的数据的组合,将这些数据统一管理起来
数组本身是一个引用数据类型,数组内存储的类型可以是基本类型 也可以是引用类型
1.数组是一个引用数据类型
2.数组是在堆内存中的一串连续的地址存在
4.数组在初始化时必须指定长度
4.堆内存的数组长度一旦确定 不能再次发生改变
5.栈内存的变量中存储的是数组的地址引用
6.数组内部存储的类型可以是基本的 也可一是引用
1.数组的定义(声明)
数据类型[] 数组名字
int[] x;
char[] y;
boolean[] z;
String[] m;
int[] x; ---->比较规范
int x[];
int []x;
2.数组的赋值(初始化)
静态初始化 有长度 有元素
int[] array=new int[]{10,20,30,40,50};
int[] array={10,20,30,40,50};
int[] array;
一百行
array=new int[]{};//此时编译器无法确定变量类型,必须要创建(new)
动态初始化 有长度 没有元素(不是真的没有 默认值)
int[] array =new int[5];
整数默认值---0
浮点数默认值---0.0
字符型默认值--- 0--char 97-a 65-A 48-'0'
布尔型默认值---false
引用数据默认值---null
3.数组元素的访问
通过元素在数组中的位置来访问
位置---->index索引
索引是有取值范围的 [从0开始----数组长度-1]
如果数组的索引超过了上述范围
会出现一个运行时异常 ArrayIndexOutOfBoundsException
4.数组元素的遍历(轮询)
通过循环的方式访问数组的每一个元素
for(;;){
}
JDK1.5版本 javaSE5.0 增加了新的特性: 增强for循环 加强for forEach
for(自己定义的变量(接收数组内每一个元素):遍历数组array){
}
正常的for循环已及加强的for循环都要熟练掌握
1.正常的for 有三个必要条件 index索引 找到某一个元素的位置
可以通过index直接访问数组的某一个位置 取值 存值都可以
不好在于写法相对来说比较麻烦
2.增强for 有两个条件 用来取值的变量 用来遍历的数组 没有index索引
好处写法相对比较容易
不好只能取值 不能存值
没有index索引 找不到元素哪一个
public class TestArray{
public static void main(String[] args) {
String[] array=new String[5] ;
for(String value:array){
System.out.println(value);
}
// int[] array=new int[]{10,20,30,40,50};
//通过元素在数组中的位置index(索引 下标)来访问
//array[index] index从0开始
//从数组内取得某一个位置的元素
//int value =array[0];
//System.out.println(value);
//向数组内的某一个位置存入元素
//array[3] = 400;
//索引有范围的
//int value=array[5];
//System.out.println(value);
//异常 ---运行时异常
//ArrayIndexOutOfBoundsException 数组索引越界
//index索引 0开始----数组(长度-1)结束
//将数组中的每一个元素都拉出来看一看
/*
for(int index=0;index<array.length;index++ ){ //每一次做一样的事情 取数组的值 5次
int value =array[index];
System.out.println(value);
}
System.out.println("-----我是一个华丽的分隔符-----");
for(int value:array){
System.out.println(value);
}
*/
}
}
5.基本数据类型和引用数据类型在内存结构上的区别
所有的变量空间存储在栈内存
变量空间可以存储基本数据类型 可以存储引用数据类型
如果变量空间存储的是基本数据 存储的是值 一个变量改变 另一个不会跟着改变
如果变量空间存储的是引用数据类型 存储的是引用(地址) 一个变量地址对应的值改变 另一个跟着改变
public class TestArray2{
public static void main(String[] args) {
int a = 10;
int b=a;
b=100;
System.out.println(a);//? 10
int[]x=new int[]{10,20,30};
//栈内存中的小容器 类型定义了只能存储这种东西 容器中只能存一份
//见到new 关键字 相当于 在 堆内存中申请开辟一块新的空间
//数组在堆内存的空间形态 是一串连续的地址
//基本类型变量空间存储的是值 传递的是值 一个改变 另一个不变
//引用类型变量空间存储的是地址(引用) 传递的就是引用 一个改变 另一个跟着改变
int[] y =x;
y[0] =100;
System.out.println(x[0]);//?100
}
}
需求 容器(变量 数组)
1.创建一个数组 用来存储1-100之间的偶数
public class SavaNum {
public static void main(String[] args) {
//1.需要创建一个数组
int[] array =new int[50];
//2.需要将1-100之间的偶数存入数组内
for(int i=0;i<array.length;i+