Java多线程设计要点
2.线程的状态有'Ready', 'Running', 'Sleeping', 'Blocked', 和 'Waiting'几个状态,'Ready' 表示线程正在等待CPU分配允许运行的时间。
3.线程运行次序并不是按照我们创建他们时的顺序来运行的,CPU处理线程的顺序是不确定的,如果需要确定,那么必须手工介入,使用setPriority()方法设置优先级。
4.我们无从知道一个线程什么时候运行,两个或多个线程在访问同一个资源时,需要synchronized
5. 每个线程会注册自己,实际某处存在着对它的引用,因此,垃圾回收机制对它就“束手无策”了。
6. Daemon线程区别一般线程之处是:主程序一旦结束,Daemon线程就会结束。
7. 一个对象中的所有synchronized方法都共享一把锁,这把锁能够防止多个方法对通用内存同时进行的写操作。synchronized static方法可在一个类范围内被相互间锁定起来。
8. 对于访问某个关键共享资源的所有方法,都必须把它们设为synchronized,否则就不能正常工作。
9. 假设已知一个方法不会造成冲突,最明智的方法是不要使用synchronized,能提高些性能。
10. 如果一个\"同步"方法修改了一个变量,而我们的方法要用到这个变量(可能是只读),最好将自己的这个方法也设为 synchronized。
11. synchronized不能继承, 父类的方法是synchronized,那么其子类重载方法中就不会继承“同步”。
12. 线程堵塞Blocked有几个原因造成:
(1)线程在等候一些IO操作
(2)线程试图调用另外一个对象的“同步”方法,但那个对象处于锁定状态,暂时无法使用。
13.原子型操作(atomic), 对原始型变量(primitive)的操作是原子型的atomic. 意味着这些操作是线程安全的, 但是大部分情况下,我们并不能正确使用,来看看 i = i + 1 , i是int型,属于原始型变量:
(1)从主内存中读取i值到本地内存.
(2)将值从本地内存装载到线程工作拷贝中.
(3)装载变量1.
(4)将i 加 1.
(5)将结果给变量i.
(6)将i保存到线程本地工作拷贝中.
(7)写回主内存.
注意原子型操作只限于第1步到第2步的读取以及第6到第7步的写, i的值还是可能被同时执行i=i+1的多线程中断打扰(在第4步)。
double 和long 变量是非原子型的(non-atomic)。数组是object 非原子型。
14. 由于13条的原因,我们解决办法是:
![](http://cms.it168.com/Images/OutliningIndicators/ExpandedBlockStart.gif)
![](http://cms.it168.com/Images/OutliningIndicators/ContractedBlock.gif)
![](http://cms.it168.com/Images/OutliningIndicators/InBlock.gif)
![](http://cms.it168.com/Images/OutliningIndicators/InBlock.gif)
![](http://cms.it168.com/Images/OutliningIndicators/InBlock.gif)
![](http://cms.it168.com/Images/OutliningIndicators/InBlock.gif)
![](http://cms.it168.com/Images/OutliningIndicators/ExpandedSubBlockStart.gif)
![](http://cms.it168.com/Images/OutliningIndicators/ContractedSubBlock.gif)
![](http://cms.it168.com/Images/OutliningIndicators/InBlock.gif)
![](http://cms.it168.com/Images/OutliningIndicators/ExpandedSubBlockStart.gif)
![](http://cms.it168.com/Images/OutliningIndicators/ContractedSubBlock.gif)
![](http://cms.it168.com/Images/OutliningIndicators/InBlock.gif)
![](http://cms.it168.com/Images/OutliningIndicators/InBlock.gif)
![](http://cms.it168.com/Images/OutliningIndicators/InBlock.gif)
![](http://cms.it168.com/Images/OutliningIndicators/ExpandedBlockEnd.gif)
15. Volatile变量, volatile变量表示保证它必须是与主内存保持一致,它实际是"变量的同步", 也就是说对于volatile变量的操作是原子型的,如用在long 或 double变量前。
16. 使用yield()会自动放弃CPU,有时比sleep更能提升性能。
17. sleep()和wait()的区别是:wait()方法被调用时会解除锁定,但是我们能使用它的地方只是在一个同步的方法或代码块内。
18. 通过制造缩小同步范围,尽可能的实现代码块同步,wait(毫秒数)可在指定的毫秒数可退出wait;对于wait()需要被notisfy()或notifyAll()踢醒。
19. 构造两个线程之间实时通信的方法分几步:
(1). 创建一个PipedWriter和一个PipedReader和它们之间的管道;
PipedReader in = new PipedReader(new PipedWriter())
(2). 在需要发送信息的线程开始之前,将外部的PipedWriter导向给其内部的Writer实例out
(3). 在需要接受信息的线程开始之前,将外部的PipedReader导向给其内部的Reader实例in
(4). 这样放入out的所有东西度可从in中提取出来。
20. synchronized带来的问题除性能有所下降外,最大的缺点是会带来死锁DeadLock,只有通过谨慎设计来防止死锁,其他毫无办法,这也是线程 难以驯服的一个原因。不要再使用stop() suspend() resume()和destory()方法
21. 在大量线程被堵塞时,最高优先级的线程先运行。但是不表示低级别线程不会运行,运行概率小而已。
22. 线程组的主要优点是:使用单个命令可完成对整个线程组的操作。很少需要用到线程组。
23. 从以下几个方面提升多线程的性能:
检查所有可能Block的地方,尽可能的多的使用sleep或yield()以及wait();
尽可能延长sleep(毫秒数)的时间;
运行的线程不用超过100个,不能太多;
不同平台linux或windows以及不同JVM运行性能差别很大。
转载于:https://www.cnblogs.com/licheng/archive/2008/07/05/1236717.html
Java多线程设计要点相关推荐
- java多线程设计wait、notify、notifyall、synchronized的使用机制
wait.notify.notifyall.synchronized的使用机制: synchronized(obj) { while(!condition) { obj.wait(); } obj.d ...
- java多线程实现电梯_面对对象第二单元总结 - 电梯(java多线程)
概述 刚刚过去的oo第二单元主要是来训练我们java多线程设计. 借助电梯这个载体,逐步深入,线程的信息交互,控制也随之复杂. 尽管,我本单元成绩不是很好看,但是,确实学到了不少东西. 下面,我就借助 ...
- 利用java多线程技术和图像显示技术来完成动画设计。
利用java多线程技术和图像显示技术来完成动画设计. package p2;import java.applet.Applet; import java.awt.Graphics; import ja ...
- 基于Java多线程的打怪升级类游戏设计与开发
摘要:本文论述了通过JAVA多线程.基于JAVA Swing的GUI图形用户界面设计.IO输入输出流.JDBC技术,实现了游戏系统的UI设计.游戏数据的存储.关卡的设置.用户头像的上传与更改.游戏数据 ...
- Java多线程编程实战:模拟大量数据同步
背景 最近对于 Java 多线程做了一段时间的学习,笔者一直认为,学习东西就是要应用到实际的业务需求中的.否则要么无法深入理解,要么硬生生地套用技术只是达到炫技的效果. 不过笔者仍旧认为自己对于多线程 ...
- Java多线课程,java多线程课程.doc
java多线程课程.doc 还剩 9页未读, 继续阅读 下载文档到电脑,马上远离加班熬夜! 亲,喜欢就下载吧,价低环保! 内容要点: 如下:线程 A:休眠 10s线程 B:休眠 20s线程 C: 休眠 ...
- 面向 CPython GIL 的多线程编程要点
目录 文章目录 目录 Python GIL Python GIL 对线程并发性能的影响 保留 GIL 的历史原因 为了兼顾解释型语言的简单 为了兼顾 C 程序库的安全 Python 的多线程编程要点 ...
- Java多线程:线程间通信之Lock
Java 5 之后,Java在内置关键字sychronized的基础上又增加了一个新的处理锁的方式,Lock类. 由于在Java线程间通信:volatile与sychronized中,我们已经详细的了 ...
- SOFA BOLT源码解析之设计要点-线程模型
1 设计要点解析 1.1 线程模型 此部分内容主要介绍蚂蚁为什么选择Netty4作为基础网络编程框架,来源于蚂蚁技术团队发布的一篇文章: 文章名称为:蚂蚁通信框架实践: 链接地址为:https:// ...
最新文章
- slf4j 日志监控
- UVA679 小球下落 Dropping Balls(二叉树的编号)
- LeetCode Intersection of Two Arrays
- Intel GPU及NVIDIA GPU对视频编解码支持情况
- TypeError: 'module' object is not callable 原因分析(python模块导入注意事项)
- 日常生活小技巧 -- 网络调试助手
- 管能做暖气管道吗_这样的暖气管道施工,标准吗
- 企业的核心竞争力是什么
- EDA鸿蒙是不是,如果华为不强研鸿蒙,和阿里合作,新系统或早用到手机上了? - 区块网...
- 学flash就丢人吗?
- Linux 服务器性能出问题,排查下这些参数指标
- 教你win7关闭开机动画,大幅度加快开机时间
- AMPL Matlab 自动求导(AD)求解雅克比、海森矩阵
- Loading 加载中 图片素材
- 完美解决“运行引擎需要DX11特性等级10.0”
- java word jar包_处理word的poi的jar包
- 服务器 dell 重装 win7系统,戴尔笔记本重装系统
- 去除图片上的文字出现马赛克?
- STM32控制0.96寸OLED(4针/4Pin)汉字以及数字,英文显示
- [Jetson TX2] NVIDIA Jetson TX2 参数介绍