tsai@nynex1.UUCP (Nelson Tsai) (08/11/88)
I have some questions about popen function in C.
According to the reference manual, popen should come with pclose.
But, in my Sun OS 3.5 interesting thing happened if I forgot
to put pclose after popen. For instance, the following program works:
#include <stdio.h>
main()
{
int i ;
for(i=1;i<100;i++)
proc(i);
}
proc(i)
int i;
{
FILE *gg;
gg = popen("date","r");
printf("%d \n",i);
}
But, if the function proc() was changed to :
proc(i)
int i;
{
FILE *gg;
char ss[200];
gg = popen("date","r");
printf("%d \n",i);
fgets(ss,200,gg);
}
Then, after executed about 20 times, it caused segmentation fault
(core dumped). Why is that ? Why reading from the pipe cause the
segmentation fault ?bill@proxftl.UUCP (T. William Wells) (08/12/88)
In article <364@nynex1.UUCP> tsai@nynex1.UUCP (Nelson Tsai) writes:
: Then, after executed about 20 times, it caused segmentation fault
: (core dumped). Why is that ? Why reading from the pipe cause the
: segmentation fault ?
That's an easy one. You ran out of fd's and the popen call
failed. It returned a null pointer and fgets tried to
dereference it. Thus the core dump. When you didn't include the
fgets, the pointer was never dereferenced, hence no core dump.