美文网首页
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多线程的简要学习心得

    Java多线程的简要学习心得 概念理解 进程是计算机中已运行程序的实体。进程是线程的容器。运用多线程进行并发开发,...

  • 2018-07-23 Android 多线程编程

    前面我写过一篇文章简要介绍了一下Java多线程,今天来讲一下Android多线程,其实Android多线程和Jav...

  • 带你搞懂Java多线程(五)

    带你搞懂Java多线程(一)带你搞懂Java多线程(二)带你搞懂Java多线程(三)带你搞懂Java多线程(四) ...

  • 带你搞懂Java多线程(六)

    带你搞懂Java多线程(一)带你搞懂Java多线程(二)带你搞懂Java多线程(三)带你搞懂Java多线程(四)带...

  • Java多线程目录

    Java多线程目录 Java多线程1 线程基础Java多线程2 多个线程之间共享数据Java多线程3 原子性操作类...

  • 5月份第一周学习安排

    学习内容: java多线程及线程同步的方法(使用) java多线程各种同步方法的原理和优缺点 java多线程设计模...

  • android 多线程 — 线程的面试题和答案

    这里都是我从各个地方找来的资料,鸣谢: Java多线程干货系列—(一)Java多线程基础 JAVA多线程和并发基础...

  • 带你搞懂Java多线程(四)

    带你搞懂Java多线程(一)带你搞懂Java多线程(二)带你搞懂Java多线程(三) 什么是线程间的协作 线程之间...

  • java多线程--Callable

    **移步[java多线程系列文章]Java多线程(二十二)---LockSupport工具Java 停止线程 一、...

  • (五) volatile关键字

    Java多线程目录 1 背景 理解Java多线程的内存抽象逻辑请阅读java多线程内存模型,当代操作系统,处理器为...

网友评论

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

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