技术文章

如何深入Java多线程开发?

JAVA多线程技术太杂,随着了jdk版本的逐渐迭代,越来越多的多线程技术被提出来,原本的还没掌握又来了新的技术,但是万变不离其宗,下面来看下多线程主要涉及哪些东西?

1,何为多线程?在计算机系统中,CPU负责计算,而内存负责数据存储,线程就是操作系统用来进行运算调度的最小单位!显然,多线程就是多个调度单位!

2,为什么要使用多线程?

①,针对单核CPU,CPU在同一时间只能和一个线程进行交互,如果这个线程因为某些原因出现阻塞,那么整个计算机就处于停滞状态,为了避免这一现象,线程被设计为多线程执行模式,如果一个线程阻塞了,另外的线程可以继续使用执行计算,这样CPU使用效率就得到了极大的提升!

②,多核CPU:现在的计算机都被设计为多核的,能保证同一时间可以有多个运算单元,如果多核CPU却只使用单线程,无疑更是极大的浪费了CPU资源!

多线程的使用在很多场景中(批量处理,并行计算等)有着极高的效率,所以使用多线程无疑是很重要的!

Java多线程开发

3,JAVA中的多线程:JAVA中的线程与操作系统的线程不是一个概念虽然都有相似的几个线程状态(new,runnable,running,block,waiting,dead),JVM只是操作系统中的一个进程,JAVA的多线程只是属于jvm中的调度单元,具体关系常见如下解释:https://www.zhihu.com/question/23096638

唯一需要注意的是,JAVA中的多线程都是抢占式的,由jvm进行调度!

Java多线程开发

4,实现多线程的几种方式:①继承Thread,②实现Runnable接口,Callable接口,③使用线程池!

⑤,线程安全可使用技术:synchronize加锁,ReenTrantLock可冲入锁,ReadWriteLock读写锁,CAS原子命令(J.U.C下以Atomic打头的类基本用CAS实现)乐观锁,AQS抽象队列式同步器;

⑥,JDK中的并发容器:StringBuffer,Vector,SynchronizeMap,HashTable,concurrentHashmap(分段锁思想),ConcurrentLinkedQueue,CopyOnWriteArrayList(高效读取),ThreadLocal(一个线程,一份变量)

⑦,网络IO:BIO(同步阻塞IO),NIO(同步非阻塞),AIO(异步阻塞)

⑧,并行处理:callable+ future异步回调,forkjoin框架。

Java多线程开发

任何技术都是为业务服务的,具体用什么技术都还是需要看场景