我正在尝试编写一个简单的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
答案 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 }