作者:whisper
链接:http://proprogrammar.com:443/article/51
声明:请尊重原作者的劳动,如需转载请注明出处
前两天看到jdk10试用版都出来了,才发现自己连1.8都没用过,对不同版本的jdk的新特性也不是太了解,所以想还是百度一下看看人家怎么说然后自己记录总结一下,其中jdk1.8的新特性可以到edu.51cto.com上学习一下,好了,现在说说jdk1.5的常用新特性吧。
泛型,
foreach循环,
自动拆装箱,
类型安全的枚举,
可变参数,
内省(https://www.cnblogs.com/H_Razor/archive/2011/02/28/1967178.html),
静态导入,
线程池,
元数据(http://www.importnew.com/14227.html)
C++通过模板技术可以指定集合的元素类型,而java在1.5之前一直没有相对应的功能,一个集合可以放任何类型的对象,相应地从集合里面拿对象的时候我们也不得不对他们进行强制的类型转换。猛虎引入了泛型,它允许指定集合里元素的类型,这样你可以强类型在编译时刻进行类型检查的好处。
Collection<String> c = new ArrayList<String>();
c.add(new Date());
//编译器会给出一个错误:
add(java.lang.String) in java.util.Collection<java.lang.String> cannot be applied to (java.util.Date)
foreach循环的加入简化了集合的遍历。假设我们要遍历一个集合对其中的元素进行一些处理。典型的代码为:
void processAll(Collection c) {
for(Iterator i = c.iterator();i.hasNext();) {
MyClass myObject = (MyClass) i.next();
myObject.process();
}
}
//使用foreach循环,我们可以把代码改写成:
void processAll(Colllection<MyClass> c) {
for(MyClass myObject : c) {
myObject.process();
}
}
//这段代码要比上面清晰许多,并且避免了强制类型转换。
自动装箱:基本类型自动转为包装类(int >> Integer)
自动拆箱:包装类自动转为基本类型(Integer >> int)
int a = 3;
COllection<Integer> c = new ArrayList<Integer>();
c.add(a);//自动转换为Integer
Integer b = new Integer(2);
c.add(b+2);//这里Integer先自动转换为int进行加法运算,然后int再次转换为Integer
JDK1.5加入了一个全新的“类”--枚举类型。为此JDK1.5引入了一个新关键字enum。我们可以这样定义一个枚举类型。
public enum Color {
RED,WHITE,BLUE
}
public enum Coin {
penny(1), nickel(5), dime(10), quarter(25);
Coin(int value) {
this.value = value;
}
private final int value;
public int value() {
return value;
}
}
//然后可以这样来使用:
Color myColor = Color.RED;
//枚举类型还提供了两个有用的静态方法values()和valueOf().我们可以很方便地使用它们,例如:
for(Color c : Color.values()) {
System.out.printl(c);
}
可变参数使程序员可以声明一个接受可变数目参数的方法。注意,可变参数必须是函数生命中的最后一个参数。加入我们要写一个简单的方法打印一些对象:
util.write(obj1);
util.write(obj1,obj2);
util.write(obj1,obj2,obj3);
...
在JDK1.5之前,我们可以用重载来实现,但是这样就需要写很多的重载函数,显得不是很有效。如果使用可变参数的话,我们只需要一个函数就行了:
public void write(Object... objs) {
for(Object obj : pbjs) {
System.out.println(obj);
}
}
在引入可变参数以后,Java的反射包也更加方便使用了,对于
c.getMethod("test", new Object[0]).invoke(c.newInstance(), new Object[0]);
//现在我们可以这样写了
c.getMethod("test").invoke(c.newInstance());
//这样代码比原来清楚了很多
要使用静态成员(方法和变量)我们给出提供这个方法的类。使用静态导入可以使被导入类的所有静态变量和静态方法在当前类直接可见,使用这些静态成员无需再给出他们的类名
import static java.lang.Math.*;
...
r = sin(PI * 2);//无需再写 r = Math.sin(Math.PI * 2);
不过,过度使用这个特性也会一定程度上降低代码的可读性。
线程并发库是Java1.5提出的关于多线程处理的高级功能,所在包:java.util.concurrent(juc)
1.线程互斥
工具类描述:Lock,RedWriteLock
2.线程通信
描述:Condition
3.线程池
ExecutorService
4.同步队列
ArrayBlockingQueue
5.同步集合
ConcurrentHashMap,CopyOnWriteArrayList
6.线程同步工具
Semaphore
关于线程并发库的内容还有很多(很重要),这里就不一一列举了,感兴趣的朋友可以查看一下相关资料。
注解(Annotation), 内容见上文网址.
亲爱的读者:有时间可以点赞评论一下
全部评论