美文网首页
Java多线程的简要学习心得

Java多线程的简要学习心得

作者: 茶九言 | 来源:发表于2018-01-28 13:23 被阅读27次

    Java多线程的简要学习心得

    概念理解

    进程是计算机中已运行程序的实体。进程是线程的容器。运用多线程进行并发开发,可以减小系统开销,降低资源共享和通信难度。

    线程是操作系统能够进行运算调度的最小单位。它被包含在进程之中,是进程中的实际运作单位。

    每个Java虚拟机都是一个进程,那么在虚拟机内部,并发编程只能依赖线程了。

    如果只是要把多核CPU利用起来做大量运算,如果机器4核CPU,单线程有点亏,那么需要有4个线程疯狂的消耗计算资源才能缩短时间。多线程还能解决主线程被阻塞的问题。

    Java线程的基础类

    基础类指上层能实现线程所需要调用API和需要实现的接口,他们被放在lang包下面。

    最最基础的是Thread、Runable、ThreadGroup,其它的都是扩展或附属。

    线程的创建

    在Java上无论用什么方法创建,最终都会映射到操作系统的线程创建上,只是Java内部还有一系列线程管理的方式,使虚拟机内部创建线程更好被管理。

    1、继承Thread。把自己交给虚拟机。

    2、实现Runable。最终还是要被封装成Thread。(线程池中是被work线程直接调用)

    3、实现Callable。这个其实是对runnable更高层次的封装,仅仅是为了拿个返回值,但需要和并发工具集一起使用才成。

    创建好之后,调用start()或者被线程池之类的工具集调用。线程就异步开跑了。

    线程中断

    Java中线程无法被其它线程中断,除非自己想结束或程序整体退出了,即使调用了interrupt()也也只是设置一个中端信号,决定权还是取决于线程自身。

    while true的每次循环可以主动判断,选择是否中断自己。

    耗时操作收到这个信号,会抛出中断异常,捕获到了也可以选择是否中断自己。

    链接:

    详细分析Java中断机制

    线程组

    管理线程的一个集合,持有线程的引用。

    在底层,可以直接让虚拟机统一设置线程组的优先级,是否deamon之类的。

    在上层,可以统一向管理的线程发送信号。比如interrupt()里,会for循环调用自己组里的所有线程的interrupt()方法。

    线程同步和通信

    同步是指我这个线程占有了这个实例的方法后,其它人就不能调用了。底层用同步监视器实现。

    通信指用对象的wait(), notify(), notifyAll()实现等待和调度。

    链接:

    深入理解Java并发之synchronized实现原理

    线程工具集

    线程本身的东西很少,为了让并发变成变得更简单,避免人们重复造轮子,api中的concurrent包为开发者提供了很多有用的工具集。线程池,各种同步锁,安全集合等。

    线程池

    基础类包括:ThreadPoolExecutor,Future,FutureTask,Callable。

    线程池是为了减小新建线程向系统申请资源的开销,对并发密集型应用带来的收益是非常客观的。

    具体原理是,线程池先一次性或动态申请足量的线程,这些线程都叫workThread,用户把自己的runnable交给线程池,保存在队里里,当workThread执行玩上一个任务,会取出队列中的runnable对象,直接调run()方法。

    线程池会把Callable和Runable都转换成RunnableFuture来执行,这样能用Future获取返回值。

    Executors有创建线程池的各种快捷方法。

    线程锁

    链接:

    Java锁----Lock实现原理

    相关文章

      网友评论

          本文标题:Java多线程的简要学习心得

          本文链接:https://www.haomeiwen.com/subject/pigaaxtx.html