`

java的servlet线程安全

阅读更多
Servlet的线程安全问题主要是由于实例变量使用不当而引起的
如:一个Servlet实例化全局变量PrintWriter output;在service方法将其赋值为用户的输出。当一个用户访问该Servlet时,程序会正常的运行,但当多个用户并发访问时,就可能会出现其它用户的信息显示在另外一些用户的浏览器上的问题。这是一个严重的问题。是由于实例变量不正确的使用是造成Servlet线程不安全。
解决办法:
1、实现 SingleThreadModel 接口
该接口指定了系统如何处理对同一个Servlet的调用。如果一个Servlet被这个接口指定,那么在这个Servlet中的service方法将不会有两个线程被同时执行,当然也就不存在线程安全的问题。
2、同步对共享数据的操作 使用synchronized 关键字能保证一次只有一个线程可以访问被保护的区段,在本论文中的Servlet可以通过同步块操作来保证线程的安全。
3、避免使用实例变量 本实例中的线程安全问题是由实例变量造成的,只要在Servlet里面的任何方法里面都不使用实例变量,那么该Servlet就是线程安全的。
线程安全问题只有当并发访问时才能检验出来,因此在编写Servlet程序时要特别注意。线程安全问题主要是由实例变量造成的,因此在Servlet中应避免使用实例变量。
分享到:
评论

相关推荐

Global site tag (gtag.js) - Google Analytics