链接:https://www.nowcoder.com/discuss/637431?source_id=discuss_experience_nctrack&channel=-1
- Integer对象比较可以使用==判断么,两个Boolean呢
- Integer为对象,如果判断相等要用equals,而不能用==(==作用于引用类型的变量,则比较的是所指向的对象的地址)
- 两个Boolean也是对象,比较值的话应该用equals吧
- volatile说一下
保证可见性;禁止指令重排 参考链接
-
Java内存模型中,就是可见性的问题,即一个线程修改了共享变量的值,对另一个线程来说是不是立即可见的。如果不是立即可见的,那么就会出现缓存一致性的问题,如果是立即可见的,那么另一个线程在进行操作的时候,拿到的变量值就是最新的。
volatile做了些什么操作就能解决可见性的问题
线程对变量操作时会从主内存中读取到自己的工作内存中,当线程对变量进行了修改后,那么其他已经读取了此变量的线程中的变量副本就会失效,这样其他线程在使用变量的时候,发现已经失效,那么就会去主内存中重新获取,这样获取到的就只最新的值了
2.如何实现指令重排序--内存屏障
volatile
会在变量写操作的前后加入两个内存屏障,来保证前面的写指令和后面的读指令是有序的,在变量的读操作后面插入两个指令,禁止后面的读指令和写指令重排序。
-
事务隔离级别说一下,默认级别是哪个呢
mysql的4种事务隔离级别,如下所示:
1、未提交读(Read Uncommitted):允许脏读,也就是可能读取到其他会话中未提交事务修改的数据
2、提交读(Read Committed):只能读取到已经提交的数据。Oracle等多数数据库默认都是该级别 (不重复读)
3、可重复读(Repeated Read):可重复读。在同一个事务内的查询都是事务开始时刻一致的,InnoDB默认级别。在SQL标准中,该隔离级别消除了不可重复读,但是还存在幻象读,但是innoDB解决了幻读
4、串行读(Serializable):完全串行化的读,每次读都需要获得表级共享锁,读写相互都会阻塞
-
redis的删除策略
-
定时删除(创建一个定时器,对key设置过期时间,当达到过期时间时,有CPU立即删除数据)以时间换空间
-
惰性删除(未过期,返回该数据,过期则删除数据)和定时删除的优缺点相反,节省CPU资源,但是内存占有量大
-
http的get和post区别
-
GET一般用于获取/查询资源信息,而POST一般用于更新资源信息
-
GET请求的数据会附在URL之后,POST把提交的数据则放置在是HTTP包的包体
-
POST的安全性要比GET的安全性高---比如:通过GET提交数据,用户名和密码将明文出现在URL上,因为(1)登录页面有可能被浏览器缓存