1. 什么是线程安全?
同一处代码,被多个线程执行,每个线程执行完的结果都是预期的结果,我们就说这段代码是线程安全的。反之,线程不安全。 线程安全问题的根本是全局变量的访问问题, 比如Servlet有一个属性,这个属性就要考虑线程安全问题,所以我们说,Servlet是线程不安全的。
2. 解决线程安全问题的办法。
a. 使用synchronized key word. 原理是使用锁,当一个线程执行一段代码的时候加上锁,此时如果另外一个线程想来执行这段代码,就必须等待,直到上个线程结束。
b. 使用ThreadLoale对象,将那个可能产生线程安全问题的变量存入ThreadLoacl对象,这样一来,每个线程都会有一个独享的ThreadLocal对象,变量也就解决了冲突,每个线程都有一个独立的变量。
c. 使用volatile key word, 这个解决方案是将此变量的存储空间由线程内部变为主存储空间。 每个线程对此变量操作的时候,都是直接对主存储空间操作,换句话说就是, 每个线程共享着一个变量。 通常这种解决方案出现在处理context变量的时候, 感觉有点像单例模式。
d. 使用一些已经处理过线程问题的容器,比如 ConcurrentHashMap, StringBuffer等。
同一处代码,被多个线程执行,每个线程执行完的结果都是预期的结果,我们就说这段代码是线程安全的。反之,线程不安全。 线程安全问题的根本是全局变量的访问问题, 比如Servlet有一个属性,这个属性就要考虑线程安全问题,所以我们说,Servlet是线程不安全的。
2. 解决线程安全问题的办法。
a. 使用synchronized key word. 原理是使用锁,当一个线程执行一段代码的时候加上锁,此时如果另外一个线程想来执行这段代码,就必须等待,直到上个线程结束。
b. 使用ThreadLoale对象,将那个可能产生线程安全问题的变量存入ThreadLoacl对象,这样一来,每个线程都会有一个独享的ThreadLocal对象,变量也就解决了冲突,每个线程都有一个独立的变量。
c. 使用volatile key word, 这个解决方案是将此变量的存储空间由线程内部变为主存储空间。 每个线程对此变量操作的时候,都是直接对主存储空间操作,换句话说就是, 每个线程共享着一个变量。 通常这种解决方案出现在处理context变量的时候, 感觉有点像单例模式。
d. 使用一些已经处理过线程问题的容器,比如 ConcurrentHashMap, StringBuffer等。
本文深入探讨了线程安全的概念,解释了为何Servlet被认为是线程不安全的,并提供了几种有效解决线程安全问题的方法,包括使用synchronized关键字、ThreadLocal对象、volatile关键字以及特定的容器类。
10万+

被折叠的 条评论
为什么被折叠?



