Java加锁的两种方法:
- synchronized关键字
- Java.util.concurrent包中的lock接口和ReentrantLock实现类
总结来说,Lock和synchronized有以下几点不同:
1)Lock是一个接口,而synchronized是Java中的关键字,synchronized是内置的语言实现;
2)synchronized在发生异常时,会自动释放线程占有的锁,因此不会导致死锁现象发生;而Lock在发生异常时,如果没有主动通过unLock()去释放锁,则很可能造成死锁现象,因此使用Lock时需要在finally块中释放锁;
3)Lock可以让等待锁的线程响应中断,而synchronized却不行,使用synchronized时,等待的线程会一直等待下去,不能够响应中断;
4)通过Lock可以知道有没有成功获取锁,而synchronized却无法办到。
5)Lock可以提高多个线程进行读操作的效率。
https://www.cnblogs.com/xdp-gacl/p/3641769.html#4195389
https://www.52pojie.cn/thread-789993-1-18.html
引用传递和值传递
http://www.cnblogs.com/xuxinstyle/p/9672958.html
https://blog.csdn.net/mayibz/article/details/79261200
https://www.cnblogs.com/yuansc/p/8550794.html
https://blog.csdn.net/weixin_37948564/article/details/80475243
https://blog.csdn.net/youanyyou/article/details/79406292
Random类:
http://www.cnblogs.com/Fskjb/archive/2009/08/29/1556417.html
random方法是java.lang.Math的方法,作用是返回带正号的 double 值,该值大于等于 0.0 且小于 1.0。而Random类是一个类(java.util.Random),里面含有很多方法
在Random类中有几个常用到的方法。
1.nextDouble() 返回下一个伪随机数,它是取自此随机数生成器序列的、在 0.0 和 1.0 之间均匀分布的 double 值。
2.nextInt() 返回下一个伪随机数,它是此随机数生成器的序列中均匀分布的 int 值。(不是在0到一之间)
3.nextInt(int n) 返回一个伪随机数,它是取自此随机数生成器序列的、在 0(包括)和指定值(不包括)之间均匀分布的 int 值。
数据库中 BTREE和B+tree区别
https://blog.csdn.net/lengxiao1993/article/details/52310712
Java线程的sleep()和wait()的区别:
sleep() 方法是线程类(Thread)的静态方法,让调用线程进入睡眠状态,让出执行机会给其他线程,等到休眠时间结束后,线程进入就绪状态和其他线程一起竞争cpu的执行时间。
因为sleep() 是static静态的方法,他不能改变对象的机锁,当一个synchronized块中调用了sleep() 方法,线程虽然进入休眠,但是对象的机锁没有被释放,其他线程依然无法访问这个对象。
wait()是Object类的方法,当一个线程执行到wait方法时,它就进入到一个和该对象相关的等待池,同时释放对象的机锁,使得其他线程能够访问,可以通过notify,notifyAll方法来唤醒等待的线程