java面向对象程序设计教程(第二版)线程、输入﹨输出ppt

java面向对象程序设计教程(第二版)线程、输入﹨输出ppt

ID:36201826

大小:2.56 MB

页数:73页

时间:2019-05-07

java面向对象程序设计教程(第二版)线程、输入﹨输出ppt_第1页
java面向对象程序设计教程(第二版)线程、输入﹨输出ppt_第2页
java面向对象程序设计教程(第二版)线程、输入﹨输出ppt_第3页
java面向对象程序设计教程(第二版)线程、输入﹨输出ppt_第4页
java面向对象程序设计教程(第二版)线程、输入﹨输出ppt_第5页
资源描述:

《java面向对象程序设计教程(第二版)线程、输入﹨输出ppt》由会员上传分享,免费在线阅读,更多相关内容在教育资源-天天文库

1、第5章Java的线程2021/8/29Java面向对象程序设计教程2主要内容5.1线程的概念与POSIX标准5.1.1线程的概念5.1.2线程的POSIX标准5.2多线程的Java实现5.2.1线程的创建方法5.2.2线程的状态5.3互斥线程间的同步机制5.3.1多线程带来的冲突问题5.3.2共享资源合理使用的实现5.3.3按同步协调程度划分的线程间的关系5.4java.util.concurrent包简介5.1线程的概念与POSIX标准2021/8/29Java面向对象程序设计教程4线程的概念线程其实是

2、控制线程(Threadofcontrol)的简写。控制线程就是程序运行时的路径,是在一个程序中与其它控制线程无关的能够独立运行的代码片段。与线程有关的几个名词:进程与线程并发性与并行性异步与同步2021/8/29Java面向对象程序设计教程5基于进程的多任务处理环境进程是重量级的内核级实体,需要分配它们自己独立的地址空间:包括有虚拟内存映射、文件描述符、用户ID等,并且每个进程都有属于自己的这些集合。用户的程序要访问进程结构中的数据、查询或改变状态,唯一方法是通过系统调用。进程间通信和转换是昂贵和受限的。

3、2021/8/29Java面向对象程序设计教程6基于线程的多任务处理环境线程是轻量级实体,由寄存器、堆栈和某些数据组成。进程结构的其余部分由所有的线程所共享:如地址空间、文件描述符等——它们共享相同的地址空间并且共同分享同一个进程。线程间通信是便宜的,线程间的转换也是低成本的。2021/8/29Java面向对象程序设计教程7线程并发并发性(Concurrency)是两个或多个线程(或传统的进程)可以同时在执行代码之中;可以是相同的代码,也可以是不同的代码。这些线程可以一次执行,也可以多次执行,即一个已开始

4、执行但被中断,而另外一个已开始了。但在给定的时间点上,只有一个在CPU在处理一个线程。2021/8/29Java面向对象程序设计教程8线程并行并行性(Parallelism)是针对多处理器环境而言的,是指两个或多个线程真正同时运行在不同的CPU上。在多处理器机上,很多不同的线程可以并行运行,或者说是同时运行。2021/8/29Java面向对象程序设计教程9异步与同步异步世界需要处理同步业务有3个人在3个收银台前结帐3个人结帐是异步的每个人信用卡在银行业务处理时需保证同步2021/8/29Java面向对象程

5、序设计教程10线程的POSIX标准5.2多线程的Java实现2021/8/29Java面向对象程序设计教程12主线程通过调用Thread类的currentThread方法来查看主线程:Thread.currentThread()举例:MainThread.java2021/8/29Java面向对象程序设计教程13创建线程有两种方式通过直接扩展Thread类来直接创建线程:publicclassRacingThreadextendsThreadnewRacingThread(10,1000).start()

6、举例:RacingThread.java,AnimalWorld.java通过设计一个类,使之实现java.lang.Runnable接口,再把该接口作为参数传递给Thread类的构造方法后间接创建线程:publicclassRacingRunnableimplementsRunnablenewThread(newRacingRunnable(10,1000)).start()举例:RacingRunnable.java,AnimalWorld.java2021/8/29Java面向对象程序设计教程14采

7、用间接创建线程的原因第一个理由是我们并不改变线程本身的性质,仅覆盖run方法,并没有增加新的功能,因此将Thread扩展子类并不恰当,这不太符合类扩展规范。第二个理由是:如果实现Runnable接口,它可能使我们所设计的类扩展其它类型而变得更为有用。2021/8/29Java面向对象程序设计教程15start方法与run方法组合实现线程并发覆盖或实现run方法…start方法一般只用来触发线程,把线程的内容放在这个方法体中不太规范,而且这样做实际上线程不会竞争运行。如果直接调用run方法,线程也不会竞争运

8、行,必须通过start方法间接调用run方法。举例:ConcurrentUnavailable.java2021/8/29Java面向对象程序设计教程16Thread类一些方法使用的例子线程优先级:PriorityTest.java创建守护线程:DaemonTest.java线程列表:ThreadList.java线程组信息:ThreadGroupTest.java2021/8/29Java面向对象程序设计教程17线程的状态2

当前文档最多预览五页,下载文档查看全文

此文档下载收益归作者所有

当前文档最多预览五页,下载文档查看全文
温馨提示:
1. 部分包含数学公式或PPT动画的文件,查看预览时可能会显示错乱或异常,文件下载后无此问题,请放心下载。
2. 本文档由用户上传,版权归属用户,天天文库负责整理代发布。如果您对本文档版权有争议请及时联系客服。
3. 下载前请仔细阅读文档内容,确认文档内容符合您的需求后进行下载,若出现内容与标题不符可向本站投诉处理。
4. 下载文档时可能由于网络波动等原因无法下载或下载错误,付费完成后未能成功下载的用户请联系客服处理。