第7章-线程

整理文档很辛苦,赏杯茶钱您下走!

免费阅读已结束,点击下载阅读编辑剩下 ...

阅读已结束,您可以下载文档离线阅读编辑

资源描述

1Java语言程序设计马皓mah@pku.edu.cn2线程概述线程的创建两种方式线程的同步1.synchronized2.wait()/notifyAll()/notify()线程的生命周期3概述进程(Process)程序(Program)的一次动态执行过程,占用特定的地址空间在某种程度上相互隔离的、独立运行的程序多任务(Multitasking)操作系统将CPU时间动态地划分给每个进程,操作系统同时执行多个进程,每个进程独立运行进程的查看Windows系统:Ctrl+Alt+DelUnix系统:psortop4概述线程(Thread)线程是进程中一个“单一的连续控制流程”(asinglesequentialflowofcontrol)/执行路径一个进程可拥有多个并行的(concurrent)线程一个进程中的线程共享相同的内存单元/内存地址空间可以访问相同的变量和对象,而且它们从同一堆中分配对象通信、数据交换、同步操作轻量级进程(lightweightprocess)5概述Java语言中的线程大多数现代的操作系统都支持线程第一个在语言本身中显性地包含线程的主流编程语言,它没有把线程化看作是底层操作系统的工具每个Java程序都至少有一个线程—主线程当一个Java程序启动时,JVM会创建主线程,并在该线程中调用程序的main()方法JVM还创建了其它线程,如垃圾收集(garbagecollection)6概述多线程(MultiThreading)语言java.lang.Thread类java.lang.Runnable接口为什么?(用途)Client/Server设计中的服务器端,如每个用户请求建立一个线程图形用户界面(GUI)的设计中提高事件响应的灵敏度从提高程序执行效率的考虑利用多处理器系统执行异步或后台处理等7初探线程publicclassSimpleThreadextendsThread{publicSimpleThread(Stringstr){super(str);}publicvoidrun(){for(inti=0;i8;i++){System.out.println(i++getName());try{sleep((long)(Math.random()*1000));}catch(InterruptedExceptione){}}System.out.println(DONE!+getName());}}概述publicclassTwoThreadsDemo{publicstaticvoidmain(String[]args){newSimpleThread(Jamaica).start();newSimpleThread(Fiji).start();}}运行结果:0Jamaica0Fiji1Jamaica1Fiji2Jamaica2Fiji3Jamaica4Jamaica5Jamaica3Fiji6Jamaica7Jamaica4FijiDONE!Jamaica5Fiji6Fiji7FijiDONE!Fijijava.lang.Threadpublicstaticvoidsleep(longmillis)throwsInterruptedExceptionCausesthecurrentlyexecutingthreadtosleep(temporarilyceaseexecution)forthespecifiednumberofmilliseconds.8线程概述线程的创建两种方式线程的同步1.synchronized2.wait()/notifyAll()/notify()线程的生命周期9线程创建的两种方式1.“SubclassingThreadandOverridingrun”继承java.lang.Thread类,重写run()方法2.“ImplementingtheRunnableInterface”实现java.lang.Runnable接口Runnable接口的唯一方法publicvoidrun()线程的创建10再探线程线程的创建publicclassTwoThreadsDemo{publicstaticvoidmain(String[]args){newSimpleThread1(Jamaica).start();newSimpleThread1(Fiji).start();}}publicclassSimpleThread2implementsRunnable{Stringname;publicSimpleThread2(Stringstr){name=str;}publicvoidrun(){for(inti=0;i8;i++){System.out.println(i++name);try{Thread.sleep((long)(Math.random()*1000));}catch(InterruptedExceptione){}}System.out.println(DONE!+name);}}publicclassSimpleThread1extendsThread{publicSimpleThread1(Stringstr){super(str);}publicvoidrun(){for(inti=0;i8;i++){System.out.println(i++getName());try{sleep((long)(Math.random()*1000));}catch(InterruptedExceptione){}}System.out.println(DONE!+getName());}}publicclassTwoThreadsDemo{publicstaticvoidmain(String[]args){SimpleThread2a=newSimpleThread2(Jamaica);Threadthread1=newThread(a);thread1.start();SimpleThread2b=newSimpleThread2(Fiji);Threadthread2=newThread(b);thread2.start();}}java.lang.ThreadpublicThread(Stringname)publicThread(Runnabletarget)publicfinalStringgetName()publicstaticvoidsleep(longmillis)throwsInterruptedException11线程创建的两种方式1.“SubclassingThreadandOverridingrun”继承Thread类,重写run()方法2.“ImplementingtheRunnableInterface”实现Runnable接口应用场合当所定义的类为一个子类时,须利用Runnable接口线程的创建12线程概述线程的创建两种方式线程的同步1.synchronized2.wait()/notifyAll()/notify()线程的生命周期13独立的(independent)、异步的(asynchronous)线程共享资源的访问多个线程对同一资源进行操作(读/写)当多个线程访问同一数据项(如静态字段、可全局访问对象的实例字段或共享集合)时,需要确保它们协调了对数据的访问,这样它们都可以看到数据的一致视图,而且相互不会干扰另一方的更改synchronized关键词wait()/notify()/notifyAll()方法线程的同步14线程同步-实例线程的同步publicclassCubbyHole{privateintcontents;publicintget(){returncontents;}publicvoidput(intvalue){contents=value;}}publicclassProducerextendsThread{privateCubbyHolecubbyhole;publicProducer(CubbyHolec){cubbyhole=c;}publicvoidrun(){for(inti=0;i10;i++){cubbyhole.put(i);System.out.println(Producer+put:+i);try{sleep((int)(Math.random()*100));}catch(InterruptedExceptione){}}}}publicclassConsumerextendsThread{privateCubbyHolecubbyhole;publicConsumer(CubbyHolec){cubbyhole=c;}publicvoidrun(){intvalue=0;for(inti=0;i10;i++){value=cubbyhole.get();System.out.println(Consumer“+got:+value);}}}publicclassProducerConsumerTest{publicstaticvoidmain(String[]args){CubbyHoleh=newCubbyHole();Producerp=newProducer(h);Consumerc=newConsumer(h);p.start();c.start();}}...Consumergot:3Producerput:4Producerput:5Consumergot:5......Producerput:4Consumergot:4Consumergot:4Producerput:5...151.给关键部分(CriticalSection)加锁(lock)CubbyHole对象synchronized关键词thetwothreadsmustnotsimultaneouslyaccesstheCubbyHole.TheJavaplatformthenassociatesalockwitheveryobjectthathassynchronizedcode线程的同步publicclassCubbyHole{privateintcontents;publicintget(){returncontents;}publicvoidput(intvalue){contents=value;}}publicclassCubbyHole{privateintcontents;publicsynchronizedintget(){returncontents;}publicsynchronizedvoidput(intvalue){contents=value;}}162.线程的协调thetwothreadsmustdosomesimplecoordination.Producer通过某种方式告诉Consumer在CubbyHole中有值,而Consumer必须通过某种方式表示出CubbyHole中的值已被取走CubbyHole对象(CriticalSection)java.lang.Object类的方法wait()、notify()、notifyAll()线程的同步17线程的同步publicclassCubbyHole{privateintcontents;publicintget(){returncontents;}publicvoidput(intvalue){contents=value;}}publicclassCubbyHole{privateintcontents;privatebooleanavailable=false;publicsynchronizedintget(){while(available==fal

1 / 22
下载文档,编辑使用

©2015-2020 m.777doc.com 三七文档.

备案号:鲁ICP备2024069028号-1 客服联系 QQ:2149211541

×
保存成功