`
yysct2005
  • 浏览: 87596 次
  • 性别: Icon_minigender_1
  • 来自: 深圳
社区版块
存档分类
最新评论

多线程设计要点

阅读更多

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

24. 推荐几篇相关英文文章:

Use Threading Tricks to Improve Programs

分享到:
评论

相关推荐

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

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

    多线程程序设计(文档)

    很有用的一个多线程程序文档,很详细讲述了多线程的操作和要点^_^

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

    读书笔记:多线程程序设计23个要点,非常受用!

    Java技巧:多线程程序设计二十三个要点

    本文介绍了Java的多线程程序设计的二十三个要点。

    多线程下载技术论文.rar

    5.1 系统设计要点 11 5.2 系统总体功能结构 12 5.3 开发环境:myeclipse SWT 15 5.4 URL类和URLConnection类的使用 15 6.系统实现 16 6.1用户界面实现 16 6.2 下载任务实现 20 6.2.1 下载任务类图 20 6.2.2 ...

    Windows程序设计实验五.doc

    解读并分析教材第三章3.5多线程文件搜索器的例子:03RapidFinder,了解和掌握多线程开发的要点和运行的方式,根据分析结果绘制出类图和流程图。 1、 将程序当中定义的所有类绘制对应的类图,并标注类之间的关系; 2...

    举例解析Java多线程编程中需要注意的一些关键点

    主要介绍了Java多线程编程中需要注意的一些关键点,包括ThreadLocal变量与原子更新等一些深层次的内容,需要的朋友可以参考下

    Java程序设计习题集下载

    第8章 多线程程序设计 第9章 编程规范 第10章 网络程序设计 第11章 多媒体与图形学程序设计 第12章 数据库程序设计 第二部分 参考答案 第1章 绪论 第2章 结构化程序设计 第3章 面向对象程序设计 第4章 数组、字符串...

    Linux多线程服务端编程:使用muduo C++网络库

    《Linux多线程服务端编程:使用muduo C++网络库》主要讲述采用现代C++在x86-64 Linux上编写多线程TCP网络服务程序的主流常规技术,重点讲解一种适应性较强的多线程服务器的编程模型,即one loop per thread。...

    JAVA程序设计习题集

    习题集内容覆盖面广,包括:Java言的基本常识、基本语法、面向对象的基本概念、数组、字符串、异常处理、文件和数据流、图形用户界面设计、小应用程序、线程、编程规范、网络程序设计、多媒体民图形学程序设计以及...

    Visual C++程序设计教程与上机指导(PDF)

    深入浅出地介绍了Visual C++编程技术的各个要点知识,首先介绍了Visual C++开发环境,并概要性地介绍了基于MFC的应用程序,然后以实例的形式对图形和文本输出、对话框和Windows标准控件、菜单、工具栏、状态栏、文档...

    Object-C语言教程&案例,要点难点,代码示例,代码解析

    Objective-C教程要点 基础语法:熟悉C语言基础是前提,Objective-C是在C语言的基础上增加了面向对象特性。 面向对象:理解类(Class)、对象(Object)、实例变量(Instance ...多线程与并发:了解GCD(Grand Central Dispa

    计算机毕业设计,课程设计,基于java电影院订票选座系统

    基于Java的电影院订票选座系统是一个实用且有挑战性的项目,适合作为计算机相关专业的毕业设计或课程设计。该系统旨在为影迷提供便捷的在线选座购票服务... - Java基础: 熟练掌握面向对象编程、集合框架、IO流、多线程等

    基于JAVA的网络通讯系统设计与实现源码+文全套

    内容概要:本文旨在介绍一个基于JAVA...技术要点:包括Socket连接的建立与维护、多线程编程、IO流的使用、数据传输协议的制定和实现等。 项目效果:具有良好的稳定性、可靠性和用户体验,能够满足基本的网络通讯需求。

    四川大学操作系统课程设计高分报告-第三次实验-生产者和消费者问题.doc

    四川大学操作系统课程设计高分报告-第三次实验-生产者和消费者问题.doc 都是自己非常认真完成的,每一个要点都实现到位,程序全部跑通且符合要求。 保证每题均正确。 最后得到的分数也很好(均为最高分)

    C#程序设计与课件案例教程

    全书共分九章,按C#知识的系统性,由浅入深安排内容,全面介绍了C#语言基础,面向对象程序设计,GUI程序设计,图形、图像与多媒体,数据库程序设计,流和文件,线程,网络程序设计以及ASP.NET。每部分内容既有示例又...

    华为内部java考题

    (2)多线程同步机制; (3)文件读写; (4)XML解析、基本的正则表达式; (5)类的加载和反射机制 (6)软件的需求分析以及逻辑思维能力; (7)软件设计(设计模式、类图)、编辑、编译、调测能力。

    Android讲义 高焕堂 (2)

    B02_JNI的多线程机制 B03_NDK与OpenGL 3D绘图框架 B04_介绍SDK-Service与核心服务 B05_实机演练_撰写第一个Core Service B06_远程服务的Proxy-Stub设计样式 B07_CS与AIDL_为甚么要继承ISensorService.Stub基类呢 B08...

Global site tag (gtag.js) - Google Analytics