您的位置:首页 > 其它

Servlet线程安全开发注意事项

2013-07-27 21:06 183 查看
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容器对于接收到的每个请求,都会创建一个请求对象,该对象只能在一个线程里被访问,所以是线程安全的。
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: