• 十万个为什么


    百度

    1. Synchronized和reentrantlock的底层实现及重入的底层原理。Monitorenter,monitorexit,AQS,重入原理:entry count,state
      https://cloud.tencent.com/developer/article/1465413
      https://tech.meituan.com/2019/12/05/aqs-theory-and-apply.html
    2. 锁的四种状态及升级过程
      https://www.cnblogs.com/mingyueyy/p/13054296.html
    3. CMS和G1的异同
      https://www.jianshu.com/p/ab54489f5d71
    4. G1什么时候引发Full GC
      https://tech.meituan.com/2016/09/23/g1.html
    5. 除了CAS,原子类,syn,lock还有什么线程安全的方式
    6. HashMap和Hashtable的异同
      https://www.cnblogs.com/williamjie/p/9099141.html
    7. 允许null键的map你知道哪些?HashMap,LinkedHashMap,WeakHashMap
    8. Null键放在HashMap的哪里?底层数组的0号位置
    9. 为什么Hashtable的扩容是2倍+1?从除留余数法,hashtable初始容量方面回答
    10. 红黑树的插入时间复杂度
      https://www.cnblogs.com/ysocean/p/8004211.html
    11. 解决哈希冲突的方式
      https://cloud.tencent.com/developer/article/1746968
    12. 现有1T的数据,内存只有1G,该怎么对他们排序?外部排序(多路归并)
    13. Tomcat为什么要重写类加载器
      https://blog.csdn.net/qq_38182963/article/details/78660779
    14. Tcp握手挥手过程及其状态转换
      https://zhuanlan.zhihu.com/p/114762902
    15. Mysql隔离级别
    16. B树和B+树的区别
      https://www.cnblogs.com/lianzhilei/p/11250589.html
    17. 你知道哪些设计模式,他们在jdk源码中是怎么体现的?
      https://blog.csdn.net/angjunqiang/article/details/42061453
    18. Java运行时数据区
    19. 说一个最熟悉的垃圾回收算法
    20. 吞吐量优先和响应时间优先的回收器是哪些?parallel scavenge和CMS
    21. 类加载全过程
      https://cloud.tencent.com/developer/article/1444580
    22. 线程池7个参数
      https://tech.meituan.com/2020/04/02/java-pooling-pratice-in-meituan.html
    23. CAS的ABA问题怎么解决?AtomicStampedReference,还可用带boolean版本戳的AtomicMarkabeReference
    24. Java内存模型。JMM共享内存模型以及8个原子操作指令
    25. 什么叫做阻塞队列的有解和无界?
    26. Cookie和session介绍一下
    27. 说一下反射,反射会影响性能吗?
    28. 谈一下AQS吧
    29. 为什么你说AQS的底层是CAS+volatile?state是volatile修饰的,并且设置state的方法除了有setState,还有compareAndSetState
    30. JUC包里的同步组件主要实现了AQS的哪些主要方法?
      TryAcquire,tryRelease,tryAcquireShared,tryReleaseShared,isHeldExclusively

    美团

    1. ConcurrentHashkMap底层原理
    2. 手写一个LRU。用LinkedHashMap
    3. HashMap底层数据结构
    4. 为什么用红黑树不用普通的AVL树
    5. 为什么在8的时候链表变成树
    6. 为什么在6的时候从树退回链表
    7. 线程池7个参数,该怎么配置最好
    8. 说一下valatile
    9. Volatile的可见性和禁止指令重排序怎么实现的
      可见性:缓存一致性协议
      禁止指令重排序:JMM模型里有8个指令完成数据的读写,通过其中load和store指令相互组合成的4个内存屏障实现禁止指令重排序
    10. CAS是什么
    11. Priorityqueue底层是什么,初始容量是多少,扩容方式呢
      最小堆,若原始大小<64,则扩容为原来的2倍,不然就扩容为原来的1.5倍
    12. HashMap的容量为什么要设置为2的次幂
    13. 你知道跳表吗?什么场景会用到?
      ConcurrentSkipListMap,用在多线程下需要自定义排序顺序时
    14. CopyOnwriteArrayList知道吗?迭代支持fail-fast吗?
      线程安全ArrayList,写时复制,迭代器是采用快照风格,不支持fail-fast
    15. Innodb的底层数据结构
    16. 为什么用B+树不用B树
    17. 为什么用B+树不用红黑树
    18. Coding:无序数组怎么寻找第k大的数,写一个二叉树层次遍历
    19. 不知道大小的数据流取其中100个数,怎样的取法能最随机?
    20. N个物品每个物品都有一定价值,分给2个人,怎么分两个人的价值差最小?
    21. 假设百度每个页面能放100个网页,每个网页都有一个评分,怎样快速找到第8页的所有网页

    顺丰

    1. 线程池的设计里体现了什么设计模式
    2. 说说你了解什么设计模式,知道责任链设计模式吗?
    3. Wait/notify体现了什么设计模式?
    4. 线程池7个参数
    5. 谈一下IOC底层原理
    6. 谈一下spring事务传播
    7. 怎么判断内存泄漏
    8. 怎么在日志里排查错误,该用哪些linux命令
    9. Mysql原子性和持久性怎么保证
      Undolog,redolog
    10. 怎么解决幻读
      Mvcc+间隙锁
    11. Innodb和myisam区别
    12. 索引分类
    13. 对象的创建过程
    14. 对象在内存中的存储布局
      对象头,类元指针,示例数据,对齐填充
    15. 对象头具体包括什么
    16. 对象怎么定位
      直接指针,句柄
    17. 堆的划分
    18. 对象怎么分配
      栈上分配->TLAB->老年代->新生代
    19. 具体讲一下CMS流程
    20. 锁的四种状态
    21. Object obj = new Object() 这句话里占用了多少内存
      引用变量4Byte,Object对象的对象头12Byte,由于对齐填充增至16Byte,共20Byte
    22. Synchronized和reentrantlock的异同

    京东

    1. 总体说一下集合框架
    2. 你怎么看待接口和抽象类
    3. 索引的分类
    4. 主键索引的设计应该采用B-tree索引还是hash索引
    5. 设计模式说5,6个
    6. 谈一谈DDD面向领域编程
    7. 说一下hibernate一级缓存和二级缓存
    8. 说一下你了解的MQ
    9. 谈一谈你对高并发的理解,你会从什么角度设计高并发程序
    10. JUC包里的限流该怎么做到
      Semaphore,guava ratelimiter
    11. 索引不适用的条件
    12. 说一下NIO和AIO
    13. AIO里用到什么设计模式
      观察者模式
    14. 说一下select,poll,epoll
    15. 谈一下TCP的拥塞控制
    16. 你知道什么是as-if-serial语义吗,他和happen-before语义有什么区别?
      本质没啥区别,前者是谈的单线程程序,后者是谈的多线程程序
    17. Executors创建线程池的方式
    18. CachedThreadPool里面用的什么阻塞队列
      SynchronousQueue
    19. 那你知道LinkedTransferQueue吗?和SynchronousQueue有什么区别?
    20. 你还知道什么阻塞队列,能具体说说他们的特点吗?
      ArrayBlockingQueue,LinkedBlockingQueue,LinkedBlockingDeque,PriorityBlockingQueue,DelayQueue
    21. 线程池的线程数怎么设置比较好?
    22. 你知道新出的LongAdder吗,和AtomicLong有什么区别?
      AtomicLong相当于多线程竞争一次修改value的机会
      LongAdder把value拆成多个值放在cell数组里,相当于多线程竞争多次修改value的机会,性能自然上升
    23. 那你知道LongAccumulator吗?
      不仅支持加法,还支持自定义的其他操作

    阿里

    1. 讲一个集合框架整体框架
      分Collection和Map两大类全部讲一遍,每一个接口和对应实现类,他们类各自的特点,性质,基本参数,能将多深讲多深
    2. ArrayList和HashSet的区别
    3. 为什么HashMap要在8的时候树化
      根据泊松分布概率
    4. HashMap线程安全的方式
      Hashtable和ConcurrentHashMap的各自特点,能讲多深多深
    5. 为什么Hashtable被弃用了,cch1.7之前和1.8之后的区别
    6. 锁的分类
      乐观锁,悲观锁,自旋锁,读写锁,排他锁,共享锁,分段锁等等各自特点,以及他们在java中的具体的实现方式
    7. Spring IOC的底层实现
      XML+dom4j+工厂+单例
    8. 索引不适用的条件
      索引列上有函数,不满足最左前缀,使用了不等号,使用了范围查询等等
    9. 索引的分类
      B-Tree索引,Hash索引,全文索引,单值索引,唯一索引,复合索引,聚簇索引,非聚簇索引等等,以及他们各自的特点
    10. 线程池了解多少
      Executors创建的几种线程池,直接new ThreadPoolExecutor,7个参数
    11. 线程池拒绝策略分别使用在什么场景
    12. Spring AOP的底层实现
      动态代理,newProxyInstance,cglib,ASM
    13. 讲一下代理模式
      动态代理,静态代理
    14. 你都了解什么设计模式,他们在jdk中如何体现的
      工厂,责任链,观察者,建造,代理,单例,原型等等在jdk中对应的体现
    15. 千万级数据量的list找一个数据(多线程),抢红包
    16. 讲一下JVM堆内存管理
      栈上分配->TLAB->新生代、老年代->可达性分析->GC算法->所有垃圾回收器机器优缺点和特点
    17. G1两个region不是连续的,而且之间还有可达的引用,我现在要回收其中一个,另一个会被怎么处理
    18. 听说过CMS的并发预处理和并发可终端预处理吗?
    19. 百万级int数据量的一个array求和(fork/join)
  • 相关阅读:
    echarts实现中国地图(部分省份版)
    Head First 设计模式——与设计模式相处
    Head First 设计模式-复合模式
    Head First 设计模式-状态、代理模式
    Head First 设计模式-模板方法、迭代器
    魔幻的一个月~
    Head First 设计模式-命令与适配器模式
    突然想写点什么……
    Head First 设计模式- 工厂与单件模式
    Head First 设计模式——观察者与装饰者模式
  • 原文地址:https://www.cnblogs.com/mgyboom/p/15302307.html
Copyright © 2020-2023  润新知