在C循环内调用system()失败

时间:2013-07-27 15:01:39

标签: c system errno

我正在尝试编写一个简单的C代码,该代码执行N次迭代的shell脚本(其中N大于3000)。最初,代码似乎运行得很好但随着迭代次数的增加,system()函数开始返回-1。此外,如果我再次运行整个程序,则错误发生在循环中的完全相同的点。

这是我的代码:

int main(void)
{
    char command[] = "bash sampleScript";
    int i, ret, N = 3000;

    for(i=0;i<N;i++){

       /* Open 'sampleScript', make the required modifications and close it */

       while(!system(NULL)){
          printf("Shell is unavailable");
          sleep(2);
       }
       ret = system(command);
       if(ret == -1){
          printf("System failed\n");
          exit(1);
       }
    }
    return 0;
}

shell脚本的输出不会影响C代码。当我执行这段代码时,在i = 2900左右,system()开始返回-1,我完全不知道为什么会这样。我在这里错过了一个明显的观点吗?有人可以帮助我吗?

我在64位Ubuntu上使用gcc。

更新

当system()返回-1时,相应的errno值为12 - 无法分配内存。

ulimit -a的输出是

core file size          (blocks, -c) 0
data seg size           (kbytes, -d) unlimited
scheduling priority             (-e) 0
file size               (blocks, -f) unlimited
pending signals                 (-i) 47495
max locked memory       (kbytes, -l) 64
max memory size         (kbytes, -m) unlimited
open files                      (-n) 1024
pipe size            (512 bytes, -p) 8
POSIX message queues     (bytes, -q) 819200
real-time priority              (-r) 0
stack size              (kbytes, -s) 8192
cpu time               (seconds, -t) unlimited
max user processes              (-u) 47495
virtual memory          (kbytes, -v) unlimited
file locks                      (-x) unlimited

1 个答案:

答案 0 :(得分:0)

我没有问你问题,也许你可以使用printf("system failed when i =%d\n",i);来获取一些信息

我使用SUSE。

ulimit -a打印这个:

core file size          (blocks, -c) 0
data seg size           (kbytes, -d) unlimited
scheduling priority             (-e) 0
file size               (blocks, -f) unlimited
pending signals                 (-i) 7464
max locked memory       (kbytes, -l) 64
max memory size         (kbytes, -m) unlimited
open files                      (-n) 1024
pipe size            (512 bytes, -p) 8
POSIX message queues     (bytes, -q) 819200
real-time priority              (-r) 0
stack size              (kbytes, -s) 8192
cpu time               (seconds, -t) unlimited
max user processes              (-u) 7464
virtual memory          (kbytes, -v) unlimited
file locks                      (-x) unlimited

这是我的代码(问题是没有错误打印,N现在是10000!):

 2 #define N 10000

  3 int main(void)
  4 {
  5     char command[] = "cd";
  6     int i, ret;
  7 
  8     for(i=0;i<N;i++){
  9 
 10        /* Open 'sampleScript', make the required modifications and close it */
 11 
 12        while(!system(NULL)){
 13           printf("Shell is unavailable");
 14          // sleep(2);
 15        }
 16        ret = system(command);
 17        if(ret == -1){
 18           printf("System failed\n");
 19           exit(1);
 20        }
 21     }
 22     return 0;
 23 }