简单梳理Java并发编程的重点知识

对于初学Java的人来说,类、对象、进程、线程、并发与串行等一系列概念很容易让人混淆。想要熟练掌握这些基础知识点,你需要有一个很好的逻辑思维以及条理清晰的分类。接下来我就给大家简单梳理并发编程相关知识。

想要学好Java并发编程,我们一定要了解一些基础概念:比如线程的概念,线程的优先级,线程的概念,启动和终止线程,线程间通信等等。接下来的我就以企业招聘面试为例,给大家简单梳理Java并发编程重点知识。
在这里插入图片描述

线程与进程的区别?

进程是操作系统分配资源的最小单元,线程是操作系统调度的最小单元。一个程序至少有一个进程,一个进程至少有一个线程。

什么是多线程中的上下文切换?

多线程会共同使用一组计算机上的CPU,而线程数大于给程序分配的CPU数量时,为了让各个线程都有执行的机会,就需要轮转使用CPU。不同的线程切换使用CPU发生的切换数据等就是上下文切换。

在Java中守护线程和本地线程区别?

Java中的线程分为两种:守护线程(Daemon)和用户线程(User)。任何线程都可以设置为守护线程和用户线程,通过方法Thread.setDaemon(bool on);true则把该线程设置为守护线程,反之则为用户线程。Thread.setDaemon()必须在Thread.start()之前调用,否则运行时会抛出异常。

两者的区别:
唯一的区别是判断虚拟机(JVM)何时离开,Daemon是为其他线程提供服务,如果全部的User Thread已经撤离,Daemon 没有可服务的线程,JVM撤离。也可以理解为守护线程是JVM自动创建的线程(但不一定),用户线程是程序创建的线程;比如JVM的垃圾回收线程是一个守护线程,当所有线程已经撤离,不再产生垃圾,守护线程自然就没事可干了,当垃圾回收线程是Java虚拟机上仅剩的线程时,Java虚拟机会自动离开。

死锁是什么?如何产生的?

死锁:是指两个或两个以上的进程(或线程)在执行过程中,因争夺资源而造成的一种互相等待的现象,若无外力作用,它们都将无法推进下去。

产生死锁的必要条件:

互斥条件:所谓互斥就是进程在某一时间内独占资源。
请求与保持条件:一个进程因请求资源而阻塞时,对已获得的资源保持不放。
不剥夺条件:进程已获得资源,在末使用完之前,不能强行剥夺。
循环等待条件:若干进程之间形成一种头尾相接的循环等待资源关系。

Java中用到的线程调度算法是什么?

采用时间片轮转的方式。可以设置线程的优先级,会映射到下层的系统上面的优先级上,如非特别需要,尽量不要用,防止线程饥饿。饥饿是一个或者多个线程因为种种原因无法获得所需要的资源,导致一直无法执行的状态。

为什么使用Executor框架?

Executor框架是一个根据一组执行策略调用,调度,执行和控制的异步任务的框架。使用Executor的原因有三:

1)每次执行任务创建线程 new Thread()比较消耗性能,创建一个线程是比较耗时、耗资源的。
2)调用 new Thread()创建的线程缺乏管理,被称为野线程,而且可以无限制的创建,线程之间的相互竞争会导致过多占用系统资源而导致系统瘫痪,还有线程之间的频繁交替也会消耗很多系统资源。
3)接使用new Thread() 启动的线程不利于扩展,比如定时执行、定期执行、定时定期执行、线程中断等都不便实现。

想要学好Java并发编程,你需要掌握很多基本概念,比如进程、线程、死锁、活锁、进程的优先级以及进程状态等等。而想要顺利通过企业面试,你还需要具备相应的实战经验。

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章