40个java多线程问题总结-java开发java经验技巧

40个java多线程问题总结-java开发java经验技巧

ID:30749594

大小:126.70 KB

页数:13页

时间:2019-01-03

40个java多线程问题总结-java开发java经验技巧_第1页
40个java多线程问题总结-java开发java经验技巧_第2页
40个java多线程问题总结-java开发java经验技巧_第3页
40个java多线程问题总结-java开发java经验技巧_第4页
40个java多线程问题总结-java开发java经验技巧_第5页
资源描述:

《40个java多线程问题总结-java开发java经验技巧》由会员上传分享,免费在线阅读,更多相关内容在工程资料-天天文库

1、40个Java多线程问题总结-编程开发技术40个Java多线程问题总结原文出处:五刀的仓颉Java多线程分类中写了21篇多线程的文章,21篇文章的内容很多,个人认为,学习,内容越多、越杂的知识,越需要进行深刻的总结,这样才能记忆深刻,将知识变成自己的。这篇文章主耍是对多线程的问题进行总结的,因此罗列了40个多线程的问题。这些多线程的问题,有些來源于各大网站、有些來源于门己的思考。可能有些问题网上冇、可能有些问题对应的答案也有、也可能冇些各位网友也都看过,但是本文写作的重心就是所有的问题都会按照自己的理解回答一遍,不会去看网上的答案,因此可能有些问题讲的不对,能指正的希望大家不吝指教。4

2、0个问题汇总1、多线程有什么用?一个可能在很多人看来很扯淡的一个问题:我会用多线程就好了,还管它有什么用?在我看來,这个回答更扯淡。所谓”知其然知其所以然”,”会用”只是”知其然”,”为什么用”才是”知其所以然”,只有达到”知其然知其所以然”的程度才可以说是把一个知识点运用自如。0K,下而说说我对这个问题的看法:(1)发挥多核CPU的优势随着工业的进步,现在的笔记木、台式机乃至商用的应用服务器至少也都是双核的,4核、8核甚至16核的也都不少见,如果是单线程的程序,那么在双核CPU上就浪费了50%,在4核CPU上就浪费了75%o单核CPU上所谓的”多线程”那是假的多线程,同一时间处理器只

3、会处理一段逻辑,只不过线程之间切换得比较快,看着像多个线程”同时”运行罢了。多核CPU上的多线程才是真止的多线程,它能讣你的多段逻辑同时工作,多线程,可以真正发挥出多核CPU的优势来,达到充分利用CPU的目的。(2)防止阻塞从程序运行效率的角度来看,单核CPU不但不会发挥出多线程的优势,反而会因为在单核CPU上运行多线程导致线程上下文的切换,而降低程序整休的效率。但是单核CPU我们述是要应用多线程,就是为了防止阻塞。试想,如果单核CPU使用单线程,那么只要这个线程阻塞了,比方说远程读取某个数据吧,对端迟迟未返回又没有设置超吋吋间,那么你的整个程序在数据返冋冋来之前就停止运行To多线程可

4、以防止这个问题,多条线程同时运行,哪怕一•条线程的代码执行读取数据阻塞,也不会影响其它任务的执行。(3)便于建模这是另外一个没有这么明显的优点了。假设有一个大的任务A,单线程编程,那么就要考虑很多,建立整个程序模型比较麻烦。但是如果把这个大的任务A分解成几个小任务,任务B、任务C、任务D,分别建立程序模型,并通过多线程分别运行这几个任务,那就简单很多了。2、创建线程的方式比较常见的一个问题了,一般就是两种:(1)继承Thread类(2)实现Runnable接口至于哪个好,不用说肯定是后者好,因为实现接口的方式比继承类的方式更灵活,也能减少程序之间的耦合度,面向接口编程也是设计模式6大原

5、则的核心。3、start()方法和run()方法的区别只有调用了start()方法,才会表现出多线程的特性,不同线程的nm()方法里面的代码交替执行。如果只是调用run()方法,那么代码还是同步执行的,必须等待一个线程的run()方法里而的代码全部执行完毕之后,另外一个线程才可以执行其rim()方法里面的代码。4、Runnab1e接口和Callable接口的区别有点深的问题了,也看出一个匕阳程序员学习知识的广度。Runnable接口屮的run()方法的返回值是void,它做的事情只是纯粹地去执行run()方法中的代码而已;Callable接口中的call()方法是有返冋值的,是一个泛型

6、,和Future>FutureTask配合可以用来获取异步执行的结果。这其实是很有用的一个特性,因为多线程相比单线程更难、更复杂的一个重要原因就是因为多线程充满着未知性,某条线程是否执行了?某条线程执行了多久?某条线程执行的时候我们期槊的数据是否已经赋值完毕?无法得知,我们能做的只是等待这条多线程的任务执行完毕而已。而Callable+Future/FutureTask却可以获取多线程运行的结果,可以在等待时间太长没获取到需要的数据的情况下取消该线程的任务,真的是非常有用。5、CyclicBarrier和CountDownLatch的区别两个看上去有点像的类,都在java.util,c

7、oncurrent下,都口J以用來表示代码运行到某个点上,二者的区别在于:(1)CyclicBarrier的某个线程运行到某个点上之后,该线程即停止运行,直到所有的线程都到达了这个点,所有线程才重新运行;CountDownLatch则不是,某线程运行到某个点上之后,只是给某个数值-1而已,该线程继续运行(2)CyclicBarrier只能唤起一个任务,CountDownLatch口J以唤起多个任务(3)CyclicBarrier可重用,Coun

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

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

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