java问题收集

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           
  1. new HashSet<String>() {{  
  2.        add("XZ13s");  
  3.        add("AB21/X");  
  4.        add("YYLEX");  
  5.        add("AR2D");  
  6. }};  
             实际是定义了一个内部匿名类 (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);             // 年份数

http://code.taobao.org/p/gecko/wiki/design-core/   教你看gecko框架代码(其实是netty简化版)

星期六,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的能力,使用注解实现的功能都可以以非注解的方式实现,只是代码可能不是很好看而已
posted @ 2014-10-10 20:44  黑DWADE  阅读(152)  评论(0编辑  收藏  举报