记录一次面试(国美Java)的知识点死角(2):

目录

hashcode:

set底层数据结构

单例手写(new class()是原子操作么)

>>>  和 >> 的区别?

垃圾收集器

mysql索引(没有实战,没有系统的学习整理记录)

自定义线程的各个参数的含义,以及可以指定的队列的多样性?

写一个栈溢出的代码:

画架构图:已经做过的项目


hashcode:

        https://www.cnblogs.com/whgk/p/6071617.html

set底层数据结构

HashSet

Set底层结构:哈希表,由数组+链表+红黑树组成

单例手写(new class()是原子操作么)

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

参看结果:

mysql索引(没有实战,没有系统的学习整理记录)

默认的额innodb是b+树,不是b树,也不是红黑树(二叉树)

B+Tree组织的一个索引结构文件,聚集索引等

简单参考链接:

请参考:个人的mysql系列笔记

——————————————————————

        mysql底层索引

自定义线程的各个参数的含义,以及可以指定的队列的多样性?

队列简单分为有界和无界,无界的话,最大数量指定也是没有用的,那么怎么指定对应的队列和应用呢?

比如无界队列:

PriorityBlockingQueue

LinkedTransferQueue

DelayQueue

有界队列:

ArrayBlockingQueue

LinkedBlockingQueue

SynchronousQueue

LinkedBlockingDeque

具体提交一个任务,是创建线程执行,还是放在队列,还是实施拒绝,请看下图

multi-thread证明的系列的代码逻辑:

 

写一个栈溢出的代码:

        递归没有出口(类似死循环)

画架构图:已经做过的项目

建议:

mysql redis jvm 多线程等基础一定要好!

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

specialApe

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值