java堆外内存泄露

本文介绍了在字节跳动面试中遇到的多线程相关问题,包括线程池线程数的确定、Redis的ZSet实现和红黑树的区别、Dubbo原理及踩过的坑。此外,文章讨论了Java堆外内存泄露,特别是ThreadLocal使用不当可能导致的内存泄漏问题。面试官着重于深入理解技术原理,强调研究技术背后的背景和应用场景的重要性。
摘要由CSDN通过智能技术生成

前言

很多同学面对多线程的问题都很头大,因为自己做项目很难用到,但是但凡高薪的职位面试都会问到。。毕竟现在大厂里用的都是多线程高并发,所以这块内容不吃透肯定是不行的。

今天这篇文章,作为多线程的基础篇,先来谈谈以下问题:

  1. 为什么要用多线程?
  2. 程序 vs 进程 vs 线程
  3. 创建线程的 4 种方式?

字节跳动

  • ⾯试前
  • ⼀⾯
  • ⼆⾯
  • ⼩结

凭借这些Java知识文档我收获了蚂蚁、拼多多、字节跳动Offer

⾯试前

头条的⾯试是三家⾥最专业的,每次⾯试前有专⻔的HR和你约时间,确定OK后再进⾏⾯试。每次都是通过视频⾯试,因为都是之前都是电话⾯或现场⾯,所以视频⾯试还是有点不⾃然。也有⼈觉得视频⾯试体验很赞,当然萝⼘⻘菜各有所爱。最坑的⼆⾯的时候对⽅⾯试官的⽹络⽼是掉线,最后很冤枉的挂了(当然有⼀些点答得不好也是原因之⼀)。所以还是有点遗憾的。

字节一面:

  • 先⾃我介绍下
  • 聊项目,逆向系统是什么意思
  • 聊项目,逆向系统用了哪些技术
  • 线程池的线程数怎么确定?
  • 如果是IO操作为主怎么确定?
  • 如果计算型操作⼜怎么确定?
  • Redis熟悉么,了解哪些数据结构?(说了zset) zset底层怎么实现的?(跳表)
  • 跳表的查询过程是怎么样的,查询和插⼊的时间复杂度?(说了先从第⼀层查找,不满⾜就下沉到第⼆层找,因为每⼀层都是有序的,写⼊和插⼊的时间复杂度都是O(logN))
  • 红⿊树了解么,时间复杂度?(说了是N叉平衡树,O(logN))
  • 既然两个数据结构时间复杂度都是O(logN),zset为什么不⽤红⿊树(跳表实现简单,踩坑成本低,红⿊树每次插⼊都要通过旋转以维持平衡,实现复杂)
  • 点了点头,说下Dubbo的原理?(说了服务注册与发布以及消费者调⽤的过程)踩过什
  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值