- 浏览: 249781 次
- 性别:
- 来自: 济南
文章分类
- 全部博客 (303)
- c (31)
- c++ (16)
- java (18)
- c# (1)
- python (3)
- java web (6)
- oracle (7)
- sqlserver (2)
- mysql (2)
- android (24)
- android系统 (15)
- android多媒体部分 (15)
- android游戏 (12)
- linux (26)
- javaScript (1)
- ajax (1)
- node JS (2)
- html (5)
- apache (3)
- jboss (1)
- weblogic (0)
- 通信协议 (10)
- 云计算 (1)
- 分布式 (5)
- ejb (1)
- webservice (5)
- 设计模式 (16)
- JNI (6)
- swing (13)
- 版本控制 (1)
- UML (1)
- xml (4)
- spring (5)
- hibernate (5)
- struts1 (3)
- struts2 (4)
- ibatis (0)
- tomcat (2)
- 心得体会 (1)
- css (1)
- 嵌入式 (41)
- arm体系结构 (10)
1静态导入
导入指定类的某个静态属性值或全部静态值
示例代码:
导入单个静态属性
import static java.long.system.out
导入静态方法
import static java.lang.math.max
导入全部静态属性和方法
import static java.lang.math.*
2自动装箱/拆箱
装箱
基本类型直接赋值给对应的包装类型(或是object变量)
示例代码如下:
int m=9;
System.out.println("m"+m);
Integer n=m;
System.out.println("n"+n);
拆箱
包装类型对象直接赋值给一个对应的基本类型变量
int k=n;
System.out.println("k"+k);
3for-each增强for循环
示例代码
for(类型 变量名: 集合变量名){}
4可变参数
/**
* 一个参数求和
*
* @param array
* @return
*/
public static int add(Integer... array) {
int sum = 0;
if (null != array && array.length > 0) {
for (int i = 0; i < array.length; i++) {
sum = sum + array[i];
}
}
return sum;
}
/**
* 一个参数和多个参数
*
* @param m
* @param array
* @return
*/
public static int add(int m, Integer... array) {
int sum = 0;
if (null != array && array.length > 0) {
for (int i = 0; i < array.length; i++) {
sum = sum + array[i];
}
}
return sum + m;
}
public static void main(String[] args) {
// 一个参数求和
Integer array[] = { 1, 2, 3, 4 };
System.out.println(add(array));
System.out.println(add(7, array));
}
5枚举 switch条件中可以使用枚举类型
public enum season {
SPRING, SUMMER, AUTUMNN, WINNER;
}
public static void main(String[] args) {
System.out.println(season.SPRING);
}
6泛型
7元数据
8反射
生成对象两种方法:
使用class对象的newInstance(), 使用默认构造器来创建实例
使用class对象获取指定的constructor(),再调用constructor的newInstance
调用方法
class的getMethods()和getMethod()方法, invoke();
访问属性
class的getFields() 和getField()方法 getxxx(obj)和setxxx(obj)
9内省
10 动态代理
/**
* 动态代理
*
* @time 1:18:30 PM
* @author retacn yue
* @Email zhenhuayue@sina.com
*/
public class JDKProxy implements InvocationHandler {
private Object targetObject;// 代理目标对象
/**
* 创建代理对象
*/
public Object createProxyInstance(Object targetObject) {
this.targetObject = targetObject;
/**
* 参数一:与目标类相同的类加载器 // 参数二:代理类使用的接口 //
* 参数三:回调对象,当代理对象的方法被调用时,会调用该参数指定的invoke方法//
*/
return Proxy.newProxyInstance(targetObject.getClass().getClassLoader(), targetObject.getClass().getInterfaces(), this);
}
/**
* @ proxy 目标对象的代理实例 @ method 对应于在代理实例上调用接口方法的method实例
*
*/
public Object invoke(Object proxy, Method method, Object[] args) throws Throwable {
System.out.println("代现实例:" + proxy.getClass());
System.out.println("方法名称:" + method.getName());
if (null != args && args.length > 0) {
for (int i = 0; i < args.length; i++) {
System.out.println("方法参数:" + args[i].toString());
}
}
Object returnValue = null;
// 调用目标对象的方法
returnValue = method.invoke(this.targetObject, args);
System.out.println("方法的返回值:" + returnValue);
return returnValue;
}
}
自定义注解
注解是一个非凡的接口:
a 使用关键字@interface
b 方法必须声明为无参,无异常抛出,
c 可以定义常量,静态成员,也可以被实现和继承
jdk的元注解
@Retention(value=RetentionPolicy.RUNTIME)
用于指定annotation可以保留多长时间
value变量的值有:
CLASS 编译器把注释记录在class 文件中,当远行程序时,JVM不保留注释
RUNTIME JVM 保留注释,程序通过反射获取注释
SOURCE 直接丢弃这种策略的注释
@Target(value = { ElementType.FIELD }) 该注解用于什么地方
ElementType.CONSTRUCTOR 构造器声明
ElementType.FIELD 域声明
ElementType. LOCAL_VARIABLE 局部变量声明
ElementType.METHOD 方法声明
ElementType.PACKAGE 包声明
? ElemenetType.PARAMETER 参数声明
?ElemenetType.TYPE 类,接口(包括注解类型)或enum声明 ElemenetType.ANNOTATION_TYPE 注解声明
@Documented 将被javadoc工具提取成为文档
@Inherited 具有继承性
发表评论
-
thread local 学习笔记
2012-11-08 15:45 595thread local(thread 的局部变量)解决多 ... -
mina 学习笔记一
2012-11-05 16:33 593mina下载路径 http://mina.apache.or ... -
多线程学习笔记一
2012-09-04 11:03 627/** * 子线程循环10次,主线程100次 如此 ... -
多线程学习笔记二
2012-09-04 11:05 599/** * 传统线程 * * @time 下午06:15 ... -
多线程学习笔记三
2012-09-04 11:06 581/** * 两个线程进行数据交换 * * @time 上 ... -
多线程学习笔记四
2012-09-04 11:08 627/** * 线程范围内的数据共享 * * 应用场景:减少 ... -
java swing 学习笔记一(画板Panel )
2012-09-04 11:18 1016/** * 画板 * * @time 3:38:10 P ... -
java swing学习笔记二(画布Canvas)
2012-09-04 11:19 3197/** * 画布 * @time 11:23:53 AM ... -
java IO流学习笔记一
2012-09-08 17:10 449IO 两大主流 16位和8位 16位对应writer和rea ... -
java 类装载器
2012-09-08 18:12 655public class ClassLoaderTest { ... -
并发库学习笔记一
2012-09-28 16:37 611新建线程并启动的几种 ... -
并发库学习笔记二
2012-09-28 16:38 430阻塞队列(生产者和消费者开发模式) 三种常用的阻塞队 Ar ... -
并发库学习笔记三
2012-09-28 16:40 565Synchronized是lock的一种简化实现,一个l ... -
并发库学习笔记四
2012-09-28 16:42 634ConcurrentHashMap并没有实现Lock-Free ... -
并发库学习笔记五
2012-09-28 16:43 694并发流程控制CountDown ... -
java IO流学习笔记二
2012-10-03 00:24 592/** * * * 目录分隔符用\\或/ * * @ ... -
java IO流学习笔记三
2012-10-04 23:39 669转换流 inputStreamReader 字节转字符 o ...
相关推荐
jdk5.0新特性介绍
[浪曦][原创]JDK5.0新特性[风中叶老师主讲]共10 part [浪曦][原创]JDK5.0新特性[风中叶老师主讲]共10 part
2.JDK5.0新特性.doc 2.JDK5.0新特性.doc
JDK5.0新特性,视频教学课件,可用容易学
jdk1.5(jdk5.0)较之前版本有了比较大的改变,本资料较详细的讲解了jdk5.0的新特性,相信能让你受益。
JDK5.0新特性 因为,在1.5版本中,对一个整数进行包装,使之成为一个Integer对象(即包装,boxing),然后加入到一个ArrayList中的做法被认为是没有必要的,反之,解包(unboxing)的做法也是没有必要的,这样的...
[浪曦][原创]JDK5.0新特性[风中叶老师主讲[浪曦][原创]JDK5.0新特性[风中叶老师主讲[浪曦][原创]JDK5.0新特性[风中叶老师主讲
jdk1.5以上版本中新增加的特性描述,带有代码例子让你很清晰的明白jdk的 常量 、枚举、 for each、反射等各种新的特性,相信需要的你,一定满足。
jdk5.0新特性 包括泛型,增强的for循环,自动的封箱和拆箱
[浪曦][原创]JDK5.0新特性[风中叶老师主讲]共10 part [浪曦][原创]JDK5.0新特性[风中叶老师主讲]共10 part
[浪曦][原创]JDK5.0新特性[风中叶老师主讲][浪曦][原创]JDK5.0新特性[风中叶老师主讲][浪曦][原创]JDK5.0新特性[风中叶老师主讲]
[浪曦][原创]JDK5.0新特性[风中叶老师主讲]共10 part [浪曦][原创]JDK5.0新特性[风中叶老师主讲]共10 part
主要内容是JDK5.0的11个主要新特征 是理解5.0和4.0差别很好的参考材料。
JDK 5.0的新特性Annotations
[浪曦][原创]JDK5.0新特性[风中叶老师主讲]共10 part [浪曦][原创]JDK5.0新特性[风中叶老师主讲]共10 part [浪曦][原创]JDK5.0新特性[风中叶老师主讲]共10 part
[浪曦][原创]JDK5.0新特性[风中叶老师主讲]共10 part [浪曦][原创]JDK5.0新特性[风中叶老师主讲]共10 part [浪曦][原创]JDK5.0新特性[风中叶老师主讲]共10 part
NULL 博文链接:https://newjueqi.iteye.com/blog/400855
浪曦 - JDK5.0新特性.part2
浪曦 - JDK5.0新特性.part3
浪曦 - JDK5.0新特性.part5.rar