• 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的能力,使用注解实现的功能都可以以非注解的方式实现,只是代码可能不是很好看而已
  • 相关阅读:
    PageRank
    Web挖掘
    无监督学习
    Activiti 学习笔记记录(2016-8-31)
    Activiti 学习笔记记录(二)
    Activiti 学习笔记记录
    Mybatis + SpringMVC + Maven实现分页查询
    Jquery.min.js 下载
    使用Apache Archiva搭建Maven Repository Server
    SpringMVC 参数传递
  • 原文地址:https://www.cnblogs.com/fatcat132006/p/4017762.html
Copyright © 2020-2023  润新知