A. linux下printf函數為什麼沒有輸出相關的內容
#include<stdio.h>
#include<unistd.h>
int main(void)
{
printf("before execl called\n");
if(-1 == execl("/bin/ls","ls","/","/home",NULL))
{
perror("execl");
return -1;
}
printf("after execl called\n");
return 0;
}
Linux下C語言的printf是C標准I/O庫中的格式化輸出函數之一,將格式化數據寫到標准輸出stdout。
1 printf首先把格式化數據寫到標准I/O的緩存,可以用setbuf和setvbuf設置緩存選項;
2 調用write系統調用,把標准I/O的緩存數據寫到文件描述符STDOUT_FILENO,則標准I/O緩存中的數據就被送到內核緩存;
3 內核把緩存中的數據輸出到標准輸出stdout對應的文件描述符STDOUT_FILENO。
這是我的理解,基本應該就是這個流程,內核層次上的細節我就不清楚了。
另外:
1 printf返回寫入的位元組數;
2 printf處理可變參數表使用的是va_list,當然也有相應的vprintf,它的第三個參數就是一個va_list
B. Linux下的一個c程序,程序一遇到printf就出現段錯誤
程序運行在內存中;
系統在程序運行之前會在內存中先給程序畫出一個空間
這個空間有些來存放代碼的;有些來存放運行時的變數,還有些....
這個空間有一個區間使用來存放運行時的變數什麼的
段錯誤 就是 程序運行時,變數訪問越界一類的問題...
可能出現的原因是:
數組下標越界
動態分配內存的指針被double free了(釋放兩次了)
C. LINUX下C語言連續的三個printf ,最後一個不執行,程序卡在那裡,按ctrl+c繼續執行。
可以如一樓那樣改,也可以把printf改為fprintf(stderr,"hello world");
printf可能有行緩沖,但stderr是無緩沖.
D. 在linux中使用printf("%02x", md5[i]); 能夠列印出32位十六進制的數據如:
定義一個字元數組char pszMd5[20];
memset(pszMd5, 0, 20);
pszMd5[0] = md5[0]
最後追加個字元串結尾符號'\0'就可以了。
數據相同,只是解釋方式不一樣了。