优秀的代码收集

一.不可修改的集合
fff.png

二.懒加载

A类中有一个属性b,这个属性b是B类的一个对象。也就是说A类中持有了B对象。如果是不同的加载方式。在A中持有的B对象会在A创建的时候同时被创建。例如

public class A{
B b
public A(){
 b=new B();
}
public B getB(){
  return b;
}
}

使用懒加载的方式可以在b被使用的时候才去创建。在没有被使用之前b是一个没有实际意义的代理对象。

public class A{
  B b;
 public A(){
 }
  public synchronized B  executeB(){
     if(b=null){
       b=new B(); 
     }
   return b;
  }
}
 //只有该方法被创建时,B对象才被创建。
  public B getB(){
    return executeB();
  }

在OkHttp的Dispatcher类中


7E4C3BBB-4719-4004-A746-15D89D2F0A96.png

三.Foreach的等价代码

String[] strings = {"A", "B", "C", "D"};
Collection stringList = java.util.Arrays.asList(strings);
/* 开始遍历 */
//获取数组的迭代器
for (Iterator itr = stringList.iterator(); itr.hasNext();) {
Object str = itr.next();//获取当前遍历的元素
itr.remove();//从集合中移除该元素
System.out.println(str);
}

foreach

for(String s:stringList){
  Object str = itr.next();
  System.out.println(str);
}
7C26249F-3B58-4C0B-AE16-E67E8177BBCD.png

3.Deck队列 Deque

/** 准备好的异步请求他们将顺序的执行。FIFO 先进先出 * 队列的
种实现,通常读作deck,双端队列,支持在两端插入和移除数据,
它不仅可以实现先进先出的队列,也可以实现后进先出的堆栈。 */
private final Deque<AsyncCall> readyAsyncCalls = 
new ArrayDeque<>();//等待队列

具备队列的特性


F396AF8A-3101-41A0-89DA-A65734AF9CC8.png

同时具备堆栈的特性
用作 LIFO(后进先出)堆栈。应优先使用此接口而不是遗留 Stack 类。在将双端队列用作堆栈时,元素被推入双端队列的开头并从双端队列开头弹出。


184B30D4-988B-426C-900D-D9BB58D0CE69.png

如何确保返回一个维护的原始对象

//BigInteger在创建时维护了一个bigInt对象。
   public BigInteger(byte[] value) {
        BigInt bigInt = new BigInt();
        bigInt.putBigEndianTwosComplement(value);
        setBigInt(bigInt);
    }
  private void setBigInt(BigInt bigInt) {
        this.bigInt = bigInt;
        this.nativeIsValid = true;
    }
  BigInt getBigInt() {
        if (nativeIsValid) {
            return bigInt;
        }
        synchronized (this) {
            if (nativeIsValid) {
                return bigInt;
            }
            BigInt bigInt = new BigInt();
           //重新维护这个对象
            setBigInt(bigInt);
            return bigInt;
        }
    }
//如果这个BigInt对象没有修改过,那么直接使用它
    public BigInteger negate() {
        BigInt bigInt = getBigInt();
        BigInt a = bigInt.copy();
        ...
        return new BigInteger(a);
    }

确保当前是UI线程

  public static boolean isOnMainThread() {
    return Looper.myLooper() == Looper.getMainLooper();
  }

定义更全面的错误信息

TreeMap中定义了更全面的异常信息,以便更精确的定位错误

 throw outOfBounds(to, this.fromBound, toBoundToCheck);
 private IllegalArgumentException outOfBounds(Object value, Bound fromBound, Bound toBound) {
            return new IllegalArgumentException(value + " not in range "
                    + fromBound.leftCap(from) + ".." + toBound.rightCap(to));
        }

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容

  • 1.ios高性能编程 (1).内层 最小的内层平均值和峰值(2).耗电量 高效的算法和数据结构(3).初始化时...
    欧辰_OSR阅读 29,804评论 8 265
  • Swift1> Swift和OC的区别1.1> Swift没有地址/指针的概念1.2> 泛型1.3> 类型严谨 对...
    cosWriter阅读 13,797评论 1 32
  • Spring Cloud为开发人员提供了快速构建分布式系统中一些常见模式的工具(例如配置管理,服务发现,断路器,智...
    卡卡罗2017阅读 135,347评论 19 139
  • 临近第四节课下课,桌洞里的饭盒开始左一声右一声地哗啦上了。下课铃一响,摇着饭盒冲出教室,奔向食堂。食堂窗口前瞬间排...
    riverchild阅读 1,768评论 0 0
  • 001、掌握好度 资讯过少至稀缺,影响个人视野、格局和发展;资讯过多至泛滥,阻碍正常理解力,使我们淹没在信息的海洋...
    An_An阅读 851评论 0 1