Race Condition是什么

一、Race Condition(竞争条件、竞态条件、资源竞争 )

1. 竞争(Race)

计算机运行过程中,

  • 并发、
  • 无序、
  • 大量

的进程在使用

  • 有限、
  • 独占、
  • 不可抢占

的资源,由于进程无限,资源有限,产生矛盾,这种矛盾称为竞争(Race)。

 

2. 竞争条件(Race Condition)

由于两个或者多个进程竞争使用不能被同时访问的资源,计算的正确性取决于多个线程的交替执行时序时,就会发生竞争条件(Race Condition)。

 

3. 竞争条件分为两类:


-Mutex(互斥):

两个或多个进程彼此之间没有内在的制约关系,但是由于要抢占使用某个临界资源(不能被多个进程同时使用的资源,如打印机,变量)而产生制约关系。


-Synchronization(同步):

两个或多个进程彼此之间存在内在的制约关系(前一个进程执行完,其他的进程才能执行),如严格轮转法。

 

二、临界区(Critical Region)

  • 一段访问临界资源的代码。
  • 为了避免出现竞争条件,进入临界区要遵循四条原则:
    • 任何两个进程不能同时进入访问同一临界资源的临界区
    • 进程的个数,CPU个数性能等都是无序的,随机的
    • 临界区之外的进程不得阻塞其他进程进入临界区
    • 任何进程都不应被长期阻塞在临界区之外

 

三、解决互斥方法:


Busy Waiting(忙等待):

等着但是不停的检查测试,不睡觉,知道能进行为止


Sleep and Wakeup(睡眠与唤醒):

引入Semapgore(信号量,包含整数和等待队列,为进程睡觉而设置),唤醒由其他进程引发。

 

 

 

 

四、解决互斥的方法:


• 禁用中断 Disabling interrupts
• 锁变量 Lock variables (no)
• 严格轮转 Strict alternation (no)
• Peterson’s solution (yes)
• The TSL instruction (yes)
最重要的方法:信号量(Semaphore)

 

Java多线程模型当中,经常会因为多个线程同时访问相同的共享数据,而造成数据的不一致性。

为了解决这个问题,通常来说需要加上同步标志“synchronized”,来保证数据的串行访问。但是“synchronized”是个性能杀手,过多的使用会导致性能下降,特别是扩展性下降,使得你的系统不能使用多个CPU资源。

 

 

 

 

https://blog.csdn.net/u012562273/article/details/56486776/

https://blog.csdn.net/u012767369/article/details/86648561

上一篇:Promise.all和Promise.race的理解和使用


下一篇:STATA 语法格式