java基础第5天
内容导读
互联网集市收集整理的这篇技术教程文章主要介绍了java基础第5天,小编现在分享给大家,供广大互联网技能从业者学习和参考。文章包含2290字,纯文字阅读大概需要4分钟。
内容图文
数组概述
数组是储存多个变量(元素)的东西(容器}
这多个变量的数据类型要一致
概念:数组是存储同一种数据类型多个元素的集合。也就是一个容器,这个容器有个名字,就是数组名。
数组就是在内存中开辟出一段空间,这些内存空间在 使用上是连续的 ,连续的下标值可以访问所有数组元素。
数组既可以存储 基本数据 类型,也可以存储 引用数据 类型。
String[] args; 引用数据类型
byte[] buf; 基本数据类型
int[] nums; 基本数据类型
数字的初始化
Java中的数组必须先初始化,然后才能使用。
所谓初始化:就是为数组中的数组元素分配内存空间,并为每个数组元素 赋值
动态初始化:
数组的创建和元素的赋值分开进行;
初始化时只指定数组 长度 ,由系统为数组分配默认初始值,元素的值可以在后面进行修改
静态初始化:
创建数组的时候就给 每个数组元素 赋值 , 由系统自动计算数组长度
java中的内存分配
Java 程序在运行时,需要在内存中的分配空间。
为了提高运算效率,就对空间进行了不同区域的划分,因为每一片区域都有特定的处理数据方式和内存管理方式。
程序为了提高效率,对数据进行不同的空间的分配,主要有以下几个区域
堆 :存放的是所有new出来的东西
栈 :存放的是局部变量
方法区:面向对象再讲
本地方法区:和系统相关,不必考虑
寄存器:供CPU使用,不必考虑
堆内存的特点:
每一个new出来的东西都有地址值
堆中的每个变量都有默认值:
byte,short,int,long为0;
float,double为0.0;
boolean为false;
引用类型为null
堆内存使用之后就成了垃圾,但是需要JVM在空闲的时候才会回收这些堆空间
数组内存结构的总结:
1.目前为止,一提到数组,就应该想到会涉及到两种内存区域:一个是堆,一个是栈
2.堆中存放的是数组的元素;栈中存放的是这个数组的引用(第一个元素的地址/首地址)
二维数据
概述:
我们每个班有很多个学生,所以,可以用数组来存储,而我们又同时有很多个班。这个也应该用一个数组来存储。如何来表示这样的数据呢?Java提供了二维数组供我们使用。
由此可见,二维数组的本质是:每个元素都是一维数组的数组
二维数组定义方式一:每个元素长度相同
指的是每个元素指向的一维数组的长度是相同的
定义方式如下:
数据类型[][] 变量名 = new 数据类型[m][n];
m表示这个二维数组有多少个一维数组
n表示每一个一维数组的元素个数
二维数组定义方式二:每个元素长度不一定相同
指的是每个元素所指向的一维数组的长度可以是不同的,根据具体情况而定
定义格式如下:
数据类型[][] 变量名 = new 数据类型[m][];
m表示这个二维数组有多少个一维数组
由于每个元素指向的一维数组长度不是固定的,所以没有直接给出,可以在接下来的程序中动态的指定每个元素具体指向的是多少个元素的一维数组
1.定义一个int数组,5个元素,从键盘输入5个int值,保存到这个数组中,然后编写三个方法:分别用来对一个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;
}
}
原文:http://www.cnblogs.com/LOGO954137373/p/6591413.html
内容总结
以上是互联网集市为您收集整理的java基础第5天全部内容,希望文章能够帮你解决java基础第5天所遇到的程序开发问题。 如果觉得互联网集市技术教程内容还不错,欢迎将互联网集市网站推荐给程序员好友。
内容备注
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 gblab@vip.qq.com 举报,一经查实,本站将立刻删除。
内容手机端
扫描二维码推送至手机访问。