`

多线程设计要点

    博客分类:
  • J2SE
阅读更多


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个,不能太多;
分享到:
评论

相关推荐

    多线程设计要点讲解 多线程设计要点讲解

    以下是对多线程设计要点的详细讲解: 1. **内存模型**:JVM内存分为主内存和工作内存。主内存存储所有线程共享的数据,而工作内存则为每个线程私有,用于存放线程的局部变量和副本。主内存位于堆区,工作内存则位于...

    Java多线程编程要点

    综上所述,Java多线程编程涵盖了线程的创建、执行和管理等多个层面,理解并熟练掌握这些要点对于编写高效并发程序至关重要。在实际开发中,还需要考虑线程安全、同步机制、死锁等问题,以确保程序的正确性和性能。

    VC++简单的多线程聊天程序课程设计

    #### 一、VC++与多线程聊天程序的设计 **1.1 背景介绍** 本课程设计项目旨在利用Visual C++(VC++)开发一个简单的多线程局域网聊天程序。随着互联网的发展,即时通讯软件如QQ、MSN等已经成为人们日常生活中的重要...

    华为编程大赛多线程编程要点.pdf

    【华为编程大赛多线程编程要点】 在编程竞赛中,多线程编程是一个重要的技能,尤其是在高并发和高性能计算的场景下。虽然题目没有明确提到多线程,但我们可以从编程大赛的角度出发,探讨一下多线程编程的相关知识点...

    win32.多线程程序设计(侯捷译)

    下面将详细阐述多线程编程的核心概念、技术要点以及其在Windows平台上的实现。 一、多线程概念 多线程是指在一个进程中同时运行多个独立的执行线程。每个线程都有自己的程序计数器、栈和局部变量,共享进程的内存...

    POSIX多线程程序设计中文版

    ### POSIX多线程程序设计知识点概述 #### 一、引言 《POSIX多线程程序设计中文版》是一本专注于介绍POSIX环境下多线程编程技术的专业书籍。该书内容丰富,覆盖了多线程的基本概念、核心原理以及实际应用技巧等多个...

    读书笔记:多线程程序设计23个要点

    以下是对标题和描述中提及的多线程程序设计要点的详细解释: 1. **内存模型**:Java的内存模型中,存在主内存和工作内存的概念。主内存存储所有线程共享的数据,而每个线程拥有自己的私有工作内存,用于存放线程...

    基于mongoose实现Http Server(多线程)

    本文将详细介绍如何使用mongoose库创建一个支持多线程的HTTP服务器,并探讨相关技术要点。 **mongoose库介绍** mongoose是一个轻量级的C语言库,用于构建嵌入式Web服务器。它具有易于使用的API,支持多种HTTP特性...

    详细剖析JAVA多线程案例教学

    本文将详细介绍Java多线程的基础知识、应用场景以及编程实践,旨在帮助初学者快速掌握多线程编程的核心概念和技术要点。 #### 二、Java多线程基础 ##### 1. 线程的概念 线程是程序执行流的最小单元,是操作系统能够...

    多线程断点续传软件的设计与实现

    ### 多线程断点续传软件的设计与实现 #### 1. 课题背景与意义 在当前互联网时代,下载软件已经成为人们日常生活中不可或缺的一部分。然而,早期的下载功能仅限于从WEB服务器上连续读取文件,一旦连接中断就需要...

    整理总结Java多线程程序编写的要点

    本文将详细讲解Java多线程程序编写的要点,包括线程的状态控制、优先级以及线程间通信。 首先,线程有五种基本状态:新建状态(New)、就绪状态(Runnable)、运行状态(Running)、阻塞状态(Blocked)和死亡状态...

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

    书中可能涵盖了所有英文版的要点,并用中文详细解释了如何在Symbian平台上进行高效的多线程编程。 6. **线程同步与通信**:在多线程环境中,线程同步是至关重要的,以确保数据的一致性和避免竞态条件。Symbian提供...

    基于多线程的网络爬虫设计与实现.pdf

    ### 基于多线程的网络爬虫设计与实现 #### 概述 网络爬虫作为一种高效的数据抓取工具,在大数据时代...通过本文的介绍,读者可以了解到基于多线程网络爬虫的设计思路和技术要点,为进一步的实际应用打下坚实的基础。

    多线程编程的资料(自己收集的)

    - **嵌入式Linux多线程编程**:专门针对嵌入式系统的特点介绍了多线程编程的技术要点,包括资源限制、实时性要求等。 通过上述知识点的总结,我们可以看出多线程编程在现代软件开发中的重要性。它不仅能够提高程序...

    多线程编程指南.pdf

    综上所述,《多线程编程指南》涵盖了从理论到实践的多线程编程各个方面的知识,旨在帮助开发者理解和掌握多线程编程的核心概念和技术要点,从而能够有效地设计和实现高性能的多线程应用程序。无论是初学者还是有一定...

    多线程使用原因以及例程

    ### 多线程使用原因及关键技术...特别是在Java中,合理使用`synchronized`关键字、`wait()`和`notify()`等机制可以帮助开发者设计出既安全又高效的多线程程序。希望本文的内容能够帮助读者更好地理解和应用多线程技术。

    玩转多线程编程.pptx

    多线程编程定式是指在多线程编程中的一些通用的设计模式,包括: * AnyObjectThread:一个通用的线程类,提供了线程的创建、管理和同步机制。 * ST2MO:一个基于状态机的多线程编程定式,提供了线程的创建、管理和...

Global site tag (gtag.js) - Google Analytics