- 1、本文档共61页,可阅读全部内容。
- 2、有哪些信誉好的足球投注网站(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
- 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
查看更多
结束线程stop() 线程完成运行并结束后,将不能再运行。 除正常运行结束外,还可用其他方法控制使其停止。 用stop( )方法,已过时 强行终止线程,容易造成线程的不一致。 使用标志flag。 通过设置flag 指明run( )方法应该结束。 例7:结束线程的控制 11.4多线程的同步处理 多个线程在并发地运行时可能共用资源。 多个线程并发执行时,线程的相对执行顺序是不确定的; 多线程对共享数据操作时,这种线程运行顺序的不确定性将会产生执行结果的不确定性,使共享数据的一致性被破坏 多线程同步处理的目的是为了让多个线程协调地并发工作。 例8:由多个并发线程共享内存引发的问题:加减法失败 public class ThreadSum extends Thread{ public static int data=0; public static int times=10000; public int ID; public boolean done; ThreadSum(int id){ ID=id; } public void run( ){ done=false; int d= ((ID % 2==0) ? 1 : -1); System.out.println(运行线程: + ID + (增量为: + d + )); for(int i=0; itimes; i++) for(int j=0; jtimes; j++) data+=d; done=true; System.out.println(结束线程: + ID); } // 方法run结束 public static void main(String args[ ]){ ThreadSum t1 = new ThreadSum(1); ThreadSum t2 = new ThreadSum(2); t1.done=false; t2.done=false; t1.start( ); t2.start( ); // 等待两个线程运行结束 while ( !t1.done || !t2.done ) ; System.out.println(结果: data= + data); } } 加减法失败程序分析 每次运行的结果不一致。 main方法中创建了两个线程t1和t2,t1.done和t2.done是两个不同的变量,占用不同的内存空间,而data是t1和t2共享的内存数据。 线程t1对data增加times×times次,每次加1,而t2对data减小times×times次,每次减1。若t1加1的操作和t2减1的操作都正确完成,则data的结果值为0 但data的值不为0,是因为两个线程并发运行造成的,当出现两个线程同时要改变data值时,对data的值加1或减1的操作就有可能无法完成。 多线程同步的基本原理 多个并发线程之间共用资源,则需要进行同步处理 对象锁的概念 一个程序的各个并发线程中对同一个对象进行访问的代码段,成为临界区。 在java语言中,临界区可以是一个语句块或一个方法,并且用synchronized关键字标识。 临界区的控制是通过对象锁进行的。Java平台将每个由synchronized(someObject){ }语句指定的对象someObject设置一个锁,称为对象锁。 对象锁是一种独占的排它锁,即一个线程获取对象的锁后,便拥有该对象的操作权,其它任何线程不能对该对象进行任何操作。 同步方法和同步语句块 同步方法:用关键字synchronized 修饰方法 同步语句块的定义格式如下: synchronized (引用类型的表达式) 语句块 方法wait/notify/notifyAll 方法wait:在其他线程调用此对象的 notify() 方法或 notifyAll() 方法前,导致当前线程等待。 方法notify:唤醒在此对象监视器上等待的单个线程 方法notifyAll:唤醒在此对象监视器上等待的所有线程。 线程死锁的防治 如果程序中多个线程互相等待对方持有的锁,而在得到对方锁之前都不会释放自己的锁,则会导致这些线程不能继续运行,这就是死锁。 Java没有检测与避免死锁的专门机制,完
文档评论(0)