2014-10-27
构造器最好保留一个无参的,否则一些框架调用初始化时,会报错
星期三,2013年11月6日
volatile关键字 : 1. 与synchronized几乎相同,但是volatile在多读少写的情况下,性能更优
2. 用来定义成员变量时,可以保证多线程每次读取成员变量都是从共享内存中读取,保证值相等
ConcurrentLinkedQueue:
1. 无锁的并发线程安全的队列
2. 要判断是否为空时,size( )会遍历整个集合,耗时较长,可改用isEmpty( )
当map为EmptyMap的时候不能使用putAll,否则报 java.lang.UnsupportedOperationException 异常 ,因为Collection.emptyMap( )此映射不支持 put 操作,并且指定映射为非空
这里的EmptyMap并不是null,也不是size = 0的新集合,null本来就不支持putAll操作,size=0则可以putAll
星期五,2013年12月20日
List 和 数组 互相转换:
List --> 数组 :
String[] array = (String[])list.toArray(new String[list.size()]);
数组 --> List :
List<String> list=Arrays.asList(array);
http://www.iteye.com/topic/418542
- new HashSet<String>() {{
- add("XZ13s");
- add("AB21/X");
- add("YYLEX");
- add("AR2D");
- }};
实际是定义了一个内部匿名类 (Anonymous Inner Class),第二层括弧 实际上是一个实例初始化块 (instance initializer block),这个块在内部匿名类构造时被执行。这种方法只适用于
星期三,2014年2月12日
final 修饰的变量不可修改,但是容器类型特殊
对于被static和final修饰过的实例常量,实例本身不能再改变了,但对于一些容器类型(比如,ArrayList、HashMap)的实例变量,不可以改变容器变量本身,但可以修改容器中存放的对象。你的需求可能需要自己包装一个类来实现。
jsonArray是一个jsonObject的一个数组:
星期五,2014年2月21日
时间处理
Long time = System.currentTimeMillis(); // long类型的当前时间
Date date = new Date(time); // 转换成date类型
SimpleDateFormat sdf = new SimpleDateFormat("yyyy-MM-dd HH:mm:ss"); // 设定格式
Calendar cal = Calendar.getInstance(); // 实例化,也是获得当前时间
cal.setTime(date); // 传入时间
int day = cal.get(Calendar.DAY_OF_MONTH); // int类型的天数
int month = cal.get(Calendar.MONTH) + 1; // 月份数,不知道为什么一定要 +1
int year = cal.get(Calendar.YEAR); // 年份数
星期六,2014年4月12日
如果一个对象有多个synchronized方法,某一时刻某个线程已经进入到了某个synchronized方法,那么在该方法没有执行完毕前,其他线程是无法访问该对象的任何synchronized方法的。
结论:
当synchronized关键字修饰一个方法的时候,该方法叫做同步方法。
Java中的每个对象都有一个锁(lock),或者叫做监视器(monitor),当一个线程访问某个对象的synchronized方法时,将该对象上锁,其他任何线程都无法再去访问该对象的synchronized方法了(这里是指所有的同步方法,而不仅仅是同一个方法),直到之前的那个线程执行方法完毕后(或者是抛出了异常),才将该对象的锁释放掉,其他线程才有可能再去访问该对象的synchronized方法。
注意这时候是给对象上锁,如果是不同的对象,则各个对象之间没有限制关系。
如果某个synchronized方法是static的,那么当线程访问该方法时,它锁的并不是synchronized方法所在的对象,而是synchronized方法所在的类所对应的Class对象。Java中,无论一个类有多少个对象,这些对象会对应唯一一个Class对象,因此当线程分别访问同一个类的两个对象的两个static,synchronized方法时,它们的执行顺序也是顺序的,也就是说一个线程先去执行方法,执行完毕后另一个线程才开始。
synchronized方法是一种粗粒度的并发控制,某一时刻,只能有一个线程执行该synchronized方法;
java元注解
@Target(ElementType.[type])
使用的对象,method表示使用在方法上
[type]={METHOD, FIELD, TYPE(类、接口、枚举声明), CONSTRUCTOR, LOCAL_VARIABLE,
PARAMETER(参数)}
@Retention(RetentionPolicy.[policy])
定义注解的保留策略
[policy]={SOURCE,
CLASS, RUNTIME(反射机制可读取)}
SOURCE
//注解仅存在于源码中,在class字节码文件中不包含
CLASS //默认的保留策略,注解会在class字节码文件中存在,但运行时无法获得
RUNTIME //注解会在class字节码文件中存在,在运行时可以通过反射获取到
@Documented
表示将此注解包含到Javadoc
@Inherited
表示允许子类继承父类的注解
Spring与Junit的常用注解分析。
@Test 该注解是Spring下的,被注解方法可以直接运行,用来测试程序
如何合理的设计和使用注解
使用注解标记字段和方法,可通过反射的手段截取注解及其标记的字段和方法的元数据,并根据需求对元数据进行处理。
它赋予了字段和方法额外的意义,提供了一种统一处理字段和方法的优雅的方式。
注解更多的意义是提供了一种设计模式,在本质上它没有增强Java的能力,使用注解实现的功能都可以以非注解的方式实现,只是代码可能不是很好看而已