JAVA编程多线程面试常见知识点灵魂拷问(一)

1、对线程池的了解
ThreadPoolExcutor创建线程池,包含七个参数。七个参数分别是核心线程数、最大线程数、任务队列、等待时间、时间单位、线程工厂、拒绝策略。
任务加入线程池算法流程,若加入线程池的任务数小于核心线程数,则线程池继续创建线程。当任务持续增加,线程池的任务数大于核心线程数,则线程池会继续创建线程处理任务。
首先判断核心线程池是否已满,若没有线程池中线程数小于核心线程数,则增加任务,继续创建线程。若线程池中线程数已达到核心线程数,则将新增任务加入等待队列。
若等待队列已满,则新增线程数,直至达到最大线程数。若继续增加任务,则根据拒绝策略处理新增的任务。可以丢弃新增任务。
线程工厂一般写入线程名,用于日志定位。
平常用Executors工具类创建单个线程池、调度线程池等,主要存在两个问题。一是等待队列无线大(Int的最大值),容易挤压任务,造成内存溢出。二是创建线程无线大,也容易造成内存溢出。

2、线程的生命周期
线程的五种状态,包括创建、准备、运行、等待、死亡、阻塞。主要方法notify()、notifyall()、wait()、sleep()、run()等。
可通过实现Runnable接口或者继承Thread类,当然还可以继承Callable接口,这个接口可以返回异常信息。
通过线程池的submit方法,可以返回一个Future对象,可以获取线程执行结果。

3、对同步的了解
通过synchronized关键字实现同步。synchronized关键字具有原子性,能保证顺序执行,其余方法执行需要获取对应锁才能继续执行。
常见的是在方法上加synchronized,实现同步方法。其实在非静态方法上加synchronized,其实是对该实例的加锁。
若是对静态方法加synchronized,则是对该类加锁。也可以创建一个Object对象,作为锁。
synchronized可以作为同步方法,也可以作为同步代码块。经常会问到同步方法和同步代码块的区别。同步代码块是通过monitorEntry和monitorExit两个指令表示进入同步代码块和退出同步代码块。
而同步方法是通过ACC的标识位,代表进入同步方法。二者其实都是通过获取对象监视器的持有权限来执行代码。
Jdk1.6后,对底层同步进行了优化,增加了很多锁,提升了同步的处理效率。

4、volatile关键字的理解
volatile关键字的作用一是禁止指令重排,二是并发情况下数据的可见性。
并发的几个特点包括原子性、可见性、有序性。synchronized关键字满足三个特性,而volatile关键字只能满足有序性和可见性。
Java内存模型,多个线程有本地内存,再从本地内存推送到主内存。volatile关键字能保证多个线程之间变量的可见性或者说一致性。
指令重排是指JVM可以在处理命令的时候可能会调整指令执行顺序,进行优化处理。比如创建一个对象,包括三个步骤,一是开辟分配内存,二是初始化实例,三是指向实例的地址,三个步骤的顺序可能会有调整。

5、JAVA内存模型
平常创建的实例分配到堆,其实大致是分为堆内存和栈内存。
线程私有区域以后程序计数器、本地方法栈、虚拟机栈,线程共享区域包括方法区、堆。
方法区主要把控类加载信息、静态变量、常量等,堆则是实例存放的区域,所有创建的实例都会在这里分配内存。
程序计数器主要是保存方法运行的位置,也就是指令执行的情况。多线程环境下,线程之间会进行切换,当下一个线程得到Cpu的调度时,需要知道上次执行的情况。
本地方法栈则是一些其它语言实现的底层方法,虚拟机栈则是保存方法的变量等信息

6、AQS的了解
AbstractQueuedSynchronizer的缩写AQS,类在java.util.concurrent.locks包下面。
AQS的核心思想是多个线程请求共享资源,分配不到锁资源的线程进入队列,按顺序分配资源。常见应用场景包括信号量、CountDownLatch等。
信号量应用场景:线程池核心线程数100,同时请求共享资源,限制共享资源最大并发数为10。这个时候可以通过信号量控制并发数,通过获取锁加一,释放锁减一,来控制资源分配。
CountDownLatch应用场景:一般用于统计,比如多个任务线程计算各个产品信息,最后需要汇总,这个时候可以通过CountDownLatch来实现,可以阻塞主线程等待任务结束。

内容参考地址:多线程面试常见知识点灵魂拷问(一) - 歪枣网
http://blog.waizaowang.com/java/21.html

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 4
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 4
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值