Servlet线程安全开发注意事项

Servlet线程安全实践
本文介绍了在Servlet开发中确保线程安全的最佳实践,包括使用本地变量、同步集合类及正确处理ServletContext、HttpSession等对象的方法。

1.尽可能在Servlet中使用本地变量

2.应该只使用制度的实例变量和静态变量

3.不要再Servlet中创建自动的线程

4.修改共享对象,一定要使用同步,尽可能缩小同步代码的范围,从性能角度考虑,不要再方法粒度上同步。

5.不同的servlet,对外部对象进行修改,要做加锁操作。

6.使用同步的集合类,如使用Vector而非ArrayList,使用Hashtable而非HashMap。

 

关于ServletContext、HttpSession、ServletRequest对象的线程安全情况.

1.ServletContext对象可以被Webapps中所有的servlet访问,在多线程的场景下对上下文属性进行设置或者读取,可能会有不一致的情况。

---------》ServletContext只保留几乎不修改的数据,而其他经常需要修改的,则采取别的办法在多个servlet中共享。

2.HttpSession对象只处理同一Session的请求,但在多线程场景下,也可能对同一个对象进行设置或者读取,也是线程不安全的。

3.ServlnetRequest

Servlet容器对于接收到的每个请求,都会创建一个请求对象,该对象只能在一个线程里被访问,所以是线程安全的。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值