1 数组的定义:
数组是存储相同类型的多个元素的连续空间
2 数组的分类:
类型:基本类型数组 引用类型数组(对象数组)
维度:一维 二维 三维 多维
3. 数组的特点:
(1) 数组所储存的元素的类型必须是同种类型
(2) 数组的长度是有限的 是固定的 一旦声明 则不能修改
(3) 数组的 空间是连续的
4 数组的声明和初始化
public static void main(String[] args) {
//声明数组 数据类型[] 数组的名称(标识符) = new 数据类型[数组的长度];;
// 数据类型[] 数组的名称 = {数组中的元素,元素和元素之间使用逗号分割}
//数组的动态初始化
//此时 该数组只是分配了空间
int[] arr1 = new int[5];// 声明了一个长度为5的整型数组 数组的名称为arr1
//数组中元素的引用
System.out.println(arr1[0]);
System.out.println(arr1[1]);
System.out.println(arr1[2]);
System.out.println(arr1[3]);
System.out.println(arr1[4]);
}
5 数组的元素的值
数组中的元素的操作是 通过索引/角标来完成 索引或角标是 从0开始的
// 为数组中的元素赋值 数组元素的初始化 ,数组中的元素可以进行多次赋值
arr1[0] = 10;
arr1[1] = 20;
arr1[2] = 30;
arr1[3] = 40;
arr1[4] = 50;
System.out.println(arr1[0]);
System.out.println(arr1[1]);
System.out.println(arr1[2]);
System.out.println(arr1[3]);
System.out.println(arr1[4]);
- 数组的静态初始化
public static void main(String[] args) {
int[] arr1 = new int[5];
// 数组的静态初始化方式1 在数组声明的同时 就初始化了数组
int[] arr2 = {10,20,30,40,22,36};
System.out.println(arr2[0]);
System.out.println(arr2[1]);
System.out.println(arr2[2]);
// 数组的静态初始化方式2
int[] arr3 = new int[]{21,11,31,41,51};
System.out.println(arr3[2]);
System.out.println(arr3[3]);
System.out.println(arr3[4]);
}
- 使用循环来操作数组
//数组的循环赋值
for(int i = 0 ; i < 5 ;i++){
arr3[i] = i + 50;
}
// 数组的遍历
for(int i = 0 ; i < 5;i++){
System.out.println(arr3[i]);
}
8 获取数组的长度
// 获取数组的长度 使用数组的length属性来获取
System.out.println("========================"+arr1.length);
System.out.println("========================"+arr2.length);
System.out.println("========================"+arr3.length);
for(int i = 0 ; i < arr3.length;i++){
System.out.println(arr3[i]);
}
}
9.数组的默认值数组元素类型 元素默认初始值
byte 0
short 0
int 0
long 0L
float 0.0F
double 0.0
char 0 或写为:’\u0000’(表现为空)
boolean false
引用类型 null
10 jvm的内存
区域名称 作用
程序计数器(寄存器) 给CPU使用,和我们开发无关。
本地方法栈 JVM在使用操作系统功能的时候使用,和我们开发无关。
方法区 存储可以运行的class文件。
堆内存 存储对象或者数组,new来创建的,都存储在堆内存。当申请不到空间时会抛出OutOfMemoryError
虚拟机栈 栈里面是一个一个“栈帧”,每个栈帧对应一次方法调用。栈帧中存放了局部变量表(基本数据类型变量和对象引用)、操作数栈、方法出口等信息。当栈调用深度大于JVM所允许的范围,会抛出StackOverflowError的错误。
基本类型的内存分析
数组的内存分析
11. 数组使用中的两个小问题
1 在进行数组元素获取的时候 产生的一个问题:数组下标越界
解决这类问题的 关键在于获取数组元素时采用数组的 length属性
2. 空指针异常
public static void main(String[] args) {
int[] arr3 = new int[]{21,11,31,41,51};
arr3 = null;
System.out.println(arr3[2]);
System.out.println(arr3[3]);
System.out.println(arr3[4]);
// System.out.println(arr3[5]);
System.out.println("--------------------------");
}
这种问题产生的原因在于 数组类型的变量 未指向任何对象
解决方案:让该变量指向一个明确的对象即可
public static void main(String[] args) {
int[] arr3 = new int[]{21,11,31,41,51};
int[] arr4 =null;
arr4 = arr3;
System.out.println(arr4[2]);
System.out.println(arr4[3]);
System.out.println(arr4[4]);
// System.out.println(arr3[5]);
System.out.println("--------------------------");
}
- 数组的常见操作
- 遍历数组
public static void main(String[] args) {
int[] arr = new int[]{32,12,42,53,65};
//使用普通for循环 + 数组的 length属性
for (int i= 0 ; i < arr.length;i++){
if(i % 2 != 0){
System.out.println(arr[i]);
}
}
System.out.println("----------------------------");
// 使用增强for循环 (foreach) 从jdk1.5.开始引入
// int 表示遍历的目标数据为int类型 j 表示遍历得到的 每一个元素的 暂存区域 arr 表示待遍历的对象容器/集合
for(int j : arr){
System.out.println(j);
}
/*
这两种循环的区别:
普通for循环可以精确的去控制 每一个元素
增强for没法去精确的控制每一个元素 只能遍历所有元素
*/
}
- 数组的拷贝
public class ArrayDemo_04 {
public static void main(String[] args) {
int[] arr1 = {56,65,69,68,58,24,35};
//将arr1中的元素拷贝到另一个数组中
// 1 创建 一个新的数组
int[] arr2 = new int[arr1.length];
for(int i = 0 ; i < arr1.length;i++){
arr2[i] = arr1[i];
}
for (int j: arr2) {
System.out.println(j);
}
// 将arr1 中的 元素逆序拷贝到arr3中
System.out.println("-----------------------------");
//1 创建一个 新的数组
int[] arr3 = new int[arr1.length];
for (int i = 0,j= arr2.length -1 ; i < arr1.length && j >= 0;i++,j--){
arr3[j] = arr1[i];
}
for (int j: arr3) {
System.out.println(j);
}
}
}
3.获取数组中的 最值问题
// 获取数组中元素的最大值
public static void main(String[] args) {
int [] arr = new int[]{65,89,69,68,32,57};
// 1 设定一个变量
// 2 假设数组中的第一元素为 最大者
//3 将最大的元素保存在变量中
//4 使用当前的最大元素 依次和后边的 元素进行比较 如果后边的元素比他大 则替换 否则就继续比较
int maxEle;
maxEle = arr[0];
for (int i = 1 ; i < arr.length;i++){
if(maxEle < arr[i]){
maxEle = arr[i];
}
}
System.out.println(maxEle);
}
// 获取数组中元素的最大值
public static void main(String[] args) {
int [] arr = new int[]{65,89,69,68,32,57};
// 1 设定一个变量 用来保存最大元素所在的位置
// 2 假设数组中的第一元素为 最大者
//3 将最大的元素的索引保存在变量中
//4 使用当前的假设最大元素所在的位置的元素 依次和后边的 元素进行比较 如果后边的元素比他大 则保存位置 否则就继续比较
int maxEleIndex;
maxEleIndex = 0;
for (int i = 1 ; i < arr.length;i++){
if(arr[maxEleIndex] < arr[i]){
maxEleIndex = i;
}
}
System.out.println(arr[maxEleIndex]);
}
作业:求数组中的最小的元素
递归算法
public class Factorial {
//递归的使用 计算1--5的和
public static void main(String[] args) {
int num = 5;
int s = sum(500);
System.out.println(s);
}
//方法的 声明 int/void 为方法的 返回值类型 如果方法不返回任何结果 则为void
// sum 为方法 的 名称 只需要遵循小驼峰命名法的标识符都可以
// (int num) 方法的参数 需要传递给方法的数据
// 一个程序的 入口 为main方法 所以其他方法要执行 必须在main方法中明确的调用
// 方法的调用 通过方法名调用 同时需要根据方法的声明 传入方法所需的参数
public static int sum(int num) {
if(num == 1){
return 1;
}else{
return num + sum(--num);
}
}
}
阶乘
public class Factroial_1 {
// 求一个数的阶乘
public static void main(String[] args) {
long result = cheng(10);
System.out.println(result);
}
public static long cheng(int num){
if(num == 1){
return 1;//此处就是递归算法的出口
}else{
return num * cheng(--num);//递归
}
}
}