Java之--Java语言基础组成—数组

时间:2021-11-18 21:50:16
Java之--Java语言基础组成—数组

Java语言基础组成—数组

Java语言由8个模块构成,分别为:关键字、标识符(包名、类名、接口名、常量名、变量名等)、注释、常量和变量、运算符、语句、函数、数组。

本片主要介绍Java中的数组,数组是一种引用数据类型。

1、数组的定义

     1)	概念:同一种类型数据的集合(存储数据的一种方式),是一个容器。
2) 好处:可以自动给数组中的元素从0开始编号,方便操作这些元素。 3) 格式
*1* 格式1:元素类型[] 数组名 = new 元素类型[元素个数或数组长度];
需求:定义一个可以存储3个整数的容器
int[] arr=new int[3]; 变量arr是数组类型,方括号中3指数组长度。。
*2* 格式2:元素类型[] 数组名=new元素类型[]{元素1,元素2,... ....};
需求:定义一个arr数组,共有四个元素2,3,1,7。
int [] arr=new int[]{2,3,1,7};
int [] arr = {2,3,1,7}; 定义格式: 解析1:数据明确时,定义方式为:
int [] arr=new int []{2,7,4,5};
注意:方括号中不写长度,如果写容易出错。
定义一个名称为arr的数组,元素类型为int,通过大括号的形式标识处数组中元素内容。
这种方式称之为静态初始化方式,即数组中元素的个数和内容都体现出来了。
解析2:数据不明确时,定义方式为:
int [] arr =new int[5];
arr[0]=2;
arr[1]=5;

2、数组的内存分配及特点

     1)	Java内存结构:Java程序在运行时,需要在内存中分配空间。为了提高运算效率,又对空间进行了不同区域的划分,因为每一片区域都有特定的处理数据方式和内存管理方式。
*1*栈内存:用于存储局部变量,当数据使用完,所占空间会自动释放。
*2*堆内存:
数组和对象,通过new建立的实例都放在堆内存中。
每一个实体都有内存地址值。
实体中的变量都有默认初始化值,根据数组类型不同而定。
实体不再被使用,会在不确定的时间内被垃圾回收器回收。
*3*方法区,本地方法区,寄存器

3、数组操作常见问题

     1)	数组中有默认初始化值为0。
实例:打印arr数组中角标为0的值。
class ArrayDemo{
public static void main(String[] args){
int [] arr=new int[3] ;
System.out.println(arr[0]+","+arr[1]+","+arr[2]);
}
}
//该程序运行结果为:0,0,0
2) 需注意数组的角标越界问题。
1.运行时提示:ArrayIndexOutOfBoundException:代表操作数组时,访问到了数组中不存在的角标。
2.NullPointException:空指针异常:代表当引用没有任何指向,值为null的情况,该引用还在用于操作实体。

4、数组常见操作

     1)遍历(获取数组中的元素)
*1*示例1(确定数组长度,无元素值):
class ArrayDemo{
public static void main(String[] args){
int [] arr=new int[3] ;
for(int x=0;x<3;x++){
System.out.print("arr["+x+"]="+arr[x]+",");
}
}
}
//该程序运行结果为:arr[0]=0,arr[1]=0,arr[2]=0, *2*示例2(数组中元素值确定,长度不定时)
数组中有一个属性可以直接获取到数组的元素个数:.length
使用方式:数组名称.length。
class ArrayDemo{
public static void main(String[] args){
int [] arr={3,4,1,2} ;
for(int x=0;x<arr.length;x++){
System.out.print("arr["+x+"]="+arr[x]+" ");
}
}
}
//该程序运行结果为:arr[0]=3 arr[1]=4 arr[2]=1 arr[3]=2 *3*示例3(数组求和)
class ArrayDemo
{
public static void main(String[] args)
{
public static void pintArray(int [] arr)
int[] arr={3,4,6,5,9,6}; for (int x=0;x<arr.length;x++ )
{
System.out.println(arr[x]);
}
}
}
//该程序运行结果为:33 2)获取数组中的最值(最大值和最小值)
*1*思路:
获取最值需要进行比较,每次都有较大的值,由于该值不确定,因此定义一个临时变量存储。
让数组中每一个元素都和该值比较,如果大于该值,就用该变量存储较大值,以此类推。
当所有的元素比较完成,那么该变量中存储的就是数组中的最大值。
*2*步骤:
定义变量,初始化为数组中的任意一个元素即可。
通过循环语句对数组进行遍历。
在遍历过程中定义判断条件,如果遍历到的元素比变量中的值大,就复制给该变量。
*3*示例代码(获取最大值)
定义一个功能完成,提高代码的复用性。
public class arrayMax {
public static void main(String[] args){
int [] arr={3,4,7,2,1,9};
int max = getMax(arr);
System.out.println("The max is "+max);
} public static int getMax(int[] arr){
int max=arr[0];
for(int i=1;i<arr.length;i++){
if(arr[i]>max)
max=arr[i];
}
return max;
}
}
//该程序运行结果为:The max is 9
*4*示例代码(获取最小值,利用角标来定义比较)
public class arrayMin {
public static void main(String[] args){
int [] arr={3,1,6,9,8,7};
int min = getMin(arr);
System.out.println("The Min is "+arr[min]);
} public static int getMin(int[] arr){
int min=0;
for(int i=1;i<arr.length;i++){
if(arr[i]<arr[min])
min=i;
}
return arr[min];
}
}
//该程序运行结果为:The Min is 1
3)排序
*1*选择排序
public class arraySort1 {
public static void main(String[] args){
int [] arr={3,4,7,2,1,9};
//在排序前打印
printArray(arr);
//排序
selectSort(arr);
//在排序后打印
printArray(arr);
}
public static void selectSort(int[] arr){
for(int i=0;i<arr.length;i++){
for(int j=i+1;j<arr.length;j++){
if(arr[i]>arr[j]){
int tmp = arr[i];
arr[i] = arr[j];
arr[j] = tmp;
}
}
} }
public static void printArray(int[] arr){
System.out.print("[");
for(int x=0;x<=arr.length;x++){
if (x!=arr.length)
System.out.print(arr[x]+",");
else
System.out.print("]");
}
}
}
//该程序运行结果为:[3,4,7,2,1,9,][1,2,3,4,7,9,]