1. 分布式主键ID的生成方式有哪几种,其中雪花算法的组成部分有哪些?
UUID:简单,不会出现重复但是太长,不能排序;
Reids: incr,Redis是单线程,不会产生线程安全问题,Redis基于内存,性能比较高但是不稳定可能会出现重复ID;
雪花算法:
雪花算法共64位,其中包含符号位1,时间戳41,机房号5+机器号5(最大1024),序列号12(每毫秒最多4096)
2. SpringBoot如何实现异步操作?
基于多线程的:@EnableAsync+@Async
基于MQ的实现
3. 创建线程有哪几种方式及runable和callable的区别?
继承Thread类
实现Runnable接口
实现Callable接口
使用线程池创建
实现Runnable接口和Callable接口都能解决扩展性的问题,区别是Runnable,run方法没有返回值,不能抛出异常,Callable,call方法,可以有返回值,可以抛出异常。
4. Synchroinzed能写在哪些地方及各自对应的锁对象是什么?
代码块上,锁对象可以是任意对象
普通方法上,加在普通方法前锁的是this对象,即调用method方法的对象
静态方法上,加在静态方法前锁的是这个类class对象
面试八股文---分布式主键+springboot异步+线程创建+synchronized
最新推荐文章于 2024-07-06 18:08:02 发布