java基础第5天
数组概述
数组是储存多个变量(元素)的东西(容器}
这多个变量的数据类型要一致
概念:数组是存储同一种数据类型多个元素的集合。也就是一个容器,这个容器有个名字,就是数组名。
数组就是在内存中开辟出一段空间,这些内存空间在使用上是连续的,连续的下标值可以访问所有数组元素。
数组既可以存储基本数据类型,也可以存储引用数据类型。
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;
}
}
java基础第5天的更多相关文章
- Java基础知识(壹)
写在前面的话 这篇博客,是很早之前自己的学习Java基础知识的,所记录的内容,仅仅是当时学习的一个总结随笔.现在分享出来,希望能帮助大家,如有不足的,希望大家支出. 后续会继续分享基础知识手记.希望能 ...
- [Java面经]干货整理, Java面试题(覆盖Java基础,Java高级,JavaEE,数据库,设计模式等)
如若转载请注明出处: http://www.cnblogs.com/wang-meng/p/5898837.html 谢谢.上一篇发了一个找工作的面经, 找工作不宜, 希望这一篇的内容能够帮助到大 ...
- 【JAVA面试题系列一】面试题总汇--JAVA基础部分
JAVA基础 基础部分的顺序: 基本语法,类相关的语法,内部类的语法,继承相关的语法,异常的语法 线程的语法,集合的语法,io 的语法,虚拟机方面的语法 每天几道,持续更新!! 1.一个". ...
- 最适合作为Java基础面试题之Singleton模式
看似只是最简单的一种设计模式,可细细挖掘,static.synchronized.volatile关键字.内部类.对象克隆.序列化.枚举类型.反射和类加载机制等基础却又不易理解透彻的Java知识纷纷呼 ...
- java基础练习 字符串,控制流,日历,日期等
1,对基本控制流程的一些练习 package org.base.practice3; import org.junit.Test; /** * Created with IntelliJ IDEA. ...
- Java基础知识【下】( 转载)
http://blog.csdn.net/silentbalanceyh/article/details/4608360 (最终还是决定重新写一份Java基础相关的内容,原来因为在写这一个章节的时候没 ...
- Java基础知识【上】(转载)
http://blog.csdn.net/silentbalanceyh/article/details/4608272 (最终还是决定重新写一份Java基础相关的内容,原来因为在写这一个章节的时候没 ...
- java基础学习03(java基础程序设计)
java基础程序设计 一.完成的目标 1. 掌握java中的数据类型划分 2. 8种基本数据类型的使用及数据类型转换 3. 位运算.运算符.表达式 4. 判断.循环语句的使用 5. break和con ...
- Java基础加强之多线程篇(线程创建与终止、互斥、通信、本地变量)
线程创建与终止 线程创建 Thread类与Runnable接口的关系 public interface Runnable { public abstract void run(); } public ...
- java基础知识小总结【转】
java基础知识小总结 在一个独立的原始程序里,只能有一个 public 类,却可以有许多 non-public 类.此外,若是在一个 Java 程序中没有一个类是 public,那么该 Java 程 ...
随机推荐
- 1124 Raffle for Weibo Followers[简单]
1124 Raffle for Weibo Followers(20 分) John got a full mark on PAT. He was so happy that he decided t ...
- win10用键盘控制鼠标
打开控制面板 进入轻松使用 更改鼠标的工作方式 勾选启用鼠标键 点击设置鼠标键 应用确定 ctrl+shift+numlock开启鼠标键 小键盘8426上下左右,5类似鼠标单击 ctrl+小键盘加速, ...
- 005-matlab2018a安装破解
1.下载地址: 百度云下载链接:https://pan.baidu.com/s/1uTYAxVX1_Hx6nbsgf4W4kA 密码:asrw 官网下载地址: 2.解压. 3.双击setup.exe后 ...
- CCPC-Wannafly Winter Camp Day2 (Div2, onsite)
Class $A_i = a \cdot i \% n$ 有 $A_i = k \cdot gcd(a, n)$ 证明: $A_0 = 0, A_x = x \cdot a - y \cdot n$ ...
- zw版【转发·台湾nvp系列Delphi例程】HALCON MoveRectangle2
zw版[转发·台湾nvp系列Delphi例程]HALCON MoveRectangle2 procedure TForm1.Button1Click(Sender: TObject);var img ...
- hdu5009
这题说的是给了一个 长度为n(n<=50000)的数列,数列表示的是给每个珍珠涂的颜色,任务是将一窜长度为n的珍珠涂成他所要的颜色.然后你可以操至多n次, 每次画只能画连续的区间,每次操作是的 ...
- centos7修改hostname
[root@centos7 ~]$ hostnamectl set-hostname prd_web1 # 使用这个命令会立即生效且重启也生效 [root@centos7 ~]$ hostname # ...
- RANSAC算法在图像拼接上的应用的实现
关于算法原理请参考<基于SURF特征的图像与视频拼接技术的研究>. 一.问题提出 RANSAC的算法原理并不复杂,比较复杂的地方在于"建立模型"和&qu ...
- 20145326 《Java程序设计》课程总结
每周读书笔记链接汇总 20145326第1周学习总结 20145326第2周学习总结 20145326第3周学习总结 20145326第4周学习总结 20145326第5周学习总结 20145326第 ...
- 20162314 Experiment 3 - Sorting and Searching
Experiment report of Besti course:<Program Design & Data Structures> Class: 1623 Student N ...