- 博客(2)
- 收藏
- 关注
原创 java常用类一百问
底层数据结构,分别是动态数组和双向链表。内存分配,数组是连续内存空间且需要指定大小。链表是非连续的,且链表空间占用更大。插入和删除元素,链表更快,只需改变链表元素指针。数组需要移动复制整个数组。随机查找,数组更快,支持索引下标查找。链表需要遍历查找。使用场景,数组适合存储大量数据且不需要频繁插入和删除。链表适合需要频繁插入和删除的数据。两者都是非线程安全的。
2022-03-04 16:15:52 412
原创 线程池一百问
当向线程池提交任务后,开始创建线程执行。ThreadPoolExecutor 创建的线程池,只有在阻塞队列占满后才会扩容线程数到最大,这在一些场景中是扩容不及时的,为此可以重写阻塞队列,让其插入元素后就返回队列满的假象,这样能触发立即扩容。通过继承 ThreadPoolExecutor,并重写 beforeExecute,afterExecute,terminated 方法,可以在任务执行前,任务执行后和线程池关闭前,加入特定的监控逻辑,如监控任务的平均执行时间,最大执行时间,和最小执行时间等。
2020-09-04 10:59:21 835
空空如也
空空如也
TA创建的收藏夹 TA关注的收藏夹
TA关注的人