恩士迅 java 三面
英文自我介绍
怎么保证线程顺序执行
只叫了个信号量,然后问我具体怎么做,我说忘记了。
【
1.创建三个线程ABC(new Thread(runnable实例),接口里面使用lambda表达式,放入一个重写的runnable实例 ,分别调用threadA.start(),threadA.join(),threadB.start(),threadB.join()threadC.start(),threadC.join()
2.使用并发包下的工具类,countDownLatch,创建两个countDownLatch实例countDownLatchAB,countDownLatchBC,都为1,线程A执行前不用检查,线程B检查countDownLatchAB为0则运行,线程B检查countDownLatchBC为0时运行,线程A结束减1,线程B结束减1。
3.使用并发包下的工具类Semaphore,创建两个Semaphore实例SemaphoreAB,SemaphoreBC,都为1,线程A执行前不用检查,线程B检查Semaphore为1则运行,线程B检查SemaphoreBC为1时运行,线程A结束减1,线程B结束减1。
方法二和方法三都是用到了操作系统里面的PV操作,使用信号量去控制。
】
讲下知道哪些集合
主要是通过单值,键值对;Set,List,Map;是否重复;底层结构;查询删除效率去讲。
linkedList 查找效率一定比 arrayList慢吗
一般情况下是,但是如果要查的元素在链表头也很快。
【arraylist底层是数组,是基于索引的查找,支持快速随机访问,时间复杂度O(1)
linkedList基于节点的查找,双向链表,要查找某个元素,需要从头开始遍历】
哪些集合安全哪些集合不安全
安全:vector,hashtable(效率慢) , cocurrentHashMap【使用锁分离技术减少锁的竞争】,CopyOnWriteArrayList【以后复制底层数组,并在写入时创建新副本的方式保证线程安全,使用于读都写少的场景】,ConcurrentLinkedQueue
不安全:ArrayList,LinkedList,HashSet,HashMap,TreeSet,TreeMap
有没有用过lambda表达式
在stream流里面,new Thread()方法里面都用到过
CI/CD用到了哪些工具
说了有两套,一套是代码提交平台gitlab,构建平台jerken,一套是阿里云的codeup和流水线flow。
mqtt有哪三个服务质量级别
说了三种,0:只发一次消息,不管是否有接收到 1:发送消息,保存在mqtt服务器,当超时未收到消息,重发,收到后,删除mqtt消息 ,可能会造成重发 2:保证只发一次且发生到位,最复杂,一般不用。
Caffine主要用来做什么
说了主要用来做本地缓存
怎么使用caffine和redis去做到缓存一致性的
将了整个设计,当有文章发生变更,先更改数据库,再发生文章变更标识。当B端在查的时候,先查本地缓存,如果有再看redis,如果redis也存在,比较caffine中的时间戳和redis中的时间戳,如果caffine小于redis的,说明版本落后,需要重新查数据库。
k8s用的过程中有遇到过什么问题
没怎么用过,但是确实是遇到过的。
【pod(最基本的可调度单元)部署失败,首先检查Pod的YAML文件是否有语法错误,然后使用kubectl logs查看日志,确定具体的原因。还有服务无法访问的问题,检查Service类型和端口配置,确保服务可以被正确暴露出来。总的来说,就是使用kubectl命令行工具来获取详细的诊断信息,并根据这些信息来调整配置或者排查问题】
前端学得怎么样
反问
怎么保证线程顺序执行
只叫了个信号量,然后问我具体怎么做,我说忘记了。
【
1.创建三个线程ABC(new Thread(runnable实例),接口里面使用lambda表达式,放入一个重写的runnable实例 ,分别调用threadA.start(),threadA.join(),threadB.start(),threadB.join()threadC.start(),threadC.join()
2.使用并发包下的工具类,countDownLatch,创建两个countDownLatch实例countDownLatchAB,countDownLatchBC,都为1,线程A执行前不用检查,线程B检查countDownLatchAB为0则运行,线程B检查countDownLatchBC为0时运行,线程A结束减1,线程B结束减1。
3.使用并发包下的工具类Semaphore,创建两个Semaphore实例SemaphoreAB,SemaphoreBC,都为1,线程A执行前不用检查,线程B检查Semaphore为1则运行,线程B检查SemaphoreBC为1时运行,线程A结束减1,线程B结束减1。
方法二和方法三都是用到了操作系统里面的PV操作,使用信号量去控制。
】
讲下知道哪些集合
主要是通过单值,键值对;Set,List,Map;是否重复;底层结构;查询删除效率去讲。
linkedList 查找效率一定比 arrayList慢吗
一般情况下是,但是如果要查的元素在链表头也很快。
【arraylist底层是数组,是基于索引的查找,支持快速随机访问,时间复杂度O(1)
linkedList基于节点的查找,双向链表,要查找某个元素,需要从头开始遍历】
哪些集合安全哪些集合不安全
安全:vector,hashtable(效率慢) , cocurrentHashMap【使用锁分离技术减少锁的竞争】,CopyOnWriteArrayList【以后复制底层数组,并在写入时创建新副本的方式保证线程安全,使用于读都写少的场景】,ConcurrentLinkedQueue
不安全:ArrayList,LinkedList,HashSet,HashMap,TreeSet,TreeMap
有没有用过lambda表达式
在stream流里面,new Thread()方法里面都用到过
CI/CD用到了哪些工具
说了有两套,一套是代码提交平台gitlab,构建平台jerken,一套是阿里云的codeup和流水线flow。
mqtt有哪三个服务质量级别
说了三种,0:只发一次消息,不管是否有接收到 1:发送消息,保存在mqtt服务器,当超时未收到消息,重发,收到后,删除mqtt消息 ,可能会造成重发 2:保证只发一次且发生到位,最复杂,一般不用。
Caffine主要用来做什么
说了主要用来做本地缓存
怎么使用caffine和redis去做到缓存一致性的
将了整个设计,当有文章发生变更,先更改数据库,再发生文章变更标识。当B端在查的时候,先查本地缓存,如果有再看redis,如果redis也存在,比较caffine中的时间戳和redis中的时间戳,如果caffine小于redis的,说明版本落后,需要重新查数据库。
k8s用的过程中有遇到过什么问题
没怎么用过,但是确实是遇到过的。
【pod(最基本的可调度单元)部署失败,首先检查Pod的YAML文件是否有语法错误,然后使用kubectl logs查看日志,确定具体的原因。还有服务无法访问的问题,检查Service类型和端口配置,确保服务可以被正确暴露出来。总的来说,就是使用kubectl命令行工具来获取详细的诊断信息,并根据这些信息来调整配置或者排查问题】
前端学得怎么样
反问
全部评论
过了吗
牛啊
三面是中文还是英文呢
相关推荐