05 2018 档案

摘要:运行这段代码会抛出 的异常, 查看Arrays.as源码 new ArrayList是创建的内部的ArrayList 而不是java.util.Arrays包下的ArrayList 查找发现 内部的ArrayList并没有add方法 点击父类查看 父类实现的 add remove等修改集合元素的方法 阅读全文
posted @ 2018-05-28 19:29 意犹未尽 阅读(383) 评论(0) 推荐(0)
摘要:项目中突然报空指针异常 排查发现三元运算符空指针异常,表面上看不出来有什么问题,编译器编译的时候会保证:2边数据类型一致如: 会编译不通过。因为String 和int不是一个类型 这一切的原因都是编译器自动拆箱造成的。如下情况 价格是否为null判断就好了 阅读全文
posted @ 2018-05-25 20:55 意犹未尽 阅读(324) 评论(0) 推荐(0)
摘要:什么是IO 什么是 I/O?当程序需要从网络(如 TCP 套接字)读取数据,或向网络写入数据时,会触发 ​I/O 操作。 ​输入:从网络接收数据到应用程序的缓冲区(如 recv() 函数)。​输出:从应用程序的缓冲区发送数据到网络(如 send() 函数)。​为什么 I/O 是性能瓶颈? ​等待时间 阅读全文
posted @ 2018-05-09 21:16 意犹未尽 阅读(519) 评论(0) 推荐(0)
摘要:ReentrantLock源码 https://www.cnblogs.com/LQBlog/p/15206866.html 简单demo 在多线程操作时。保证一块共享资源的原子性。第一想到的就是用synchronized关键字 在jdk5提供一个更灵活更强大的 ReentrantLock 使用re 阅读全文
posted @ 2018-05-03 21:28 意犹未尽 阅读(417) 评论(0) 推荐(0)
摘要:限制并发资源的并发访问数量。 samephore.acquire(); 获取许可 samephore.release(); 释放一个许可。 模拟银行10个办理任务的窗口。 samephore.acquire() 如果有10个任务获取许可并没有释放 其他人等待 某一个获取许可正在执行的任务 释放许可才 阅读全文
posted @ 2018-05-03 12:46 意犹未尽 阅读(189) 评论(0) 推荐(0)
摘要:应用场景 财务成本核算。可能会有多个耗时的步骤。如果顺序执行是非常慢的。再相互数据获取数据不依赖的情况下可以使用Future并行执行 自己实现future异步加载 调用getData 方法如果没有setData 则state是false 则释放锁 加入到等待队列 当你get方法线程加载完数据再set 阅读全文
posted @ 2018-05-02 23:45 意犹未尽 阅读(1008) 评论(0) 推荐(1)
摘要:CountDownLatch CountDownLatch是jdk5 java.util.concurrent新增的的工具类 使用场景。如:导出excel需要解析创建多个sheel。创建多线程并行执行。执行完毕 相应给客户端 public static void main(String[] args 阅读全文
posted @ 2018-05-02 22:53 意犹未尽 阅读(302) 评论(0) 推荐(0)