printf linux 头文件,Linux C 格式化输出时要注意的问题
在Linux下提供了以下函數提供格式化輸出,printf,fprintf,sprintf,snprintf。這些函數的頭文件定義都是stdio.h。為標準的C庫函數。
printf提供標準的輸出流,fprintf往特定的流中寫數據。前者比較常見,用的也較多。
sprintf格式化輸入到字符指針緩沖,這個函數自動的加入null byte到緩沖,但是返回值不包括這個結束字節。
使用sprintf函數意緩沖溢出問題,用戶要保證格式化數據的長度。
如下代碼:
#include
int main(int argc,char *argv[])
{
char buffer[6];
sprintf(buffer,"%d",123456789);
printf("%s\n",buffer);
return 0;
}
gcc version 4.5.1 20100924 (Red Hat 4.5.1-4) (GCC)
下輸出:123456789
buffer緩沖區,只有6個字節的長度,但是輸出的數據卻有9個字節,這個結果在一些情況下是不確定的,可能造成系統崩潰。
這個問題,在網絡編程中,尤其要注意。接受客戶端提交的數據,我們如果用這個函數來格式化,由于客戶端的輸入是不確定的,這對系統存在潛在的危險。如果,有提交的數據超過緩沖,可能造成系統出錯。這就是緩沖區攻擊的原理。
針對以上的問題,有個替代的函數snprintf。n表示格式化的長度。
以下代碼:
#include
intmain(intargc,char*argv[])
{
charbuffer[6];
sprintf(buffer,"%d",123456789);
printf("%s\n",buffer);
return0;
}
總結
以上是生活随笔為你收集整理的printf linux 头文件,Linux C 格式化输出时要注意的问题的全部內容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: Linux中断与进程切换,结合中断上下文
- 下一篇: linux 其他常用命令