竞争条件,简单来说就是多个进程同时访问同一个共享资源,导致出现预期结果以外的错误的情况。
出现竞争条件的本质原因是cpu对程序的调度是没有特定规律的,某一时刻cpu处理哪个进程是不确定的。
简单写一个测试程序,先需要子进程和父进程依次打印往终端中打印0~99,如果不做同步的话,其实是存在竞争条件的,代码如下:
/*************************************************************************
> File Name: compet.c
> Author: conbiao
> Created Time: 2024年09月26日 星期四 16时58分10秒
************************************************************************/
/***********************************************************************
* HEADER
**********************************************************************/
#include <stdio.h>
#include <sys/types.h>
#include <unistd.h>
#include <stdlib.h>
/***********************************************************************
* MACRO
**********************************************************************/
/***********************************************************************
* GLOBAL VARIABLE
**********************************************************************/
/***********************************************************************
* FUNCTION DESCRIPTION
**********************************************************************/
/***********************************************************************
* FUNCTION NAME:
***********************************************************************
*
* Summary:
*
* Params:
*
* Return:
*
***********************************************************************/
/***********************************************************************
* MAIN
**********************************************************************/
int main(int argc, char *argv[])
{
int ret = 0;
pid_t pid;
pid = fork();
if(pid < 0)
{
printf("%s: fork fail!\n",__func__);
exit(-1);
}
else if(pid == 0)
{
for(int i = 0;i < 100;i++)
{
printf("This is child process! i = %d\n",i);
}
}
else
{
for(int i = 0;i < 100;i++)
{
printf("This is father process! i = %d\n",i);
}
}
return ret;
}
运行结果如下:
为了避免出现竞争条件,需要开发者在代码中做同步,保证有顺序要求的进程有序进行。