一、静态导入(jdk1.5以后的特性):
一般使用静态方法都需要写上: 类名.方法 如:Math.max(a, b);
静态导入:import static java.lang.Math.*; 则后面写方法时可以直接: max(a, b);
二、可变参数
面试题:overload 和 override的区别?
http://robert.blog.51cto.com/374512/591269
可变参数:一个方法接受的参数个数不固定.。
特点:1)只能出现在参数列表的最后
2)调用可变参数的方法时,编译器为该可变参数隐含创建一个数组,在方法体中以数组形式访问可变参数。
public static int add(int a,int ... args){ //1)最后
int sum = a;
for (int i = 0; i < args.length; i++) {
sum += args[i]; //2)数组
}
return sum;
}
三、增强for循环
for (int arg : args) {
sum += arg;
}
四、枚举
枚举:就是要让某个类型的变量的取值只能为若干个固定值中的一个,否则编译器就会报错。枚举可以让编译器在编译时就可以控制源程序中填写的非法值,普通变量的方式在开发阶段无法实现这一目标。
http://www.iteye.com/topic/1116193
注:
1)如果想在一个类中编写完成各个枚举类和测试调用类,那么可以将枚举类定义成调用类的内部类。采用抽象方法定义nextDay就是将大量的if.else语句转移成一个个独立的类。
2)如果枚举只有一个成员时,就可以作为一种单例的实现方式(相反思考:若要定义一个单例,可写一个一个元素的枚举类)
public class EnumTest {
public static void main(String[] args) {
//一、用枚举定义变量,只能给它原定义的元素定义,实际上定义出来的变量为一个对象
Weekday fri = Weekday.FRI;
//枚举对象的方法
System.out.println(fri.name());//打印对象的名称
System.out.println(fri.ordinal());//给此对象排序
//枚举类的静态方法:
System.out.println(Weekday.valueOf("SUN"));//对传过来的字符串“SUN”变成实际对象“SUN”(对应的枚举元素)
System.out.println(Weekday.values());//把元素转成数组类型,(对枚举元素逐一的遍历:得到枚举数组,再遍历)
}
//二、定义枚举类型的一周 ,格式如下 :关键字:enum
public enum Weekday{
//枚举所列出来的元素都为一个个对象。
SUN,MON,TUE,WED,THI,FRI,SAT;
//无参的构造方法,类首先调用 要定义private
private Weekday(){
System.out.println("first");
}
private Weekday (int day){
System.out.println("seconed");
}
}
//三、定义一个交通灯枚举:抽象方法 、有参构造方法混合使用(较复杂)
public enum TrafficLamp{
//new 子类的实例对象,并调用有参的构造方法 ,并用RED
RED(40){
//每个元素重写类的抽象方法nextLamp()
public TrafficLamp nextLamp(){
return GREEN;
}
},
GREEN(35){
public TrafficLamp nextLamp(){
return YELLOW;
}
},
YELLOW(10){
public TrafficLamp nextLamp() {
return RED;
}
};
//定义类TrafficLamp的抽象方法
public abstract TrafficLamp nextLamp();
//定义类TrafficLamp的构造方法,带时间参数
private int time;
private TrafficLamp(int time){
this.time = time;
}
}
}