对于功能类似的方法来说,因为参数列表不一样,却需要记住那么多不同的方法名称,太麻烦。 此时,就可以使用到方法的重载 方法的重载(overload):多个方法的名称一样,但是参数列表不一样 好处:只需要记住一个方法名称,就可以实现类似的多个功能 方法重载与下列因素相关: 1. 参数个数不同 2. 参数类型不同 3. 参数的多类型顺序不同 方法重载与下列因素无关: 1. 参数的名称无关 2. 方法的返回值类型
接下来用代码实现,助于理解:
public class Demo01MethodOverload {
public static void main(String[] args) {
System.out.println(sum(10, 20));// 两个参数的方法
System.out.println(sum(10, 20, 30));// 三个参数的方法
System.out.println(sum(10, 20, 30, 40));//四个参数的方法
}
public static int sum(int a, double b) {
return (int) (a + b);
} //参数的多类型顺序不同
public static int sum(double a, int b) {
return (int) (a + b);
} //参数的多类型顺序不同
public static int sum(int a, int b) {
System.out.println("有两个参数方法的执行");
return a + b;
}
public static int sum(int a, int b, int c) {
System.out.println("有3个参数的方法执行");
return a + b + c;
}
public static int sum(int a, int b, int c, int d) {
System.out.println("有4个参数的方法执行");
return a + b + c + d;
}
public static int sun(double a, double b) {
return (int) (a + b);// 参数类型不同
}
}
参数类型分别为两个byte,两个short,两个int,两个long 并在main方法中进行测试
public class Demo10MethodOverloadSame {
public static void main(String[] args) {
byte a = 10;
byte b = 20;
System.out.println(isSame(a, b));
System.out.println(isSame((short)10, (short)20));
System.out.println(isSame(10, 20));
System.out.println(isSame(10l, 10l));
}
public static boolean isSame(byte a, byte b) {
System.out.println("两个byte参数的方法执行");
boolean same;
if (a == b) {
same = true;
} else {
same = false;
}
return same;
}
public static boolean isSame(short a, short b) {
System.out.println("两个short参数的方法执行");
boolean same = a == b ? true : false;
return same;
}
public static boolean isSame(int a, int b) {
System.out.println("两个int参数的方法执行");
return a == b;
}
public static boolean isSame(long a, long b) {
System.out.println("两个long参数的方法执行");
if (a == b) {
return true;
} else {
return false;
}
}
}
byte short int long float double char boolean String 在调用输出语句的时候,println方法其实就是进行了多种数据类型的重载形式
接下来用代码实现,助于理解:
public class Demo11OverloadPrint {
public static void main(String[] args) {
myprint(100);
myprint("Hello");
}
public static void myprint(byte num) {
System.out.println(num);
}
public static void myprint(short num) {
System.out.println(num);
}
public static void myprint(int num) {
System.out.println(num);
}
public static void myprint(long num) {
System.out.println(num);
}
public static void myprint(float num) {
System.out.println(num);
}
public static void myprint(double num) {
System.out.println(num);
}
public static void myprint(char zifu) {
System.out.println(zifu);
}
public static void myprint(boolean is) {
System.out.println(is);
}
public static void myprint(String str) {
System.out.println(str);
}
}
数组:是一种容器,可以同时存放多个数据值 数组的特点: 1. 数组是一种引用数据类型 2. 数组当中的多个数据,类型必须统一 3. 数组的长度在程序运行期间不可改变 数组的初始化:在内存当中创建一个数组,并且向其中赋予一些默认值。
两种常见的初始化方式: 1. 动态初始化:(指定长度) 2. 静态初始化:(指定内容)
动态初始化数组的格式: 数据类型[] 数组名称 = new 数据类型[数组长度];
解析含义: 左侧数据类型:也就是数组当中保存的数据,全都是统一的什么类型 左侧的中括号:代表是一个数组 左侧的数组名称:给数组取一个名字 右侧的new:代表创建数组的动作 右侧的数据类型必须和左边的数据类型保持一致 右侧中括号的长度,也就是数组当中,到底可以保存多少个数据,是一个int数字
接下来用代码实现,助于理解:
public class Demo12Array {
public static void main(String[] args) {
// 创建一个数组,里面可以存放300个int数据
// 格式:数据类型[] 数组名称 = new 数据类型[数组长度];
int[] arrayA = new int[300];
// 创建一个数组,能存放10个double类型的数据
double[] arrayB = new double[10];
// 创建一个数组,能存放5个字符串
String[] arrayC = new String[5];
}
}
静态初始化:在创建数组的时候,不直接指定数据个数多少,而是直接将具体的数据内容 进行指定。 静态初始化基本格式: 数据类型[] 数组名称 = new 数据类型[] { 元素1,元素2,...}; 注意事项: 虽然静态初始化没有直接告诉长度,但是根据打括号里面的元素具体内容,也可以 自动推算出长度。所以数组都是有长度的。
接下来用代码实现,助于理解:
public class Demo13Array {
public static void main(String[] args) {
// 直接创建一个数组,里面装的全都是int数字,具体为5、15、25
int[] arrayA = new int[] {5, 15, 25};
// 创建一个数组,用来装字符串:“Hello”,“World”,“Java”
String[] arrayB = new String[] {"Hello", "World", "Java"};
}
}
使用静态初始化数组的时候,格式还可以省略一下。 标准格式: 数据类型[] 数组名称 = new 数据类型[] { 元素1,元素2,...}; 省略格式: 数据类型[] 数组名称 = { 元素1,元素2,...}; 注意事项: 1. 静态初始化没有直接指定长度,但是仍然会自动推算得到长度 2. 静态初始化标准格式可以拆分为两个步骤 3. 动态初始化也可以拆分为两个步骤 4. 静态初始化一旦使用省略格式,就不能拆分为两个步骤了 使用建议: 如果不确定数组当中的具体内容,用动态初始化;否则,已经确定了具体的内容,用静态初始化
接下来用代码实现,助于理解:
public class Demo14Array {
public static void main(String[] args) {
// 省略格式的静态初始化
int[] arrayA = { 10, 20, 30};
// 静态初始化的标准格式,可以拆分为两个步骤
int[] arrayB;
arrayB = new int[] { 11, 21, 31 };
//动态初始化也可以拆分为两个步骤
int[] arrayC;
arrayC = new int[5];
}
}
直接打印数组名称,得到的是数组对应的:内存地址哈希值 二进制:01 十进制:0123456789 16进制:0123456789abcdef 访问数组元素的格式:数组名称[索引值] 索引值:就是一个int数字,代表数组当中元素的编号 【注意】索引值从0开始,一直到“数组的长度-1“为止
接下来用代码实现,助于理解:
public class Demo15ArrayUse {
public static void main(String[] args) {
// 静态初始化的省略格式
int[] array = { 10, 20, 30};
System.out.println(array);// [I@1b6d3586
// 直接打印数组当中的元素
System.out.println(array[0]);// 第0号元素是10
// 也可以将数组当中的某一个单个元素,赋值交给变量
int num = array[2];
System.out.println(num);// 30
}
}
使用动态初始化数组的时候,其中的元素将会自动拥有一个默认值,规则如下: 如果是整数类型,那么默认为0; 如果是浮点类型,那么默认为0.0; 如果是字符类型,那么默认为‘\u0000’; 如果是布尔类型,那么默认为false; 如果是引用类型,那么默认为null 注意事项: 静态初始化其实也有默认值的过程,只不过系统自动马上将默认值替换成为了大括号当中的具体数值
接下来用代码实现,助于理解:
public class Demo16ArrayUse {
public static void main(String[] args) {
// 动态初始化一个数组
int[] array = new int[3];
System.out.println(array);// 内存地址值
System.out.println(array[0]);
System.out.println(array[1]);
System.out.println(array[2]);
System.out.println("==================");
// 将数据123赋值交给数组array当中的1号元素
array[1] = 123;
System.out.println(array[1]);
}
}
Java的内存需要划分成为5个部分: 1. 栈(stack):存放的都是方法中的局部变量。方法的运行一定要在栈当中运行。 局部变量:方法的参数,或者是方法{}内部的变量 作用域:一旦超出作用域,立刻从栈内存当中消失 2. 堆(Heap):凡是new出来的东西,都在堆当中 堆内存里面的东西都有一个地址值:16进制 堆内存里面的数据,都有默认值,规则: 如果是整数 默认为0 如果是浮点数 默认为0.0 如果是字符 默认为‘\u0000’ 如果是布尔 默认为false 如果是引用类型 默认为null 3. 方法区(Method Area):存储.class相关信息,包含方法的信息 4. 本地方法栈(Native Method Stack):与操作系统相关 5.寄存器(pc Register):与CPU相关
public class Demo18ArrayOne {
public static void main(String[] args) {
int[] array = new int[3];// 动态初始化
System.out.println(array);// 地址值
System.out.println(array[0]);
System.out.println(array[1]);
System.out.println(array[2]);
System.out.println("============");
// 改变数组当中元素的内容
array[1] = 10;
array[2] = 20;
System.out.println(array);// 地址值
System.out.println(array[0]);
System.out.println(array[1]);
System.out.println(array[2]);
}
}
public class Demo19ArrayTwo {
public static void main(String[] args) {
int[] arrayA = new int[3];// 动态初始化
System.out.println(arrayA);// 地址值
System.out.println(arrayA[0]);
System.out.println(arrayA[1]);
System.out.println(arrayA[2]);
System.out.println("============");
arrayA[1] = 10;
arrayA[2] = 20;
System.out.println(arrayA);// 地址值
System.out.println(arrayA[0]);
System.out.println(arrayA[1]);
System.out.println(arrayA[2]);
System.out.println("============");
int[] arrayB = new int[3];// 动态初始化
System.out.println(arrayB);// 地址值
System.out.println(arrayB[0]);
System.out.println(arrayB[1]);
System.out.println(arrayB[2]);
System.out.println("============");
arrayB[1] = 100;
arrayB[2] = 200;
System.out.println(arrayB);// 地址值
System.out.println(arrayB[0]);
System.out.println(arrayB[1]);
System.out.println(arrayB[2]);
}
}
public class Demo20ArraySame {
public static void main(String[] args) {
int[] arrayA = new int[3];// 动态初始化
System.out.println(arrayA);// 地址值
System.out.println(arrayA[0]);
System.out.println(arrayA[1]);
System.out.println(arrayA[2]);
System.out.println("============");
arrayA[1] = 10;
arrayA[2] = 20;
System.out.println(arrayA);// 地址值
System.out.println(arrayA[0]);
System.out.println(arrayA[1]);
System.out.println(arrayA[2]);
System.out.println("============");
// 将arrayA数组的地址值,赋值给arrayB数组
int[] arrayB = arrayA;
System.out.println(arrayB);// 地址值
System.out.println(arrayB[0]);// 0
System.out.println(arrayB[1]);// 10
System.out.println(arrayB[2]);// 20
System.out.println("============");
arrayB[1] = 100;
arrayB[2] = 200;
System.out.println(arrayB);// 地址值
System.out.println(arrayB[0]);
System.out.println(arrayB[1]);
System.out.println(arrayB[2]);
}
}
数组的索引编号从0开始,一直到“数组的长度-1为止” 如果访问数组元素的时候,索引编号并不存在,那么将会发生 数组索引越界异常 ArrayIndexOutOfBoundsException 原因:索引编号写错了 解决:修改成为存在的正确索引编号
接下来用代码实现,助于理解:
public class Demo21ArrayIndex {
public static void main(String[] args) {
int[] array = { 15, 25, 35};
System.out.println(array[0]);
System.out.println(array[1]);
System.out.println(array[2]);
// 错误写法
// 并不存在3号元素,所以发生异常
System.out.println(array[3]);
}
}
所有的引用类型变量,都可以赋值为一个null值,代表其中什么都没有 数组必须进行new初始化才能使用其中的元素 如果只是复制了一个null,没有进行new创建 那么将会发生: 空指针异常:NullPointerException 原因:忘了new 解决:补上new
接下来用代码实现,助于理解:
public class Demo22ArrayNull {
public static void main(String[] args) {
int[] array = null;
//array = new int[3];
System.out.println(array[0]);
}
}
如何获取数组的长度,格式: 数组名称.length 这将会得到一个int数字,代表数组的长度 数组一旦创建,程序运行期间,长度不可改变
接下来用代码实现,助于理解:
public class Demo23ArrayLength {
public static void main(String[] args) {
int[] arrayA = new int[3];
int[]arrayB = { 10, 20, 30, 40, 50, 50, 60 };
int len = arrayB.length;
System.out.println("arrayB数组的长度是:" + len);
System.out.println("============");
int[] arrayC = new int[3];
System.out.println(arrayC.length);
arrayC = new int[5];
System.out.println(arrayC.length);
}
}
public class Demo24Array {
public static void main(String[] args) {
int[] array = { 15, 25, 30, 40, 50, 75 };
// 首先使用原始方式
System.out.println(array[0]);
System.out.println(array[1]);
System.out.println(array[2]);
System.out.println(array[3]);
System.out.println(array[4]);
System.out.println("===========");
// 使用循环,次数其实就是数组的长度
for (int i = 0; i < 5; i += 1) {
System.out.println(array[i]);
}
System.out.println("===========");
int len = array.length;// 长度
for (int i = 0; i < len/*或者直接写array.length*/; i += 1) {
System.out.println(array[i]);
}
}
}
public class Demo25ArrayMax {
public static void main(String[] args) {
int[] array = { 5, 15, 30, 20, 10000 };
int max = array[0];
for (int i = 1; i < array.length; i++) {
// 如果当前元素,比max最大,则换
if (array[i] > max) {
max = array[i];
}
}
System.out.println("最大值:" + max);
}
}
public class Demo26ArrayMin {
public static void main(String[] args) {
int[] array = { 5, 15, 30, 20, 10000 };
int min = array[0];
for (int i = 1; i < array.length; i++) {
// 如果当前元素,比min小,则换
if (array[i] < min) {
min = array[i];
}
}
System.out.println("最小值:" + min);
}
}