`
zha_zi
  • 浏览: 594501 次
  • 性别: Icon_minigender_1
  • 来自: 西安
社区版块
存档分类
最新评论

多线程编程注意的23条

 
阅读更多

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运行性能差别很大。

分享到:
评论

相关推荐

    Linux下的多线程编程.pdf

    多线程编程的优点之二是线程之间方便的通信机制。不同的进程具有独立的数据空间,要进行数据的传递只能通过通信的方式进行,这种方式不仅费时而且很不方便。线程则不然,由同一进程下的线程之间共享数据空间,所以一...

    MFC多线程编程

    【MFC多线程编程】是Windows环境下使用Microsoft ...总结,MFC多线程编程使开发者能轻松地在Windows环境中实现并发处理,提升程序性能,但同时也需要注意线程管理、同步和资源竞争等问题,以确保程序的稳定性和效率。

    Delphi 多线程编程

    #### 四、Delphi多线程编程技巧与注意事项 - **线程优先级调整**:在某些情况下,可能需要调整线程的优先级以优化资源分配。可以通过`SetThreadPriority`函数来实现。 - **异常处理**:在多线程环境下,异常处理尤...

    Windows多线程编程技术与实例(C++)(PDF)

    这些API的使用方法和注意事项是多线程编程实践中的重要知识,书中会有具体的代码示例帮助理解。 在多线程编程中,线程同步是避免数据竞争和死锁的关键。本书深入浅出地介绍了各种同步机制,如临界区(Critical ...

    多线程编程指南.pdf

    ### 多线程编程指南:全面解析与应用 #### 多线程编程的定义与重要性 多线程编程是一种让程序能够同时执行多个任务的技术,通过在单一进程中创建多个线程来实现并发操作,从而提高了程序的效率和响应速度。这种...

    多线程编程(完整版)

    多线程编程是一种重要的软件开发技术,特别是在处理并发任务、优化资源利用率和提高程序响应速度方面。通过创建多个线程,程序可以在同一进程中并行执行不同的任务,从而提高整体效率。 在操作系统层面,进程和线程...

    多线程编程指南

    多线程编程是一种让多个代码路径在同一个程序中同时运行的技术,它允许多个执行流(线程)并发执行。在iOS开发中,多线程编程可以帮助开发者充分利用多核处理器的性能,提高应用程序的响应性和运行效率。然而,多...

    C#多线程编程实战完整源码

    C#多线程编程是开发高效、响应迅速的软件应用的关键技术之一,尤其在现代计算环境中,多核处理器和并发处理的需求日益增加。本资源"《C#多线程编程实战》完整源码"提供了丰富的实例,适用于学习和实践C#中的多线程...

    VC多线程编程

    #### 五、多线程编程注意事项 1. **线程安全**:确保共享资源访问的同步,避免数据竞争和死锁。 2. **资源管理**:正确处理线程生命周期中的资源分配和释放。 3. **性能考量**:频繁的线程切换可能会导致性能下降,...

    MFC多线程编程注意事项

    MFC多线程编程注意事项,很不错的资料。

    C# 多线程编程实例实战

    C# 多线程编程实例实战 本文探索了 C# 多线程编程实例实战,特别是单个写入程序/多个阅读程序的线程同步问题。在这种情况下,写入程序需要修改共享资源,而阅读程序需要读取数据。为了解决这个问题,需要满足两个...

    C# 多线程编程 详解

    ### C#多线程编程详解 #### 一、引言 在现代软件开发中,多线程编程是一项至关重要的技术,它能够显著提高程序的执行效率和响应速度。《C#多线程编程详解》一书由安德鲁·D·比瑞尔撰写,为读者提供了深入理解并...

    iOS 多线程编程指南 pdf

    RUNLOOP是多线程编程中的核心组件,文档第三章对其进行了详细的剖析。RUNLOOP模式、输入源等概念是理解RUNLOOP的基础。文档还详细说明了何时使用RUNLOOP,以及如何使用RUNLOOP对象,包括获得、配置以及启动RUNLOOP...

    linux下多线程编程

    Linux 下多线程编程 Linux 下的多线程编程遵循 POSIX 线程接口,称为 pthread。编写 Linux 下的多线程程序,需要使用头文件 pthread.h,...同时,也需要注意多线程编程的实际应用和 Debug 的难度,避免出现各种问题。

    多线程编程中英文对照.rar

    在IT领域,多线程编程是一项关键技能,尤其是在操作系统如Symbian中。多线程技术允许程序同时执行多个任务,提升系统效率和用户体验。以下是对"多线程编程"这个主题的详细解释: 1. **多线程概念**:多线程是指一个...

    多线程编程10例

    ### 多线程编程10例 #### 一、引言 在计算机科学领域,多线程编程是一种常见的技术手段,用于提高程序的执行效率和响应能力。通过本篇文章,我们将探讨多线程编程的基本概念及其在实际开发中的应用。 #### 二、...

    VC多线程编程概述.pdf

    然而,实现多线程编程的同时也需要注意到潜在的问题,如线程切换开销、资源竞争等问题,通过合理的同步机制可以有效地解决这些问题。因此,深入理解多线程编程的基本原理和技术细节对于开发高质量的软件至关重要。

    详细描述了Delphi多线程编程,超级简单易懂

    ### Delphi多线程编程详解 #### 一、Delphi多线程编程概述 多线程编程是现代软件开发中的关键技术之一,它能够显著提升应用程序的性能和用户体验。Delphi作为一种广泛使用的编程语言,提供了丰富的多线程支持,...

Global site tag (gtag.js) - Google Analytics