Java并发编程的艺术-读书笔记
2017-10-23 23:19
399 查看
1.上下文切换为什么影响性能?
因为CPU切换前会保存上一个任务的状态,以便下次切换回这个任务时,可以再加载这个任务的状态2.多线程一定会比单线程快吗?
不一定,多线程在创建线程及CPU上下文切换时会有一定的开销。3.如何避免死锁?
1)避免一个线程同时获取多个锁Thread t1 = new Thread(new Runnable() { @Override public void run() { synchronized (A) { Thread.sleep(2000); synchronized (B) { System.out.println("1"); } } } });
2)尝试使用定时锁lock.tryLock(timeout)来替代使用内部锁机制
4.硬件和软件的资源限制
在并发编程时,程序的执行速度受限于计算机硬件资源或软件资源。例如服务器带宽为2Mb/s,某个资源的下载速度为1Mb/s,启动10个线程下载,下载速度不会变成10Mb/s。
对于有数据库操作时,如果SQL语句执行非常快,而线程的数量比数据库连接数要大很多,则某些线程会被阻塞,等待数据库连接。
5.synchronized关键字的使用
Java中的每一个对象都可以作为锁。1)对于普通同步方法,锁是当前实例对象
2)对于静态同步方法,锁是当前类的Class对象
3)对于同步方法块,锁是Synchronized括号里配置的对象
相关文章推荐
- Java并发编程的艺术-读书笔记
- Java并发编程艺术----读书笔记(二)
- Java并发编程的艺术读书笔记(1)-并发编程的挑战
- Java并发编程艺术----读书笔记(一)
- synchronized的实现原理-java并发编程的艺术读书笔记
- java并发编程的艺术读书笔记--Java内存模型(2)
- <java并发编程的艺术>读书笔记-第三章java内存模型(一)
- java并发编程的艺术-读书笔记-01
- JAVA并发编程实践--读书笔记
- Java并发编程艺术笔记之一二章
- Java并发编程的艺术(一)——并发编程需要注意的问题
- 【Java并发编程的艺术】【学习笔记】ThreadLocal与Fork/Join
- Java并发编程的艺术--笔记
- java并发编程实战 java并发编程的艺术 阅读随笔
- java并发编程的艺术第九章——java中的线程池
- 《Java Concurrency》读书笔记,Java并发编程实践基础
- java并发Fork/join框架-java并发编程的艺术
- Java并发编程的艺术笔记
- Java并发编程艺术 6 Java并发容器和框架
- Java 并发编程实践基础 读书笔记: 第三章 使用 JDK 并发包构建程序