方法和对象相关;函数和对象无关。
Java中只有方法,C中只有函数,而C++里取决于是否在类中
简单的键盘输入和输出:
publicclass Test01 {
publicstaticvoid main (String[] args) {
Scannerscanner = new Scanner(System.in);
// 将输入的第一行赋给string
// String string=scanner.nextLine();
// 将输入单词到第一个空白符为止的字符串赋给string
// String string=scanner.next();
// 将输入的数字赋给变量6
intstring=scanner.nextInt();
System.out.println("结果: " + string);
}
}
方法(函数):
就是完成特定功能的代码块。为了提高代码的复用性,可以将其定义成一个单独的功能,该功能的体现就是java中的函数。函数就是体现之一。
方法的作用:
1)、用于定义功能。
2)、用于封装代码提高代码的复用性。
注意:方法中只能调用方法,不能定义方法。
如何定义一个方法?
方法其实就是一个功能,定义方法就是实现功能,通过两个明确来完成:
1)、明确该功能的运算完的结果,其实是在明确这个方法的返回值类型。
2)、在实现该功能的过程中是否有未知内容参与了运算,其实就是在明确这个方法的参数列表(参数类型&参数个数)。
为何定义方法名称?
1)、为了对该功能进行标示,方便于调用。
2)、为了通过名称就可以明确方法的功能,增加代码的阅读性。
java中的函数的定义格式:
访问控制符 [修饰符] 返回值类型 方法名( [参数] ) {
//方法体
}
方法用于定义类的某种行为(或功能)。
访问控制符:
用于限制方法在其他类中的使用范围
修饰符:
用于限制方法的调用方式:
static修饰的方法可以直接使用类名调用也可以使用类创建的对象调用
非static修饰的方法只能使用类创建的对象调用
被final修改的方法在子类中不能被重写。
返回值类型:
- 方法有返回值,使用return关键字将数据返回,return结束方法,结束功能,
- 如果方法返回基本数据类型的数据,则返回值类型必须是返回数据所属的数据类型或者精度更高的数据类型(针对于数值类型的数据)。
- 如果方法返回引用数据类型的数据,则返回值类型必须是返回数据所属的数据类型或者其父类。
- 方法不能返回多个值,将欲返回的多个值放在数组中,就可以间接实现返回多个值的效果。
- 当方法没有具体的返回值时,返回的返回值类型用void关键字表示。这时return语句可以省略,系统会帮你自动加上。
return的作用:
结束函数。结束功能。
方法不能返回多个值,将欲返回的多个值放在数组中,就可以间接实现返回多个值的效果。
如何定义一个函数?
函数其实就是一个功能,定义函数就是实现功能,通过两个明确来完成:
1)、明确该功能的运算完的结果,其实是在明确这个函数的返回值类型。
2)、在实现该功能的过程中是否有未知内容参与了运算,其实就是在明确这个函数的参数列表(参数类型&参数个数)。
重载
重载的定义是:在一个类中,如果出现了两个或者两个以上的同名函数,只要它们的参数的个数,或者参数的类型不同,即可称之为该函数重载了。
1,同一个类,
2,同名。
3,参数个数不同or 参数类型不同、顺序不同。
4,函数重载和返回值类型无关。
5,java是严谨性语言,如果函数出现的调用的不确定性,会编译失败
如何区分重载:当函数同名时,只看参数列表。和返回值类型没关系。
数组:
数组是相同数据类型的数据按顺序组成的一种引用数据类型。
声明数组仅仅给出了元素的数据类型和数组名字,要使用数组就必须为它分配内存空间,即实例化数组。当实例化一个数组时就申请了一段连续的内存空间存储数组中的元素。
数组中的数据是通过数组名和数组下标来操作数据的,下标从0开始下标的专业叫法:索引
用于存储同一类型数据的一个容器。
好处:
可以对该容器中的数据进行编号,从0开始。数组用于封装数据,就是一个具体的实体。
穷举法只能用于初始化数组,即必须和声明数组代码放在一条语句中完成。
核心思想:就是对角标的操作
如何在java中表现一个数组呢?两种表现形式。
元素类型[] 变量名 = new 元素类型[元素的个数];
元素类型[] 变量名 = {元素1,元素2...};
元素类型[] 变量名 = new 元素类型[]{元素1,元素2...};
数组中常见的两个异常:
ArrayIndexOutOfBoundsException://当访问到数组中不存在的角标时,就会发生该异常。
NullPointerException//当引用型变量没有任何实体指向时,还在用其操作实体。就会发生该异常
枚举类的使用
如何自定义枚举类?如何使用关键字enum定义枚举类?Enum类的主要方法?实现接口的枚举类
枚举类的使用:入门
类的对象只有有限个,确定的。举例如下:
星期:Monday(星期一)、......、Sunday(星期天)
性别:Man(男)、Woman(女)
季节:Spring(春节)......Winter(冬天)
支付方式:Cash(现金)、WeChatPay(微信)、Alipay(支付宝)、BankCard(银行卡)、CreditCard(信用卡)
就职状态:Busy、Free、Vocation、Dimission
订单状态:Nonpayment(未付款)、Paid(已付款)、Delivered(已发货)、Return(退货)、Checked(已确认)Fulfilled(已配货)、
线程状态:创建、就绪、运行、阻塞、死亡
当需要定义一组常量时,强烈建议使用枚举类
枚举类的实现
JDK1.5之前需要自定义枚举类
JDK 1.5 新增的enum 关键字用于定义枚举类
若枚举只有一个对象, 则可以作为一种单例模式的实现方式。
枚举类的属性
枚举类对象的属性不应允许被改动, 所以应该使用 private final 修饰
枚举类的使用private final 修饰的属性应该在构造器中为其赋值
若枚举类显式的定义了带参数的构造器, 则在列出枚举值时也必须对应的传入参数
自定义枚举类
私有化类的构造器,保证不能在类的外部创建其对象
在类的内部创建枚举类的实例。声明为:public static final
对象如果有实例变量,应该声明为private final,并在构造器中初始化
Class Season{
private final String SEASONNAME;//季节的名称
private final String SEASONDESC;//季节的描述
private Season(String seasonName,String seasonDesc){
this.SEASONNAME= seasonName;
this.SEASONDESC= seasonDesc;
}
Public static final Season SPRING= newSeason("春天", "春暖花开");
Public static final Season SUMMER= newSeason("夏天", "夏日炎炎");
Public static final Season AUTUMN= newSeason("秋天", "秋高气爽");
Public static final Season WINTER= newSeason("冬天", "白雪皑皑");
}
使用enum定义枚举类
使用说明
使用enum定义的枚举类默认继承了java.lang.Enum类,因此不能再继承其他类,枚举类的构造器只能使用private 权限修饰符
枚举类的所有实例必须在枚举类中显式列出(, 分隔; 结尾)。列出的实例系统会自动添加public static final 修饰
必须在枚举类的第一行声明枚举类对象
JDK 1.5 中可以在switch 表达式中使用Enum定义的枚举类的对象作为表达式, case 子句可以直接使用枚举值的名字, 无需添加枚举类作为限定。
Public enum SeasonEnum {
SPRING("春天","春风又绿江南岸"),
SUMMER("夏天","映日荷花别样红"),
AUTUMN("秋天","秋水共长天一色"),
WINTER("冬天","窗含西岭千秋雪");
private final String seasonName;
private final String seasonDesc;
private SeasonEnum(String seasonName, String seasonDesc) {
this.seasonName= seasonName;
this.seasonDesc= seasonDesc;
}
public String getSeasonName() {
return seasonName;
}
public String getSeasonDesc() {
return seasonDesc;
}
}
Enum类的主要方法:
values()方法:返回枚举类型的对象数组。该方法可以很方便地遍历所有的枚举值。
valueOf(String str):可以把一个字符串转为对应的枚举类对象。要求字符串必须是枚举类对象的“名字”。如不是,会有运行时异常:IllegalArgumentException。
toString():返回当前枚举类对象常量的名称
和普通Java 类一样,枚举类可以实现一个或多个接口,若每个枚举值在调用实现的接口方法呈现相同的行为方式,则只要统一实现该方法即可。若需要每个枚举值在调用实现的接口方法呈现出不同的行为方式, 则可以让每个枚举值分别来实现该方法