网站首页
JSP空间
动态资讯
开源项目
技术文档
资源下载
J2EE资源
客户论坛
在线支付
 
  技术文档>>JAVA>>新手入门>>基础入门>查看文档  
  java编程中多线程设计要点全接触     
  文章作者:未知  文章来源:水木森林  
  查看:59次  录入:管理员--2007-11-17  
 
  1.多线程中有主内存和工作内存之分, 在jvm中,有一个主内存,专门负责所有线程共享数据;而每个线程都有他自己私有的工作内存, 主内存和工作内存分贝在jvm的stack区和heap区。
  
  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条的原因,我们解决办法是:
  
  class xxx extends thread{
  
  //i会被经常修改
  private int i;
  
  public synchronized int read(){ return i;}
  
  public synchronized void update(){ i = i + 1;}
  
  ..........
  
  }
  
  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运行性能差别很大。
 
 
上一篇: 实战体会java多线程编程的精要    下一篇: 在java程序中采用线程获取优异性能
  相关文档
常用java方法 11-17
java设计模式之 adapter(纠合不兼容的类) 11-17
servle和applet通信 11-17
javascript如何与applet通讯 11-17
java入门攻略之helloworld问题 11-17
如何设计出具有gui特色的纯java程序 11-17
[java100例]064、线程间通讯 11-17
hibernate自关联关系 11-17
构建wap应用程序开发环境 11-16
基础入门:java学习路径七步走 11-17
学编程的人不能不看的好文章(4) 11-17
通过实例学习java对象的构造过程 11-17
java接口的妙用 11-17
开天劈地:开发java程序的新武器 11-17
面向对象编程:java collection更有效管理elements 11-16
weblogic6.0安装及配置 11-17
java ide:eclipse3.1新特性及插件介绍 11-16
互连环境下实现oracle数据库分布式处理 11-17
decodeuri 方法 11-16
java推荐读物 11-17
返回首页 | 关于我们 | J网章程 | JSP空间合租 | 客服中心 | 免责声明 | 常见问题 | 参观机房
本站主机空间代理至厦门市华众网络科技有限公司
《中华人民共和国增值电信业务经营许可证》
编号:闽B2-20050079
@2005-2008福建JSP技术网 版权所有 闽ICP备05000928号
技术电话:13616026886
邮箱:admin@fjjsp.com 站长QQ,点击这里给我发消息