printf的格式控制的完整格式:
% - 0 m.n l或h 格式字元
下面對組成格式說明的各項加以說明:
①%:表示格式說明的起始符號,不可缺少。
②-:有-表示靠左對齊輸出,如省略表示靠右對齊輸出。
③0:有0表示指定空位填0,如省略表示指定空位不填。
④m.n:m指域寬,即對應的輸出項在輸出裝置上所佔的字元數。N指精度。用於說明輸出的實型數的小數位元。為指定n時,隱含的精度為n=6位。
⑤l或h:l對整型指long型,對實型指double型。h用於將整型的格式字元修正為short型。
格式字元
格式字元用以指定輸出項的資料類型和輸出格式。
①d格式:用來輸出十進位整數。有以下幾種用法:
%d:按整型資料的實際長度輸出。
%md:m為指定的輸出欄位的寬度。如果資料的位元小於m,則左端補以空格,若大於m,則按實際位元輸出。
%ld:輸出長整型資料。
②o格式:以無符號八進位形式輸出整數。對長整型可以用"%lo"格式輸出。同樣也可以指定欄位寬度用“%mo”格式輸出。
例:
main()
{ int a = -1;
printf("%d, %o", a, a);
}
運行結果:-1,177777
程式解析:-1在記憶體單元中(以補碼形式存放)為(1111111111111111)2,轉換為八位元為(177777)8。
③x格式:以無符號十六進位形式輸出整數。對長整型可以用"%lx"格式輸出。同樣也可以指定欄位寬度用"%mx"格式輸出。
④u格式:以無符號十進位形式輸出整數。對長整型可以用"%lu"格式輸出。同樣也可以指定欄位寬度用“%mu”格式輸出。
⑤c格式:輸出一個字元。
⑥s格式:用來輸出一個串。有幾中用法
%s:例如:printf("%s", "CHINA")輸出"CHINA"字串(不包括雙引號)。
%ms:輸出的字串佔m列,如字串本身長度大於m,則突破獲m的限制,將字串全部輸出。若串長小於m,則左補空格。
%-ms:如果串長小於m,則在m列範圍內,字串向左靠,右補空格。
%m.ns:輸出佔m列,但只取字串中左端n個字元。這n個字元輸出在m列的右側,左補空格。
%-m.ns:其中m、n含義同上,n個字元輸出在m列範圍的左側,右補空格。如果n>m,則自動取n值,即保證n個字元正常輸出。
⑦f格式:用來輸出實數(包括單、雙精確度),以小數形式輸出。有以下幾種用法:
%f:不指定寬度,整數部分全部輸出並輸出6位小數。
%m.nf:輸出共佔m列,其中有n位小數,如數值寬度小於m左端補空格。
%-m.nf:輸出共佔n列,其中有n位小數,如數值寬度小於m右端補空格。
⑧e格式:以指數形式輸出實數。可用以下形式:
%e:數字部分(又稱尾數)輸出6位小數,指數部分佔5位或4位。
%m.ne和%-m.ne:m、n和”-”字元含義與前相同。此處n指資料的數字部分的小數位元,m表示整個輸出資料所佔的寬度。
⑨g格式:自動選f格式或e格式中較短的一種輸出,且不輸出無意義的零。
關於printf函數的進一步說明:
如果想輸出字元"%",則應該在“格式控制”字串中用連續兩個%表示,如:
printf("%f%%", 1.0/3);
輸出0.333333%。
對於單精確度數,使用%f格式符輸出時,僅前7位是有效數字,小數6位.
對於雙精確度數,使用%lf格式符輸出時,前16位是有效數字,小數6位.
拾遺由高手指點
對於m.n的格式還可以用如下方法表示(例)
char ch[20];
printf("%*.*s/n",m,n,ch);
前邊的*定義的是總的寬度,後邊的定義的是輸出的個數。分別對應外面的參數m和n 。我想這種方法的好處是可以在語句之外對參數m和n賦值,從而控制輸出格式。
今天(06.6.9)又看到一種輸出格式 %n 可以將所輸出字串的長度值賦紿一個變數, 見下例:
int slen;
printf("hello world%n", &slen);
執行後變數被賦值為11。
又查了一下, 看到一篇文章(查看)說這種格式輸出已經確認為一個安全隱患,並且已禁用。再搜搜果然這種用法都被用來搞什麼溢出、漏洞之類的,隨便找了一個:格式化字串攻擊筆記
特別注意下%*.*s這種用法
轉自:http://blog.liuwentao.net/read.php?17 -----------------------------------------------------------------------------------------------------------------------------------------------逸出字元參考: /a:蜂鳴,響鈴
/b:回退:向後退一格
/f:換頁
/n:換行,游標到下行行首
/r:斷行符號,游標到本行行首
/t:水平製表
/v:垂直製表
//:反斜線
/':單引號
/":雙引號
/?:問號
/ddd:三位八進位
/xhh:二位十六進位
/0:Null 字元(NULL),什麼都不做 註:
1,/v垂直製表和/f換頁符對螢幕沒有任何影響,但會影響印表機執行響應操作。
2,/n其實應該叫斷行符號換行。換行只是換一行,不改變游標的橫座標;斷行符號只是回到行首,不改變游標的縱座標。
3,/t 游標向前移動四格或八格,可以在編譯器裡設定
4,/' 在字元裡(即單引號裡)使用。在字串裡(即雙引號裡)不需要,只要用 ' 即可。
5,/? 其實不必要。只要用 ? 就可以了(在windows VC6 和tc2 中驗證)。 格式控制符參考:格式輸出字元:printf使用:向終端輸出若干個類型任意的資料。形式:printf (格式控制符,輸出資料行表)說明:格式控制符:% 格式說明引導符。 - 指定靠左對齊輸出。 0 指定空位填零。 m.n 指定輸出域寬度及精度。 l.h 輸出長度的修正。 格式字元 指定輸出的資料類型。說明:格式字元:指定輸出項的資料類型和輸出格式。 d 有符號十進位整數。 o 無符號八位元。 x 無符號十六進位數。(小寫x格式中用小寫字母a,b,c,d,e,f來表示10到15之間的數,大寫的X則用大寫的ABCDEF來表示10到15之間的數) u 不帶符號的十進位整數。基本整型:兩個位元組,十六個bit(位)11 11 11 11 11 11 11 11 等於 65535.11 11 11 11 11 11 11 10 等於 -2.負數的第一位(符號位)為1。負數的補碼怎麼得到:原碼取反加一。2的位元為:00 00 00 00 00 00 00 10,取反就等於11 11 11 11 11 11 11 01,然後加1,位元逢二進一,所以就得出-2 的二進位代碼。 有符號的整型數可以用 %d 輸出。無符號的整型數可以用 %u 輸出。電腦裡存的數字都是位元,最高位是符號位還是資料位元,可以由輸出格式符來控制。 位元轉換八位元:三個 1 對應一個 7 。位元鏨十六進位數:四位二進位對應一位十六進位,四個1 對應一個 f。 說明: 格式字元:c 輸出一個字元。 s 輸出一個字串。 e 以指數形式輸出實型數。 f 以小數形式輸出實型數。 g 自動決定輸出格式為e和f中較短的一種,不列印無效的零。 % 輸出%。 注意:對於單精確度數,使用 %f 格式符輸出時,僅前7位是有效數字,小數6位。 對於雙精確度數,使用 %lf 格式符輸出時,前16位是有效數字,小數6位。 長度修正符 l:對整型指定長整型long 例:%ld , %lx , %lo , %lu 對實型指定雙精確度double 例:%lf h:只用於整型的格式字元修正為short 例:%hd , %hx , %ho , %hu對64位整數的輸入輸出,在POJ上的C++環境下(即VC++),64位整數是:
__int64
輸入輸出格式為”%I64d”.在G++環境下, 64位整數是
long long
輸入輸出格式為”%lld”.域寬及精度的描述 M:域寬,即對應的輸出項在輸出裝置上所佔字元數 若:實際資料寬度>M,按實際資料寬度輸出。 實際資料寬度<M,左邊補空。 N:精度,說明輸出的實型數的小數位元。 幾點說明: 編譯器只是檢查printf 函數的調用形式,不分析格式控制字元串,如果格式字元與輸出項的類型不符,不進行類型轉換。(輸出的數為隨機) 格式字元要用小寫字母。 格式控制字元串中可以包含逸出字元。 格式控制字元串中的一般字元則原樣輸出。 輸出項的參數除了常數、變數外還可以是運算式、函數調用。 %g,%f和%e這三個格式用於列印浮點值。
%g格式用於列印那些不需要按列對齊的浮點數特別有用。其作用有二:
一,去掉該數尾多餘的零(沒有達到六位的數)
二,保留六位有效數字(多餘六位的)
%e格式用於列印浮點數時,一律顯示地使用指數形式:例如:輸出圓周率時是:3.141593e+00
兩者的區別:
%g格式列印出的數是總共6位有效數字
%e格式列印出小數點後的6位有效數字
%f禁止使用指數形式來表示浮點數。因此圓周率輸出為:3.141593
(但注意它的精度要求:也是小數點後6位有效數字)
(8)%%格式用於列印一個%字元。
(9)%E和%G只是在輸出時用大寫字母(E)代替了小寫字母(e) 輸出加號或減號的技巧,例如:
printf("%+d %+d %+d/n",-5,0,5);
只要在中間加個“+”號就行。作用是輸出符號位(即,數的加號或減號)
如果不希望正數的前面出現‘+’號,可用下面的方法
只要在中間加個“ ”號(即:空格)就行。例如:
作用:如果一個數是非負數,就在它的前面插入一個空格。
int i;
for(i=-3;i<=3;i++)
printf("% d/n",i); //注意%和d之間有一個空格 sscanf()的提示:
分解字串,很多功能都需要Regex的知識,所以就介紹一下最簡單的幾種用sscanf來分解字串 的用法。
1.
char str[100],str1[100],str2[100];
gets(str);
sscanf(str,”%s%s”,str1,str2);
將讀入的一整行字串按空格,定位字元或斷行符號符分割成兩個字串。
2
取指定長度的字串。如在下例中,取最大長度為4位元組的字串。
sscanf("123456 ", "%4s", str);本文來自CSDN部落格,轉載請標明出處:http://blog.csdn.net/qiqi5521/archive/2008/04/19/2306364.aspx