java基础第5天

数组概述

数组是储存多个变量(元素)的东西(容器}

这多个变量的数据类型要一致

概念:数组是存储同一种数据类型多个元素的集合。也是一个容器,这个容器有个名字,就是数组名

数组就是在内存中开辟出一段空间,这些内存空间在使用上是连续的,连续的下标值可以访问所有数组元素。

数组既可以存储基本数据类型,也可以存储引用数据类型。

String[] args; 引用数据类型

byte[] buf; 基本数据类型

int[] nums; 基本数据类型

 

数字的初始化

Java中的数组必须先初始化然后才能使用。

所谓初始化:就是为数组中的数组元素分配内存空间,并为每个数组元素赋值

 

动态初始化:

数组的创建和元素的赋值分开进行;

初始化时只指定数组长度,由系统为数组分配默认初始值,元素的值可以在后面进行修改

 

 静态初始化:

创建数组的时候就给每个数组元素赋值由系统自动计算数组长度

java中的内存分配

Java 程序在运行时,需要在内存中的分配空间。

为了提高运算效率,就对空间进行了不同区域的划分,因为每一片区域都有特定的处理数据方式和内存管理方式。

 

程序为了提高效率,对数据进行不同的空间的分配,主要有以下几个区域

:存放的是所有new出来的东西

:存放的是局部变量

方法区:面向对象再讲

本地方法区:和系统相关,不必考虑

寄存器:供CPU使用,不必考虑

 

堆内存的特点:

每一个new出来的东西都有地址值

堆中的每个变量都有默认值:

byteshortintlong0

floatdouble0.0

booleanfalse

引用类型为null

堆内存使用之后就成了垃圾,但是需要JVM在空闲的时候才会回收这些堆空间

 

数组内存结构的总结:

1.目前为止,一提到数组,就应该想到会涉及到两种内存区域:一个是堆,一个是栈

2.堆中存放的是数组的元素;栈中存放的是这个数组的引用(第一个元素的地址/首地址)

 

 二维数据

概述:

我们每个班有很多个学生,所以,可以用数组来存储,而我们又同时有很多个班。这个也应该用一个数组来存储。如何来表示这样的数据呢?Java提供了二维数组供我们使用。

由此可见二维数组的本质:每个元素都是一维数组的数组

 

二维数组定义方式一:每个元素长度相同

指的是每个元素指向的一维数组的长度是相同的

定义方式如下:

 数据类型[][] 变量名 = new 数据类型[m][n];

m表示这个二维数组有多少个一维数组

n表示每一个一维数组的元素个数

 

二维数组定义方式二:每个元素长度不一定相同

指的是每个元素所指向的一维数组的长度可以是不同的,根据具体情况而定

定义格式如下:

数据类型[][] 变量名 = new 数据类型[m][];

m表示这个二维数组有多少个一维数组

 

由于每个元素指向的一维数组长度不是固定的,所以没有直接给出,可以在接下来的程序中动态的指定每个元素具体指向的是多少个元素的一维数组

1.定义一个int数组,5个元素,从键盘输入5int值,保存到这个数组中,然后编写三个方法:分别用来对一个int型数组求最大值,最小值,平均值(注意返回值类型),调用这三个方法对输入的数组进行计算。

 

import java.util.Scanner;
class HomeWork{
public static void main(String[] args){
Scanner s = new Scanner(System.in);
System.out.println("请输入数组长度: ");
int len = s.nextInt();
int[] arr = new int[len];
for(int i = 0;i<arr.length;i++){
System.out.println("请输入第"+(i+1)+"个值");
arr[i] = s.nextInt();
}
System.out.println("Max value is: "+getMax(arr));
System.out.println("Min value is: "+getMin(arr));
System.out.println("Ave value is: "+getAve(arr));

}
public static int getMax(int[] arr){
int max = arr[0];
for(int i = 0;i<arr.length;i++){
if(arr[i]>max){
max = arr[i];
}
}
return max;
}

public static int getMin(int[] arr){
int min = arr[0];
for(int i = 0;i<arr.length;i++){
if(arr[i]<min){
min = arr[i];
}

}
return min;

}
public static double getAve(int[] arr){
int sum = 0;
for(int i = 0;i<arr.length;i++){
sum += arr[i];
}
double res = sum / arr.length;
return res;
}

 


}

 

posted @ 2017-03-20 20:26  IT博客园  阅读(159)  评论(0编辑  收藏  举报