目录
hashcode:
set底层数据结构
单例手写(new class()是原子操作么)
>>> 和 >> 的区别?
垃圾收集器
mysql索引(没有实战,没有系统的学习整理记录)
自定义线程的各个参数的含义,以及可以指定的队列的多样性?
写一个栈溢出的代码:
画架构图:已经做过的项目
https://www.cnblogs.com/whgk/p/6071617.html
HashSet
Set底层结构:哈希表,由数组+链表+红黑树组成
no https://mp.weixin.qq.com/s/dU_Mzz76h-qQZvrgeSe44g
你可以看到:在考虑性能和安全中的饿汉式,会加锁对象实例:
synchnized(java3y.class)
查看命令;
java -XX:+PrintFlagsFinal
java -XX:+PrintCommandLineFlags -version
参考链接:
jdk垃圾收集器查看
官方的证明:
http://hg.openjdk.java.net/jdk8u/jdk8u/hotspot/rev/24cae3e4cbaa
https://bugs.openjdk.java.net/browse/JDK-6679764
https://docs.oracle.com/javase/8/docs/technotes/guides/vm/gctuning/collectors.html#sthref27
结论:
UseParallelGC 即 Parallel Scavenge + Parallel Old
参看结果:
默认的额innodb是b+树,不是b树,也不是红黑树(二叉树)
B+Tree组织的一个索引结构文件,聚集索引等
简单参考链接:
请参考:个人的mysql系列笔记
——————————————————————
队列简单分为有界和无界,无界的话,最大数量指定也是没有用的,那么怎么指定对应的队列和应用呢?
比如无界队列:
PriorityBlockingQueue
LinkedTransferQueue
DelayQueue
有界队列:
ArrayBlockingQueue
LinkedBlockingQueue
SynchronousQueue
LinkedBlockingDeque
具体提交一个任务,是创建线程执行,还是放在队列,还是实施拒绝,请看下图
递归没有出口(类似死循环)
建议:
mysql redis jvm 多线程等基础一定要好!