- 1、本文档共61页,可阅读全部内容。
- 2、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
- 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
查看更多
Java09_多线程程序设计.ppt
ReentrantLock ReentrantLock -- 可重入的锁 可重入锁指在同一个线程中,可以重入的锁。当然,当这个线程获得锁后,其他线程将等待这个锁被释放后,才可以获得这个锁。 构造器:ReentrantLock(boolean fair): 布尔值用来表示,创建的这个锁是公平的锁,还是自由竞争的锁。 所谓公平的锁,是指,各个希望获得所得线程获得锁的顺序是按到达的顺序获得,还是自由竞争获得 例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 (引用类型的表达式) 语句块 例子:见workspaces 方法wait/notify/notifyAll 方法wait:在其他线程调用此对象的 notify() 方法或 notifyAll() 方法前,导致当前线程等待。 方法notify:唤醒在此对象监视器上等待的单个线程 方法notifyAll:唤醒在此对象监视器上等待的所有线程。 线程死锁的防治 如果程序中
您可能关注的文档
- 起动机结构原理及常见故障分析.ppt
- 1公司法示范案例研究.ppt
- 服务机器人中嵌入式语音识别交互系统的研究[PPT课件].ppt
- 清华培训沟通全天20061121(课前).ppt
- 第三终端经典皇马战术.ppt
- 丝网印刷的基本方法PPT课件.ppt
- 第一次上机 熟习vc++.ppt
- 2013_脑卒中的康复治疗规范技术111.ppt
- 漂亮的ppt模版--清新的一天.ppt
- 全球四大通讯社 英文版.ppt
- 2025年卫星遥感技术在森林火灾预警中的应用报告.docx
- 自然语言处理技术2025年引领智能客服行业发展,问题解决与效率提升报告.docx
- 自然语言处理技术在智能客服中的应用效果评估与2025年改进报告.docx
- 2024-2025学年初中信息技术(信息科技)七年级下册滇人版(2016)教学设计合集.docx
- 康复工程智能化产品在康复治疗中的智能化升级路径规划报告.docx
- 共享办公空间2025年运营创新模式下的空间布局与设施配置策略.docx
- 行政法学知识的延伸与试题及答案.docx
- 2025年城市轨道交通站点周边交通组织变革的风险管理与对策报告.docx
- 虚拟现实(VR)设备在虚拟办公环境中的应用与市场潜力研究报告.docx
- 自然语言处理技术赋能智能客服2025年应用的创新模式与挑战分析.docx
文档评论(0)