美团Java后端(四)

本文探讨了Java中volatile关键字的作用,包括确保可见性和禁止指令重排序,以及不同事务隔离级别的概念,涵盖了Boolean对象比较、Integer对象equals使用,以及MySQL事务隔离的细节。此外,还涉及了Redis删除策略对比、HTTP GET/POST的区别和内存屏障的概念。
摘要由CSDN通过智能技术生成

链接:https://www.nowcoder.com/discuss/637431?source_id=discuss_experience_nctrack&channel=-1

  • Integer对象比较可以使用==判断么,两个Boolean呢
  1. Integer为对象,如果判断相等要用equals,而不能用==(==作用于引用类型的变量,则比较的是所指向的对象的地址)
  2. 两个Boolean也是对象,比较值的话应该用equals吧
  • volatile说一下

保证可见性禁止指令重排   参考链接

  1. Java内存模型中,就是可见性的问题,即一个线程修改了共享变量的值,对另一个线程来说是不是立即可见的。如果不是立即可见的,那么就会出现缓存一致性的问题,如果是立即可见的,那么另一个线程在进行操作的时候,拿到的变量值就是最新的。

volatile做了些什么操作就能解决可见性的问题

线程对变量操作时会从主内存中读取到自己的工作内存中,当线程对变量进行了修改后,那么其他已经读取了此变量的线程中的变量副本就会失效,这样其他线程在使用变量的时候,发现已经失效,那么就会去主内存中重新获取,这样获取到的就只最新的值了

2.如何实现指令重排序--内存屏障

volatile会在变量写操作的前后加入两个内存屏障,来保证前面的写指令和后面的读指令是有序的,在变量的读操作后面插入两个指令,禁止后面的读指令和写指令重排序。

  • 事务隔离级别说一下,默认级别是哪个呢

mysql的4种事务隔离级别,如下所示:

1、未提交读(Read Uncommitted):允许脏读,也就是可能读取到其他会话中未提交事务修改的数据

2、提交读(Read Committed):只能读取到已经提交的数据。Oracle等多数数据库默认都是该级别 (不重复读)

3、可重复读(Repeated Read):可重复读。在同一个事务内的查询都是事务开始时刻一致的,InnoDB默认级别。在SQL标准中,该隔离级别消除了不可重复读,但是还存在幻象读,但是innoDB解决了幻读

4、串行读(Serializable):完全串行化的读,每次读都需要获得表级共享锁,读写相互都会阻塞

  • redis的删除策略

  1. 定时删除(创建一个定时器,对key设置过期时间,当达到过期时间时,有CPU立即删除数据)以时间换空间

  2. 惰性删除(未过期,返回该数据,过期则删除数据)和定时删除的优缺点相反,节省CPU资源,但是内存占有量大

  •  http的get和post区别

  1. GET一般用于获取/查询资源信息,而POST一般用于更新资源信息

  2. GET请求的数据会附在URL之后,POST把提交的数据则放置在是HTTP包的包体

  3. POST的安全性要比GET的安全性高---比如:通过GET提交数据,用户名和密码将明文出现在URL上,因为(1)登录页面有可能被浏览器缓存

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值