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

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

  1. 88道BAT Java面试题 助你跳槽BAT,轻松应对面试官的灵魂拷问

    88道BAT Java面试题 助你跳槽BAT,轻松应对面试官的灵魂拷问 前言: 备战金九银十逃脱不了面试官的灵魂拷问,笔者整理了88道Java面试,由于面试题太多文章没有包含答案,需要领取这些面试题答 ...

  2. Java面试常见知识点总结

    目录 面试常见知识点 静态代码块 代码块 构造方法之间的顺序 interface和abstract的区别 abstract能不能继承interface 反正可不可以 interface 和abstra ...

  3. java并发多线程面试_Java多线程并发面试问答

    java并发多线程面试 Today we will go through Java Multithreading Interview Questions and Answers. We will al ...

  4. 整天都说注解注解注解,你们了解注解吗?来自——面试官的灵魂拷问

    注解 它可以用于创建文档,跟踪代码中的依赖性,甚至执行基本编译时检查.注解是以'@注解名'在代码中存在的,根据注解参数的个数,我们可以将注解分为:标记注解.单值注解.完整注解三类.它们都不会直接影响到 ...

  5. 京东深资架构师告诉你Java面试常见知识点(建议收藏)

    后端架构师 专注研究 Java 核心技术.架构,不限于分享算法.架构.高并发.多线程.JVM.Spring Boot.Maven.分布式.Spring Cloud +Docker+k8s.Dubbo. ...

  6. 34岁!100天!学会Java编程(Day12)——知识点串连

    知识点串连 前面开发项目时,主要依靠的是<手把手教你学Java>中零散的知识点,以及将<Java从入门到精通>当作开发词典来进行查询.晚上将后者从头到尾过一遍,对知识点进行查漏 ...

  7. Java个人技术知识点总结(业务场景篇,java高级多线程面试

    Kafka宕机引发的高可用问题 问题要从一次Kafka的宕机开始说起. 笔者所在的是一家金融科技公司,但公司内部并没有采用在金融支付领域更为流行的RabbitMQ,而是采用了设计之初就为日志处理而生的 ...

  8. (2.6w字)网络知识点灵魂拷问(下)——前端面试必问

    关注公众号"执鸢者",获取大量教学视频并进入专业交流群. 十一.HTTP协议(请求报文和响应报文) 11.1 请求报文 HTTP请求报文主要包括:请求行.请求头部以及请求的数据(实 ...

  9. 网络知识点灵魂拷问——前端面试必问

    一.当浏览器输入一个url请求会经历什么? 1.浏览器的地址栏输入URL并按下回车 2.DNS域名解析 (1)在浏览器DNS缓存中搜索 (2)如果浏览器缓存中没有,操作系统会先检查自己本地的hosts ...

最新文章

  1. 分类讨论 ---- 2020 icpc 上海 Walker (二分 or 思维分类讨论)
  2. 计算机有什么知识,计算机基础知识有什么
  3. Angular页面里元素class的动态绑定的实现源代码调试
  4. din算法 代码_深度兴趣网络(DIN,Deep Interest Network)
  5. 如何快速的学习html5,高效快速学习HTML5的技巧
  6. 飞鸽类能记住传书的人类
  7. 【Python-2.7】切片
  8. ISE_FIFO_IP核接口测试(一)
  9. gsm短信猫长短信pdu数据包分析[转]
  10. linux中下载迅雷链接
  11. c语言的算法必须要有输入输出,多选题: 1、计算机算法必须具备输入、输出和________等特性...
  12. 【历史上的今天】9 月 26 日:硅晶体管先驱出生;黑客盗取雅虎用户信息;“生物圈 2 号”实验室
  13. 云南企业私有云平台搭建解决方案、Zstack云平台管理软件介绍
  14. matlab获取2的整数次幂,如何快速判断正整数是2的N次幂
  15. 由frankmocap得到的.pkl文件转为.bvh或者.fbx
  16. jstat gc命令详解
  17. openpbs环境下GPU版NAMD的作业提交问题
  18. 1,10-Phen|邻菲啰啉|邻二氮杂菲|1,10-菲啰啉有机配体-66-71-7
  19. 佛罗里达计算机科学,佛罗里达大学计算机科学专业居然这么吃香?
  20. el-card实现菜单栏效果

热门文章

  1. (王道408考研数据结构)第五章树-第三节3:线索二叉树
  2. 七种寻址方式(寄存器相对寻址方式)
  3. Python for循环的用法,怎么前面还有一个变量或函数?
  4. Qt:Qt实现飞秋拦截助手—ARP攻击
  5. makefile 编译不同目录下的源文件
  6. N - Dragon Balls(并查集+深度的意义
  7. 从零搭建 vue-cli 脚手架
  8. 通讯录数据表设计v0.5
  9. ajax格式,需要指定交互的data类型
  10. 【转】WCF请求应答(Request-Reply)、单向操作(One-Way)、回调操作(Call Back)