网站大量收购闲置独家精品文档,联系QQ:2885784924
  1. 1、本文档共27页,可阅读全部内容。
  2. 2、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
  3. 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  4. 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
查看更多
10_多线程剖析

10_多线程 讲师:胡琦光 本章概述 程序 进程 线程 java实现多线程 线程的状态和方法 线程基本信息和优先级 线程的同步和死锁问题 生产者消费者模式 任务调度 线程的概念 A 程序:Program,是一个静态的概念 进程:Process,是一个动态的概念 进程是程序的一次动态执行过程, 占用特定的地址空间. 每个进程都是独立的,由3部分组成cpu,data,code 缺点:内存的浪费,cpu的负担 线程:Thread,是进程中一个“单一的连续控制流程” (a single sequential flow of control)/执行路径 线程又被称为轻量级进程(lightweight process)。 Threads run at the same time, independently of one another 一个进程可拥有多个并行的(concurrent)线程 一个进程中的线程共享相同的内存单元/内存地址空间?可以访问相同的变量和对象,而且它们从同一堆中分配对象?通信、数据交换、同步操作 由于线程间的通信是在同一地址空间上进行的,所以不需要额外的通信机制,这就使得通信更简便而且信息传递的速度也更快。 线程和进程的区别 A 区别 进程 线程 根本区别 作为资源分配的单位 调度和执行的单位 开 销 每个进程都有独立的代码和数据空间(进程上下文),进程间的切换会有较大的开销。 线程可以看成时轻量级的进程,同一类线程共享代码和数据空间,每个线程有独立的运行栈和程序计数器(PC),线程切换的开销小。 所处环境 在操作系统中能同时运行多个任务(程序) 在同一应用程序中有多个顺序流同时执行 分配内存 系统在运行的时候会为每个进程分配不同的内存区域 除了CPU之外,不会为线程分配内存(线程所使用的资源是它所属的进程的资源),线程组只能共享资源 包含关系 没有线程的进程是可以被看作单线程的,如果一个进程内拥有多个线程,则执行过程不是一条线的,而是多条线(线程)共同完成的。 线程是进程的一部分,所以线程有的时候被称为是轻权进程或者轻量级进程。 JAVA中实现多线程(一) A 在Java中负责线程的这个功能的是Java.lang.Thread 这个类 可以通过创建 Thread 的实例来创建新的线程。 每个线程都是通过某个特定Thread对象所对应的方法run( )来完成其操作的,方法run( )称为线程体。 通过调用Thead类的start()方法来启动一个线程。 Thread 示例代码 A public class TestThread extends Thread { public void run() { for(int i=0;i100;i++){ System.out.println(this.getName()+:+i); } } public static void main(String[] args) { TestThread thread1 = new TestThread(); thread1.start(); TestThread thread2 = new TestThread(); thread2.start(); } } JAVA中实现多线程(二) A 继承Thread类方式的缺点:那就是如果我们的类已经从一个类继承(如小程序必须继承自 Applet 类),则无法再继承 Thread 类 通过Runnable接口实现多线程 优点:可以同时实现继承。实现Runnable接口方式要通用一些。 Runable 示例代码 A public class TestThread2 implements Runnable { public static void main(String[] args) { Thread thread1 = new Thread(new TestThread2(1)); thread1.start(); Thread thread2 = new Thread(new TestThread2(2)); thread2.start(); } public void run() { for(int i=0;i100;i++){ System.out.println(this.threadId+:+i); } } } 课堂练习(20分钟)A 1.使用 继承 创建线程 2.使用 接口 实现线程 线程状态 B 线程状态 B 新生状态: 用new关键字和Thread类或其子类建立一个线程对象后,该线程对象就处于新生状态。处于新生状态的线程有自己的内存空间,通过调用start方法进入就

文档评论(0)

jiayou10 + 关注
实名认证
内容提供者

该用户很懒,什么也没介绍

版权声明书
用户编号:8133070117000003

1亿VIP精品文档

相关文档