如果一段代码所在的进程中有多个线程在运行,而这些线程同时运行的结果与单个线程运行的结果是一样的,那么就是线程安全的,而线程安全基本上是因为全局变量和静态变量引起,因为这些变量在程序中可能被多个线程调用,而每一次调用可能会同时发生,导致本来A线程将X赋值为1,还没运行完,B线程同时也将它赋值为2,此时A线程经过一定的操作后想要取回那个X=1,却已经被改变了,使用时就好比是操作系统中涉及到的线程互斥,使用信号量一样,要注意读、写的权限,顺序等等。
实际中的例子:
vector是线程安全的,而ArrayList非线程安全,但却节约系统性能
比如一个 ArrayList 类,在添加一个元素的时候,它可能会有两步来完成:
1. 在 Items[Size] 的位置存放此元素;
2. 增大 Size 的值。
在单线程运行的情况下,如果 Size = 0,添加一个元素后,此元素在位置 0,而且 Size=1;
而如果是在多线程情况下,比如有两个线程,线程 A 先将元素存放在位置 0。但是此时 CPU 调度线程A暂停,线程 B 得到运行的机会。线程B也向此 ArrayList 添加元素,因为此时 Size 仍然等于 0 (注意哦,我们假设的是添加一个元素是要两个步骤哦,而线程A仅仅完成了步骤1),所以线程B也将元素存放在位置0。然后线程A和线程B都继续运行,都增加 Size 的值。
那好,现在我们来看看 ArrayList 的情况,元素实际上只有一个,存放在位置 0,而 Size 却等于 2。这就是“线程不安全”了。
同一个vector,A线程访问的时候,B线程不能访问而挂起(等待状态),等A释放对vector的锁以后B才能访问。
而同一个List可以被多个线程同时访问 。