大家好,今天小编关注到一个比较有意思的话题,就是关于java并发编程实战教程的问题,于是小编就整理了2个相关介绍Java并发编程实战教程的解答,让我们一起看看吧。
实际工作中,什么场景会用到多线程开发?
最典型的应用比如tomcat,tomcat内部***用的就是多线程,上百个客户端访问同一个web应用,tomcat接入后都是把后续的处理扔给一个新的线程来处理,这个新的线程最后调用到我们的servlet程序,比如doGet或者doPost方法。
如果不***用多线程机制,上百个人同时访问一个web应用的时候,tomcat就得排队串行处理了,那样客户端根本是无法忍受那种访问速度的。
还有就是需要异步处理的时候,需要使用多线程。比如taska和taskb要并行处理,单个线程只能串行处理,先做完taska然后再做taskb。如果想要多个task同时执行的话,就必须为每个task分配一个线程,然后通过j***a虚拟机的线程调度,来同时执行多个任务。比如你的CPU是多核心的话,就可以让一个CPU执行一个线程。如果只有一个CPU的话,底层是按照分时复用的原则,各个线程按照时间片来获得CPU***。
使用多线程是为了提高程序运行的效率。***如有一个程序,要求用户输入多个算式,计算出结果,并分别打印到屏幕上。如果用户一直没有输入,那么无法计算,更无法打印。如果用户输入了,必须要全部输入完,才能计算出结果,再打印到屏幕。
使用线程的话,一个线程用来等待用户输入,一个用来计算结果,一个用来打印。用户在输入算式3的时候,计算线程在计算算式2,打印线程在打印算式1,三个线程同时进行,减少了等待,这样就提高了运行效率
如何深入J***a多线程开发?
对于新手来说多线程无疑最难理解的部分,平常我们练习最多的就是输出一些参数,从db中增删改查操作一些数据,这些都是单线程所做的事情,如果遇到了大数据量的处理,IO密集型的任务以及高并发的处理,这时就得用到多线程。
常用的实现方式就是继承thread,或者实现Runnable接口,还有一种带有返回值的方式,即实现callable接口来实现多线程的处理。当然线程频繁的启动和关闭是很耗***的,于是就使用到了线程池。可以先学会使用j***a自带的四种线程池,然后理解线程池的原理,比如corePoolSize核心线程数,maxPoolSize最大线程数,线程拒绝策略等。
单核cpu同时只能运行一个线程,在j***a中的线程是随机执行的,内存中会有程序计数器记录线程执行到了哪里,由于线程的切换时间很短,肉眼看起来好像同时执行多个线程。所以单核cpu只能实现并发,而多核cpu才能使用多线程实现并行,充分利用cpu***。