`
pengtyao
  • 浏览: 401902 次
  • 性别: Icon_minigender_1
  • 来自: 北京
社区版块
存档分类
最新评论

开发知识整理----多线程(2011-05)

阅读更多
一.多线程


1.进程与线程的相同点与区别?

相同点:
(a)二者都具有ID,一组寄存器,状态,优先级以及所要遵循的调度策略。
(b) 每个进程都有一个进程控制块,线程也拥有一个线程控制块。
(c) 线程和子进程共享父进程中的资源;线程和子进程独立于它们的父进程,竞争使用处理器资源;线程和子进程的创建者可以在线程和子进程上实行某些控制,比如,创建者可以取消、挂起、继续和修改线程和子进程的优先级;线程和子进程可以改变其属性并创建新的资源。
不同点:
(a) 线程是进程的一部分, 一个没有线程的进程是可以被看作单线程的,如果一个进程内拥有多个进程,进程的执行过程不是一条线(线程)的,而是多条线(线程)共同完成的。
(b) 启动一个线程所花费的空间远远小于启动一个进程所花费的空间,而且,线程间彼此切换所需的时间也远远小于进程间切换所需要的时间。
(c)系统在运行的时候会为每个进程分配不同的内存区域,但是不会为线程分配内存(线程所使用的资源是它所属的进程的资源),线程组只能共享资源。对不同进程来说,它们具有独立的数据空间,要进行数据的传递只能通过通信的方式进行,这种方式不仅费时,而且很不方便。而一个线程的数据可以直接为其他线程所用,这不仅快捷,而且方便。
(d) 与进程的控制表PCB相似,线程也有自己的控制表TCB,但是TCB中所保存的线程状态比PCB表中少多了。
(e) 进程是系统所有资源分配时候的一个基本单位,拥有一个完整的虚拟空间地址,并不依赖线程而独立存在。

主要区别:每个进程都需要操作系统为其分配独立的内存地址空间,而同一进程中的所有线程在同一块地址空间中工作,共享同一块内存和系统资源,比如共享一个对象或者共享已经打开的一个文件。

2.创建线程的两种方式?

(a)扩展java.lang.Thread类:class ThreadA extends Thread

(b)实现java.lang.Runnable接口:class ThreadB implements Runnable

说明: Java不允许一个类继承多个类,因此一个类继承了Thread类后就不能再继承其它类了,所以Java提供了Runnable这一接口来解决这一问题,只要实现Runnable的run方法;Thread类也实现了Runnable接口。

3.线程的状态转换




4.线程调度

两种CPU使用权调度模型:
(a)分时调度模型(所有线程轮流获取cpu时间片)
(b)抢占式调度模型(按优先级高低)
注意:线程调度不是跨平台的,不仅取决于JVM,还依赖于操作系统。

程序明确让一个线程给另一个线程运行机会的做法:

(a)调整各个线程的优先级(setPriority())
(b)让处于运行状态的线程调用Thread.sleep()方法(出让cpu使用权,但是不会出让已占对象锁)。
(c)让处于运行状态的线程调用Thread.yield()方法。
(d)让处于运行状态的线程调用另一个线程的join()方法。

5.调整各个线程的优先级


(a)虽然Java提供10个优先级,但是它不能多数操作系统进行很好的映射。所以如果希望程序能移植至各个操作系统中,应该确保在设置线程的优先级时,使用Thread类三个静态变量来标识线程优先级:MAX_PRIORITY=10,MIN_PRIORITY=1,NORM_PRIORITY=5。这样才能保证在不同的操作系统中,对同样的优先级线程采用同样的调度方式。
(b)主线程默认优先级为Thread.NORM_PRIORITY。
(c)线程A创建线程B,那么线程B和A具有相同优先级。
(d)可以通过setPriority()方法设置线程优先级。

6.sleep()与yield()方法的异同?

相同:都是Thread类的静态方法,都会使当前处于运行状态的线程放弃CPU,把运行机会让给别的线程。
区别:
(a)sleep()方法会给其它线程运行机会,而不考虑其它线程的优先级,因此会给较低优先级线程一个运行的机会;yield()方法只会个相同优先级或更高优先级线程一个运行机会。
(b)当线程执行了sleep(long millis)方法后,将转到阻塞状态,当线程执行yield()后,将转到就绪状态。
(c)sleep()方法声明抛出InterruptedException异常,而yield()方法没有声明任何异常。
(d)sleep()方法具有更好的可移植性。不能依靠yield()方法来提高程序的并发性能。yield()一般只是用在调试程序时,实际应用中不推荐使用yield()。

7.线程同步


原子操作(atomic operation):
不会被线程调度机制打断的操作;这种操作一旦开始,就一直运行到结束,中间不会有任何context switch(切换到另一个线程)

线程同步特征:

所谓线程之间的保持同步,是指不同线程在执行同一个对象的同步代码块时,因为要获得这个对象的锁而相互牵制。
(a)如果一个同步代码块和非同步代码块同时操作共享资源,仍然会造成对共享资源的竞争。(因为当一个线程执行一个对象的同步代码块时,其它线程仍然可以执行对象的非同步代码块)
(b)每个对象都有唯一的一个同步锁。
(c)静态方法也可使用synchronized修饰符。
(d)当一个线程开始执行同步代码块时,并不意味必须以不中断方式运行。同步代码块中也可以执行sleep、yield方法,此时它们并没有释放锁,只是放弃CPU使用权。
(e)synchronized声明不会被继承。子类相应方法还想同步必须重新加上synchronized修饰。

8.同步与并发

    同步是解决共享资源竞争的有效手段,但是,多线程的同步与并发是一对此消彼长的矛盾。为了提高并发的性能,应该使同步代码块中包含尽可能少的操作,使得一个线程尽快的释放锁,减少其它线程等待锁的时间。或者同一个可变类中提供两种实现:单线程环境中使用异步实现,多线程环境中使用同步实现。

9.释放对象锁


以下情况持有锁的线程会释放锁:
(a)执行完同步代码块或同步方法;
(b)执行同步代码块或同步方法过程中遇到异常导致线程终止;
(c)执行同步代码块或同步方法过程中执行了锁所属对象的wait()方法,该线程释放锁,进入对象的等待池中。(执行Thread.sleep() 、Thread.yield()只会放弃CPU,不会释放锁)

10.死锁

导致死锁的主要原因:
(a)系统资源不足
(b)进程运行推进顺序不合适
(c)资源分配不当

死锁四个必要条件:
(a)互斥:一个资源只能同时被一个线程使用;
(b)请求与保持:一个进程请求资源而阻塞时,对已获资源不释放;
(c)不剥夺:进程已获资源,未使用完之前,不能强行进行剥夺;
(d)循环等待:若干进程之间形成一种首尾相接的循环等待资源关系;

11.线程通信

java.lang.Object类中提供两个用于线程通信的方法:
(a)wait():执行该方法的线程释放对象锁,JVM把该线程放到该对象的等待池中,等待其它线程将其再次唤醒;
(b)notify():执行该方法的线程唤醒在对象的等待池中等待的一个线程。JVM从对象的等待池中随机选择一个线程,把它转到对象的锁池中。
注意:对一个对象的wait()和notify()的调用,必须放在同步代码块中,并且同步代码块采用这个对象的锁。否则,虽然编译可以通过,但是运行时会抛出:IllegalMonitorStateExcpetion异常。

12.线程控制

Thread类中提供了一些线程控制方法:
(a)start():启动线程;
(b)stop():终止线程;
(c)suspend():暂停线程;
(d)resume():是暂停线程恢复运行;

其中stop()、suspend()、resume()由于可能导致以下危险而在JDK1.2中被废弃:
(a)容易导致死锁;
(b)一个线程强制中断或终止另一个线程,可能导致共享数据停留在不稳定的中间状态;

所有一般实际编程中,是在受控制的线程中定义一个标志变量,其它线程通过改变标志变量的值,达到控制线程暂停、恢复、自然终止的效果。

13ThreadLocal类

(a)ThreadLocal并不是一个Thread,而是Thread的局部变量,也许把它命名为ThreadLocalVariable更容易让人理解一些。
(b)当使用ThreadLocal维护变量时,ThreadLocal为每个使用该变量的线程提供独立的变量副本,所以每一个线程都可以独立地改变自己的副本,而不会影响其它线程所对应的副本。
(c)ThreadLocal实现的思路很简单:在ThreadLocal类中有一个Map,用于存储每一个线程的变量副本,Map中元素的键为线程对象,而值对应线程的变量副本。
(d)ThreadLocal是解决线程安全问题一个很好的思路,它通过为每个线程提供一个独立的变量副本解决了变量并发访问的冲突问题。在很多情况下,ThreadLocal比直接使用synchronized同步机制解决线程安全问题更简单,更方便,且结果程序拥有更高的并发性。
(e)概括起来说,对于多线程资源共享的问题,同步机制采用了“以时间换空间”的方式,而ThreadLocal采用了“以空间换时间”的方式。前者仅提供一份变量,让不同的线程排队访问,而后者为每一个线程都提供了一份变量,因此可以同时访问而互不影响。
  • 大小: 76.5 KB
分享到:
评论

相关推荐

    JAVA核心面试知识整理-最全.zip

    这份“JAVA核心面试知识整理-最全.zip”压缩包提供了全面的Java面试准备材料,涵盖了Java基础、Java虚拟机(JVM)、多线程并发以及算法和Java中间件等多个关键领域。 首先,让我们深入Java基础。这部分通常包括Java...

    JAVA核心面试知识整理-最全

    3. 线程同步:synchronized关键字、wait()、notify()、notifyAll()以及Lock接口和相关的实现类,防止多线程并发访问资源时产生数据不一致问题。 六、IO流 1. 流的概念:数据的输入输出通道,分为字节流...

    【推荐】JAVA核心面试知识整理-283页.pdf

    本部分将深入解析【推荐】JAVA核心面试知识整理-283页.pdf文档中的关键知识点,帮助你准备面试。 首先,我们关注JVM(Java虚拟机),它是Java程序运行的基础。JVM负责解释字节码并执行Java程序。理解JVM的工作原理...

    Java多线程和并发知识整理

    Java多线程和并发知识是Java开发中的重要组成部分,它涉及到如何高效地利用系统资源,尤其是在多核CPU环境下,合理地使用多线程可以显著提升应用程序的性能。 **1. 理论基础** 1.1 为什么需要多线程 多线程的引入...

    Android开发(个人整理01) 线程Demo源码

    以上内容是根据"Android开发(个人整理01) 线程Demo源码"所涉及的Android线程开发知识,这些知识点对于理解和优化Android应用程序的性能至关重要。在实际项目中,开发者应熟练掌握并灵活运用这些概念和技巧。

    C++桌面图标一百种玩法系列之三【整理-时钟】完整

    6. **多线程**:为了让时钟在后台持续更新时间而不影响用户界面的响应,开发者可能使用了多线程技术,将时间更新和界面刷新放在不同的线程中执行。 7. **事件处理**:为了响应用户的操作,如关闭或最小化窗口,...

    java核心知识点整理-已转换.docx

    以下是对标题为“Java核心知识点整理-已转换.docx”的文档中提及的一些关键概念的详细解释: 1. JVM(Java Virtual Machine) JVM是Java程序的执行引擎,它负责将字节码(.class文件)转换为机器码,使得Java具有...

    后端开发基础知识整理JAVA、JVM、操作系统、网络、设计模式、mysql、redis、多线程、spring、springboo

    ### 后端开发基础知识整理 本篇文档对后端开发中的关键知识点进行了全面而深入的梳理,涵盖了Java语言基础、JVM、操作系统、网络技术、数据库、缓存、多线程、Spring框架等方面的核心概念和技术要点。以下是针对...

    JAVA核心知识点整理-互联网各大厂面试大全

    1. **Java基础知识**:包括Java语法、面向对象特性(封装、继承、多态)、异常处理、集合框架(List、Set、Map)、IO流、多线程、网络编程等。这些是Java程序员的基础技能,面试中常会被问到。 2. **Spring框架**:...

    MAX整理-FIR0918-D2007.rar

    程序优化是软件开发中一个关键环节,它涉及到对现有程序的性能进行提升,这可能意味着改进算法效率、优化内存使用、实现多线程并行处理、改善图形渲染过程等。这些优化工作有助于提高软件运行的速度和稳定性,同时...

    java开发面试合集-自己整理

    - 多线程:理解线程的创建方式,掌握同步和互斥机制,如synchronized关键字和Lock接口。 - 反射:了解如何通过反射动态调用方法和访问字段。 3. **并发编程** - 线程池:理解ExecutorService和...

    Java基础知识学习--自己整理.zip

    这份“Java基础知识学习--自己整理.zip”压缩包显然是一个精心整理的Java初学者教程,包含了作者的学习笔记和心得,旨在帮助新手快速入门。下面将详细阐述Java的基础知识。 **一、Java简介** Java是由Sun ...

    Java多线程的其他知识_动力节点Java学院整理

    在实际开发中,理解并熟练掌握这些Java多线程知识对于编写高效、稳定且易于维护的并发代码至关重要。合理的线程管理和异常处理策略能够帮助开发者有效地处理并发环境中的错误和异常,确保程序的健壮性。此外,合理...

    易语言多线程框架图

    接下来,根据文件内容,可以整理出以下具体的多线程知识点: 1. 启动按钮:这可能指的是一种触发机制,通过按钮点击来启动多线程程序,开始任务的执行。 2. 信号量许可证:在易语言中创建信号量,作为控制多个线程...

    JAVA核心知识点整理-最新版本

    接下来,我们关注Java基础语法,包括类、对象、封装、继承、多态等面向对象概念,以及异常处理、集合框架、IO流、多线程、网络编程等基础知识。 微服务是现代软件架构的重要组成部分,Spring框架作为Java中的主流...

    java多线程相关资料整理

    Java多线程是Java开发中的重要组成部分,它允许程序同时执行多个任务,提高了系统的效率和响应性。在Java中,实现多线程有两种主要方式:继承Thread类和实现Runnable接口。下面将对Java多线程的相关知识点进行详细的...

    ios代码整理-gl

    11. **异步编程**:GCD(Grand Central Dispatch)和操作队列用于实现多线程和异步任务,提升应用性能。 12. **自动布局**:Auto Layout和Size Classes用于实现适应不同屏幕尺寸的布局。 13. **单元测试与持续集成...

    JAVA核心知识点整理,涵盖JAVA基础、集合类、JVM、IO/NIO、多线程、Spring原理等知识

    ### JAVA核心知识点整理 在Java开发领域中,掌握核心知识点对于提升个人技能及解决实际问题至关重要。本文将根据提供的文件信息,对JAVA基础、集合类、JVM、IO/NIO、多线程以及Spring框架的基本原理进行深入解析,...

    整理多线程面试必问源码知识点.docx

    在Java多线程编程中,`synchronized`关键字和`volatile`关键字是非常重要的概念,它们主要解决了并发环境下的数据同步和可见性问题。下面将详细解释这两个知识点。 ### 一、synchronized `synchronized`是Java中的...

    java+多线程+同步详解源码整理

    在Java编程语言中,多...综上所述,Java的多线程和同步是开发高效并发程序的关键,通过学习和实践,你将能够解决复杂并发场景下的问题,提升代码质量和性能。记住,深入理解源码和实际操作是掌握这些概念的最佳途径。

Global site tag (gtag.js) - Google Analytics