- 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
- 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
- 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
- 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们。
- 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
- 7、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
Java语言程序设计 马 皓 mah@pku.edu.cn 第七章 线程 概述 线程的创建 两种方式 线程的同步 synchronized wait()/notifyAll()/notify() 线程的生命周期 概述 进程(Process) 程序(Program)的一次动态执行过程, 占用特定的地址空间 在某种程度上相互隔离的、独立运行的程序 多任务(Multitasking)操作系统?将CPU时间动态地划分给每个进程,操作系统同时执行多个进程,每个进程独立运行 进程的查看 Windows系统: Ctrl+Alt+Del Unix系统: ps or top 概述 线程(Thread) 线程是进程中一个“单一的连续控制流程” (a single sequential flow of control)/执行路径 一个进程可拥有多个并行的(concurrent)线程 一个进程中的线程共享相同的内存单元/内存地址空间?可以访问相同的变量和对象,而且它们从同一堆中分配对象?通信、数据交换、同步操作 轻量级进程(lightweight process) 概述 Java语言中的线程 大多数现代的操作系统都支持线程 第一个在语言本身中显性地包含线程的主流编程语言,它没有把线程化看作是底层操作系统的工具 每个 Java 程序都至少有一个线程—主线程 当一个 Java 程序启动时,JVM 会创建主线程,并在该线程中调用程序的main()方法 JVM还创建了其它线程,如垃圾收集(garbage collection) 概述 多线程(MultiThreading)语言 java.lang.Thread类 java.lang.Runnable接口 为什么? (用途) Client/Server设计中的服务器端, 如每个用户请求建立一个线程 图形用户界面(GUI)的设计中提高事件响应的灵敏度 从提高程序执行效率的考虑 利用多处理器系统 执行异步或后台处理等 概述 初探线程 第七章 线程 概述 线程的创建 两种方式 线程的同步 synchronized wait()/notifyAll()/notify() 线程的生命周期 线程的创建 线程创建的两种方式 “Subclassing Thread and Overriding run” ?继承java.lang.Thread类, 重写run()方法 “Implementing the Runnable Interface” ?实现java.lang.Runnable接口 Runnable接口的唯一方法 public void run() 线程的创建 再探线程 线程的创建 线程创建的两种方式 “Subclassing Thread and Overriding run” ?继承Thread类, 重写run()方法 “Implementing the Runnable Interface” ?实现Runnable接口 应用场合 当所定义的类为一个子类时,须利用Runnable接口 第七章 线程 概述 线程的创建 两种方式 线程的同步 synchronized wait()/notifyAll()/notify() 线程的生命周期 线程的同步 独立的(independent)、异步的(asynchronous) 线程 共享资源的访问 多个线程对同一资源进行操作(读/写) 当多个线程访问同一数据项(如静态字段、可全局访问对象的实例字段或共享集合)时,需要确保它们协调了对数据的访问,这样它们都可以看到数据的一致视图,而且相互不会干扰另一方的更改 synchronized 关键词 wait() / notify() / notifyAll() 方法 线程的同步 线程同步-实例 线程的同步 给关键部分(Critical Section)加锁(lock) CubbyHole对象 synchronized 关键词?the two threads must not simultaneously access the CubbyHole. The Java platform then associates a lock with every object that has synchronized code 线程的同步 线程的协调 the two threads must do some simple coordination. Producer通过某种方式告诉Consumer在CubbyHole中有值,而 Consumer必须通过某种方式表示出CubbyHole中的值已被取走 CubbyHole对象 (Critical Section) java.lang.Object类的方法 wait()、notify()、no
原创力文档


文档评论(0)