`

Java 多线程程序设计要点(synchronized..)

    博客分类:
  • java
阅读更多

转的http://www.blogjava.net/site120/archive/2007/01/08/92492.html

Java 多线程程序设计要点(synchronized..)

也是一遍不错的文章
-----------------------------------------------------------------------------------------------------
                                                                                                                                               ----选择自 duoshanx 的 Blog

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多线程程序编写的要点,包括线程的状态控制、优先级以及线程间通信。 首先,线程有五种基本状态:新建状态(New)、就绪状态(Runnable)、运行状态(Running)、阻塞状态(Blocked)和死亡状态...

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

    Java多线程编程不仅可以显著提升程序的性能,还能让程序设计更加贴近现实世界的模型。然而,多线程编程也伴随着一系列挑战,如死锁、竞态条件等问题。因此,在实际开发中,开发者需要充分了解多线程的工作原理,并...

    java程序设计要点

    ### Java程序设计要点详解 Java作为一种广泛使用的编程语言,在软件开发、Web应用、移动应用以及大数据处理等领域都有着不可替代的地位。以下将从多个角度深入解析Java程序设计的关键要素,包括环境搭建、语法基础...

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

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

    java面试题_多线程(68题).zip

    这份“java面试题_多线程(68题).zip”压缩包很可能是包含了68个与Java多线程相关的面试问题和解答,帮助求职者准备相关面试。以下是一些可能包含在这些问题中的核心知识点: 1. **线程的创建**:Java提供了两种主要...

    java多线程抓取图片

    总之,Java多线程技术是构建高效爬虫的关键,通过合理的多线程设计,我们可以实现高效、稳定、可控的图片抓取。压缩包中的示例代码提供了实践学习的机会,通过研究这些示例,你将能够更好地理解和运用多线程爬虫技术...

    Java聊天室程序(java).rar

    综上所述,"Java聊天室程序"是一个全面的Java学习项目,它涵盖了网络通信、多线程、数据处理、用户界面设计等多个核心Java技术,对于Java初学者或准备进行毕业设计的学生来说,是一个很好的实践平台。通过这个项目,...

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

    Java的多线程程序设计是开发高效并发应用的关键技术之一,以下是对标题和描述中所述的二十三个要点的详细解释: 1. **主内存与工作内存**:Java的内存模型JMM(Java Memory Model)定义了主内存(Main Memory)和...

    Java多线程技术在网络通信系统中的应用.pdf

    总结来说,Java多线程技术在网络通信系统中的应用包括了线程间通信的原理、多线程实现网络通信的原理、线程安全及同步控制的有效途径,以及网络通信编程中的Socket类实现。掌握这些技术要点,对于进行高效、稳定、...

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

    理解并熟练运用这些多线程设计要点,有助于编写出高效、稳定的并发程序。在实际开发中,根据需求选择合适的同步策略,如使用Lock接口的实现类,或者使用并发工具类如Semaphore、CountDownLatch等,都可以提高并发...

    java知识要点总结.rar

    9. **Java多线程编程总结.pdf**:Java提供了丰富的多线程API,包括Thread类、Runnable接口和Executor框架。理解线程生命周期、线程安全和线程池的概念,有助于编写高性能并发程序。 10. **Java学习之抽象类的总结....

    Java程序设计环节考核指导.doc

    6. **多线程编程**:理解并能编写多线程程序,包括Thread类的使用、Runnable接口的实现、线程同步和通信机制(如synchronized关键字、wait()、notify())。 7. **数据库访问**:学生需要掌握如何使用Java JDBC API...

    java面向对象程序设计习题大全

    本书旨在通过一系列习题帮助学生深入理解Java面向对象程序设计的基本概念和技术要点。通过大量的练习题,不仅可以加深对Java基础知识的理解,还能培养解决问题的能力。此外,书中还涵盖了一些高级主题,如多线程、...

    java面向对象程序设计PPT教案

    面向对象编程(Object-Oriented Programming,简称...以上只是Java面向对象程序设计的部分要点,实际PPT教案中可能涵盖更详细的内容,包括实例演示、代码解析和练习题,帮助学习者逐步掌握面向对象编程的思想和技术。

    多线程使用原因以及例程

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

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

    Java多线程编程是Java开发中的一项重要技术,它允许程序同时执行多个任务,提高了系统效率和响应速度。然而,多线程环境下的编程也带来了一些挑战,如数据同步、线程安全等问题。本文将重点讨论Java多线程编程中需要...

    java语言学习六大要点

    此外,熟悉Java并发包(java.util.concurrent)中的工具类,能帮助简化多线程编程。 6. 了解网络编程: 虽然大多数开发者不会直接编写底层网络程序,但理解网络编程的基本原理,如TCP/IP协议、套接字(Socket)通信...

    多人聊天程序课程设计报告.docx

    该程序基于Java语言,利用Java提供的Socket类来构建客户端与服务器间的连接,并通过多线程技术实现多点对多点的聊天功能。 - **架构模式**:采用客户机/服务器(C/S)模式,其中服务器负责监控用户状态和消息转发,...

    JAVA语言程序设计期末题库

    这个“JAVA语言程序设计期末题库”显然旨在帮助学生准备期末考试,涵盖了一系列与Java编程相关的知识要点。下面将详细阐述Java语言的主要概念和关键知识点。 1. **基础语法**:Java语言的基础包括变量、数据类型...

Global site tag (gtag.js) - Google Analytics