看書的時候發現這個習題沒有答案,于是就想把自己做的結果貼上來,和大家分享分享!
首先把題目貼上來吧:
/*********** 8.10節中提及POSIX.1要求在調用exec時關閉打開的目錄流。按下列方法對此進行驗證,對根目錄調用opendir,查看在你的系統上實現的DIR結構,然后打印執行時關閉標志。接著open同一目錄讀取并打印執行時關閉標志 ***********/
首先說,關于執行時關閉標志的作用,JesseEisen的這篇博客已經講解的非常好了,(傳送門在這里)我就不在這里獻丑了,我想講的是opendir和open函數的一點區別。
opendir函數在打開目錄流的的時候是設置了close-on-exec(執行時關閉)標志的,open函數則沒有。
具體來看這段代碼:
1 /*** 2 這里的err_exit()函數是我自己定義的,功能就是調用strerror()函數打印出錯誤信息,并且調用exit()函數退出! 3 ***/ 4 5 #include<dirent.h> 6 #include<errno.h> 7 #include<fcntl.h> 8 #include<string.h> 9 #include<stdlib.h>10 #include<stdarg.h>11 #include<stdio.h>12 #include<sys/types.h>13 #include<unistd.h>14 void err_exit(char *fmt,...);15 int main(int argc,char *argv[])16 {17 DIR *dirp;18 int dir_fd;19 int val;20 21 /*用opendir的方式打開目錄,并且獲取文件描述符,然后查看其close-on-exec標志*/22 if(NULL == (dirp=opendir("/")))23 err_exit("[opendir]: ");24 if(-1 == (dir_fd=dirfd(dirp))) //獲取打開目錄流的文件描述符25 err_exit("[dirfd]: ");26 if(-1 == (val=fcntl(dir_fd,F_GETFD)))27 err_exit("[fcntl]: ");28 29 PRintf("%-9s: ","[opendir]");30 if(val & FD_CLOEXEC)31 printf("close-on-exec flag is on/n");32 else33 printf("close-on-exec flag is off/n");34 35 if(-1 == closedir(dirp))36 err_exit("[closedir]: ");37 38 /*用open的方式打開目錄,然后查看其close-on-exec標志*/39 if(-1 == (dir_fd=open("/",O_DIRECTORY))) //open函數加上O_DIRECTORY標志就能夠打開目錄了40 err_exit("[open]: ");41 if(-1 == (val=fcntl(dir_fd,F_GETFD)))42 err_exit("[fcntl]: ");43 44 printf("%-9s: ","[open]");45 if(val & FD_CLOEXEC)46 printf("close-on-exec flag is on/n");47 else48 printf("close-on-exec flag is off/n");49 50 if(-1 == close(dir_fd))51 err_exit("[close]: ");52 53 return 0;54 }
這段代碼功能就是這樣的:
首先通過opendir函數打開一個目錄,然后通過dirfd函數提取出目錄流的文件描述符,然后再利用fcntl獲取close-on-exec標志。
接著再來通過open函數(增加了O_DIRECTORY標志就能打開目錄了,詳見open(2))打開同一個目錄,然后再來通過fcntl函數來查看它的close-on-exec標志。
程序的運行結果如下:
從結果中我們可以看到,opendir打開的目錄流擁有close-on-exec標志位,而open函數打開的目錄流沒有close-on-exec標志位,這正好印證了APUE8.10節的敘述:
新聞熱點
疑難解答