Session的线程安全问题及有效性问题

本文探讨了Session的线程安全问题,强调了虽然Session接口本身是线程安全的,但其中保存的对象需要开发者确保线程安全。同时,文章介绍了Session的有效性问题,包括如何判断和处理Session失效,以及Session的生命周期。最后提到了session.invalidate()方法对Session的影响。
摘要由CSDN通过智能技术生成

1、线程安全问题

Session接口的相关实现由Tomcat容器提供,本身保证线程安全。但Session中保存的对象,其线程安全当然要由开发者保证。线程安全问题隐蔽、偶发,出了问题不好定位修正,一定要注意线程安全问题。通常,通过如下代码创建或者取得Session引用:

HttpSession session = request.getSession(true);                  // 这个方法是线程安全的。

通过如下方法为session设置属性:

session.setAttribute("user", new user("name"));                     // 这个方法也是线程安全的。

通过如下方法从session获取属性:

User u = session.getAttribute("user");                                      // 这个方法也是线程安全的

接下来,从u读取属性或者设置属性:

u.getName();

u.setName("NewName");

以上两个方法,是不是线程安全,取决于User类的实现,为了保证线程安全,需要在getName与setName方法的实现中加上线程同步机制,也就是说要保证User类本身是线程安全的。如果User类不保证线程安全,就由使用者来保证线程安全,代码应该这样:

synchronized(u) {

    u.getName();

    u.setName("NewName");

}

在User类不保证线程安全的情况下

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值