c語言printf字元串
① c語言printf函數中,%C和%s都可以輸出字元串
這句話是不對的,因為%c只能夠輸出單個字元,%s表示的是輸出字元串,所以說這句話是錯誤的。
printf()函數是式樣化輸出函數, 一般用於向准則輸出設備按規定式樣輸出消息。正在編寫步驟時經常會用到此函數。printf()函數的挪用式樣為:printf(「<式樣化字元串>」,<參數表>);。
其中式樣化字元串包括兩部分內容:一部分是正常字元,這些字元將按原樣輸出;另一部分是式樣化規定字元。以「%」開端,後跟一個或幾個規定字元,用來確定輸出內容式樣。
(1)c語言printf字元串擴展閱讀:
printf函數注意:
函數printf從右到左壓棧,然後將先讀取放到棧底,最後讀取的放在棧頂,處理時候是從棧頂開始的,所以我們看見的結果是,從右邊開始處理的。
格式:
1、可以在「%」和字母之間插進數字表示最大場寬。
例如:%3d表示輸出3位整型數,不夠3位右對齊。
%9.2f表示輸出場寬為9的浮點數,其中小數位為2,整數位為6。
小數點佔一位,不夠9位右對齊。
%8s表示輸出8個字元的字元串,不夠8個字元右對齊。
如果字元串的長度、或整型數位數超過說明的場寬,將按其實際長度輸出。
但對浮點數,若整數部分位數超過了說明的整數位寬度,將按實際整數位輸出。
若小數部分位數超過了說明的小數位寬度,則按說明的寬度以四捨五入輸出。
另外,若想在輸出值前加一些0,就應在場寬項前加個0。
例如:%04d表示在輸出一個小於4位的數值時,將在前面補0使其總寬度為4位。
如果用非浮點數表示字元或整型量的輸出格式,小數點後的數字代表最大寬度,
小數點前的數字代表最小寬度。
例如:%6.9s表示顯示一個長度不小於6且不大於9的字元串。若大於9,則第9個字元以後的內容將被刪除。
2、可以在「%」和字母之間加小寫字母l,表示輸出的是長型數。
例如:%ld表示輸出long整數
%lf表示輸出double浮點數
3、可以控制輸出左對齊或右對齊,即在「%」和字母之間加入一個「-」號可說明輸出為左對齊, 否則為右對齊。
參考資料來源:網路-printf
② printf在c語言中是什麼意思
在C語言中printf( )是專門用於輸出的語句。 用法如下:
1、printf()函數是格式化輸出函數,一般用於向標准輸出設備按規定格式輸出信息。
2、printf()函數的調用格式為:printf("", )。
3、格式輸出,它是c語言中產生格式化輸出的函數(在 stdio.h 中定義)。用於向終端(顯示器,控制台等)輸出字元。
(2)c語言printf字元串擴展閱讀:
格式化字元串包含三種對象,分別為:
(1)字元串常量;
(2)格式控制字元串;
(3)轉義字元。
字元串常量原樣輸出,在顯示中起提示作用。輸出表列中給出了各個輸出項,要求格式控制字元串和各輸出項在數量和類型上應該一一對應。其中格式控制字元串是以%開頭的字元串,在%後面跟有各種格式控制符,以說明輸出數據的類型、寬度、精度等。
註:本文的所有示例代碼均在Linux環境下以g++ 4.4.6編譯成64位程序的執行。
③ C語言怎麼用printf輸出字元串。
printf函數的一般使用形式為:printf("輸出格式",輸出項系列);要輸出字元串,則只需寫出相應的輸出格式以及輸出項系列即可,其中輸出格式為%s,輸出項系列為字元串名。
printf函數輸出字元串的例子如下:
#include<stdio.h>
void main()
{char str[10]="ABCD";
printf("%s",str);}
上述程序輸出了字元串 ABCD
④ printf在c語言中是什麼意思
在C語言中printf( )是專門用於輸出的語句。 用法如下:
1、printf()函數是格式化輸出函數,一般用於向標准輸出設備按規定格式輸出信息。
2、printf()函數的調用格式為:printf("", )。
3、格式輸出,它是c語言中產生格式化輸出的函數(在 stdio.h 中定義)。用於向終端(顯示器,控制台等)輸出字元。
格式化字元串包含三種對象,分別為:
(1)字元串常量;
(2)格式控制字元串;
(3)轉義字元。
字元串常量原樣輸出,在顯示中起提示作用。輸出表列中給出了各個輸出項,要求格式控制字元串和各輸出項在數量和類型上應該一一對應。其中格式控制字元串是以%開頭的字元串,在%後面跟有各種格式控制符,以說明輸出數據的類型、寬度、精度等。
註:本文的所有示例代碼均在Linux環境下以g++ 4.4.6編譯成64位程序的執行。
⑤ c語言中printf的用法
c語言中printf的用法的用法你知道嗎?下面我就跟你們詳細介紹下c語言中printf的用法的用法,希望對你們有用。
c語言中printf的用法的用法如下:
Printf和Scan函數的使用方法
一 printf()函數是格式化輸出函數, 一般用於向標准輸出設備按規定格式輸出
信息。在編寫程序時經常會用到此函數。printf()函數的調用格式為:
printf("<格式化字元串>", <參量表>);
其中格式化字元串包括兩部分內容: 一部分是正常字元, 這些字元將按原
樣輸出; 另一部分是格式化規定字元, 以"%"開始, 後跟一個或幾個規定字元,
用來確定輸出內容格式。
參量表是需要輸出的一系列參數, 其個數必須與格式化字元串所說明的輸出
參數個數一樣多, 各參數之間用","分開, 且順序一一對應, 否則將會出現意想
不到的錯誤。
格式化字元串的格式是:
%[標志][輸出最小寬度][.精度][長度]格式字元
1. 標志:標志字元為-、+、#、空格四種,其意義下表所示:
標志 意義
- 結果左對齊,右邊填空格
+ 輸出符號(正號或負號)
空格 輸出值為正時冠以空格,為負時冠以負號
# 對c,s,d,u類無影響;對o類,在輸出時加前綴o;對x類,在輸出時加前綴0x;對e,g,f 類當結果有小數 時才給出小數點(??????)
例1:
#i nclude
main()
{
int a=100;
float b=123.255;
printf("a=%d ",a);
printf("a=d ",a);
printf("a=%-10d ",a);
printf("a=%+d ",a);
printf("a=% d ",a);
printf("a=%#o ",a);
printf("a=%#x ",a);
printf("b=%#f ",b);
}
運行結果
a=100
a= 100
a=100
a=+100
a= 100
a=0144
a=0x64
b=123.254997 (?????)
2.輸出最小寬度:用十進制整數來表示輸出的最少位數。(至少要輸出這么多位!)
若實際位數多於定義的寬度:則按實際位數輸出。
若實際位數少於定義的寬度:則右對齊,左邊留空。
有負號,左對齊,右邊留空
表示寬度的數字以0開始,則右對齊,左邊留空。
例2 #i nclude
main()
{
int a=3456;
printf("a== ",a); //若實際位數多於定義的寬度:則按實際位數輸出
printf("a=d ",a); //若實際位數少於定義的寬度:則右對齊,左邊留空
printf("a=%-10d ",a); //若實際位數少於定義的寬度:有負號,左對齊,右邊留空
printf("a=0d ",a); //若實際位數少於定義的寬度:表示寬度的數字以0開始,則右對齊,左邊留空
printf("a=%-010d ",a); //左對齊,0無意義。
}
運行結果:
a=3456
a= 3456
a=3456
a=0000003456
a=3456
3.精度:精度格式符以“.”開頭,後跟十進制整數。意義是:
如果輸出數字,則表示小數的位數;若實際位數大於所定義的精度數,則四捨五入。若不足則補0;
如果輸出的是字元,則表示輸出字元的個數;若實際位數大於所定義的精度數,則截去超過的部分。
例3:
#i nclude
main()
{
printf("%.3f ",12.3456);
printf("%.9f ",12.3456);
printf("%.3s ","abcdefg");
printf("%.9s ","abcdefg");
}
運行結果:
12.346 //四捨五入到小數點後三位
12.345600000 //不足補0
abc
abcdefg
4.長度:長度格式符為h,l兩種,h表示按短整型量輸出,l表示按長整型量輸出?????
5.Turbo C2.0提供的格式字元如下:
━━━━━━━━━━━━━━━━━━━━━━━━━━
符號 作用
──────────────────────────
%c 單個字元
%d 十進制有符號整數
%e 以“科學記數法”的形式輸出十進制的浮點數 如2.451e+02
%f 輸出十進制浮點數,不帶域寬時,保留6位小數
%g 選用e或f格式中較短的一個輸出十進制浮點數,不輸出無效零
%0 無輸出無符號八進制整數
%p 指針的值
%s 輸出字元串
%u 輸出無符號十進制整數
%x, %X 輸出無符號十六進制整數 (不輸出前綴Ox)
━━━━━━━━━━━━━━━━━━━━━━━━━━
2. 一些特殊規定字元
━━━━━━━━━━━━━━━━━━━━━━━━━━
字元 作用
──────────────────────────
換行
f 清屏並換頁
回車
Tab符
xhh 表示一個ASCII碼用16進表示,
其中hh是1到2個16進制數
━━━━━━━━━━━━━━━━━━━━━━━━━━
使用這些轉義字元時不需要加上%,可單獨使用!
由本節所學的printf()函數, 並結合上一節學習的數據類型, 編制下面的程
序, 以加深對Turbo C2.0數據類型的了解。
例1
#i nclude
#i nclude
int main()
{
char c, s[20], *p;
int a=1234, *i;
float f=3.141592653589;
double x=0.12345678987654321;
p="How do you do";
strcpy(s, "Hello, Comrade");
*i=12;
c='x41';
printf("a=%d ", a);
printf("a=m ", a);
printf("a=d ", a);
printf("a=- ", a);
printf("*i=M ", *i);
printf("*i=%-4d ", *i);
printf("i=%p ", i);
printf("f=%f ", f);
printf("f=6.4f ", f);
printf("x=%lf ", x);
printf("x=.16lf ", x);
printf("c=%c ", c);
printf("c=%x ", c);
printf("s[]=%s ", s);
printf("s[]=%6.9s ", s);
printf("s=%p ", s);
printf("*p=%s ", p);
printf("p=%p ", p);
getch();
retunr 0;
}
其他需要注意的一些問題:
1.如果用浮點數表示字元或整型量的輸出格式, 小數點後的數字代表最大寬度,
小數點前的數字代表最小寬度。
例如: %6.9s 表示顯示一個長度不小於6且不大於9的字元串。若大於9, 則第9個字元以後的內容將被刪除。
2.使用printf函數時還要注意一個問題,那就是輸出表列中的求值順序。不同的編譯系統不一定相同,可以從左到右,也可從右到左。Turbo C是按從右到左進行的。請看下面兩個例子:
例1
main(){
int i=8;
printf("%d %d %d %d %d %d ",++i,--i,i++,i--,-i++,-i--);
}
運行結果
8
7
7
8
-7
-8
例2
main(){
int i=8;
printf("%d ",++i);
printf("%d ",--i);
printf("%d ",i++);
printf("%d ",i--);
printf("%d ",-i++);
printf("%d ",-i--);
}
運行結果:
9
8
8
9
-8
-9
這兩個程序的區別是用一個printf語句和多個printf 語句輸出。但從結果可以看出是不同的。為什麼結果會不同呢?就是因為printf函數對輸出表中各量求值的順序是自右至左進行的。在第一例中,先對最後一項“-i--”求值,結果為-8,然後i自減1後為7。 再對“-i++”項求值得-7,然後i自增1後為8。再對“i--”項求值得8,然後i再自減1後為7。再求“i++”項得7,然後i再自增1後為8。 再求“--i”項,i先自減1後輸出,輸出值為7。 最後才求輸出表列中的第一項“++i”,此時i自增1後輸出8。
但是必須注意,求值順序雖是自右至左,但是輸出順序還是從左至右,因此得到的結果是上述輸出結果。
補充:最近在調試程序時發現一段代碼如下:
printf(sFormat,"%%0?",THE_NUMBER_LEN);
輸出數組後發現sFormat = d;其中宏THE_NUMBER_LEN定義的為4,發現如果需要通過在printf轉化的數組中出現%,那麼就使用%%來代替,且後面的所有字元都會直接放入sFormat數組中一直遇到新的%。只有碰到“%+特定字元”,才會把右邊對應的變數放入進來。
例如: printf(sFormat,"ABC%%d%d%%s?bc",THE_NUMBER_LEN,6);輸出為ABC?%s6abc;
還有就是發現如果是修改成%0?,輸出的字元串就變成 ?,這樣我猜想就是在printf函數時,碰到第一個%0後知道再遇見下一個%前,如果中間沒有特定字元d,s,e,f等,通通變成空格,而我在%中間增加兩個的非特殊字元後,發現?前面的空格急劇增加,原因就不清楚。故兩%之間不能增加其他非特殊字元。
二 Scan函數
數
scanf()函數是格式化輸入函數, 它從標准輸入設備(鍵盤) 讀取輸入的信息。
其調用格式為:
scanf("<格式化字元串>", <地址表>);
格式化字元串包括以下三類不同的字元;
1. 格式化說明符: 格式化說明符與printf()函數中的格式說明符基本相同。
2. 空白字元: 空白字元會使scanf()函數在讀操作中略去輸入中的一個或多
個空白字元。
3. 非空白字元: 一個非空白字元會使scanf()函數在讀入時剔除掉與這個非
空白字元相同的字元。
注意:(1)地址表是需要讀入的所有變數的地址, 而不是變數本身:
----如果是一般的變數,通常要在變數名前加上"&";但輸出時是用變數名
----如果是數組,用數組名就代表了該數組的首地址;輸出時也是用數組名
----如果是指針,直接用指針名本身,不要加上“*”;輸出時也用該指針即可。
例1:
各個變數的地址之間同","分開。
main()
{
int i;
char *p, str[20];
scanf("%d", &i);
scanf("%s", p);
scanf("%s", str);
printf("i=%d ",i);
printf("%s ", p);
printf("%s ", str);
}
(2)scanf函數中是否包含空白/非空白字元導致輸入格式的不同
如:scanf("%d,%d",&i,&j); scanf中有,所以輸入的格式應該是5,6==>i=5,j=6
scanf("%d%d",&i,&j); 可以用空格或回車來分隔兩個輸入 如 5 6==>i=5,j=6
scanf("%d %d",&i,&j); 同上
(3) 實際使用scanf()函數時存在一個問題, 下面舉例進行說明:
當使用多個scanf()函數連續給多個字元變數輸入時, 例如:
main()
{
char c1, c2;
scanf("%c", &c1);
scanf("%c", &c2);
printf("c1 is %c, c2 is %c", c21, c2);
}
運行該程序, 輸入一個字元A後回車 (要完成輸入必須回車), 在執行scanf
("%c", &c1)時, 給變數c1賦值"A", 但回車符仍然留在緩沖區內, 執行輸入語句
scanf("%c", &c2)時, 變數c2輸出的是一空行, 如果輸入AB後回車, 那麼輸出結
果為: c1 is A, c2 is B。
要解決以上問題, 可以在輸入函數前加入清除函數fflush()( 這個函數的使
用方法將在本節最後講述)。修改以上程序變成:
#i nclude
main()
{
char c1, c2;
scanf("%c", &c1);
fflush(stdin);
scanf("%c", &c2);
printf("c1 is %c, c2 is %c", c1, c2);
}
在輸入字元數據時,若格式控制串中無非格式字元,則認為所有輸入的字元均為有效字元。
例如:scanf("%c%c%c",&a,&b,&c);
輸入為:d e f
則把'd'賦予a, ' ' 賦予b,'e'賦予c。
只有當輸入為: def
時,才能把'd'賦於a,'e'賦予b,'f'賦予c。
如果在格式控制中加入空格作為間隔,
如:scanf ("%c %c %c",&a,&b,&c);
則輸入時各數據之間可加空格。
例4
main(){
char a,b;
printf("input character a,b ");
scanf("%c%c",&a,&b);
printf("%c%c ",a,b);
}
由於scanf函數"%c%c"中沒有空格,輸入M N,結果輸出只有M。而輸入改為MN時則可輸出MN兩字元。
(4)格式字元串的一般形式為:
%
[輸入數據寬度][長度]類型
其中有方括弧[]的項為任選項。各項的意義如下:
1)類型:表示輸入數據的類型,其格式符和意義如下表所示。
格式 字元意義
d 輸入十進制整數
o 輸入八進制整數
x 輸入十六進制整數
u 輸入無符號十進制整數
f或e 輸入實型數(用小數形式或指數形式)
c 輸入單個字元
s 輸入字元串
2)“*”符:用以表示該輸入項,讀入後不賦予相應的變數,即跳過該輸入值。
如:scanf("%d %*d %d",&a,&b);
當輸入為:1 2 3時,把1賦予a,2被跳過,3賦予b。
3)寬度:用十進制整數指定輸入的寬度(即字元數)。
例如:
scanf("]",&a);
輸入:12345678
只把12345賦予變數a,其餘部分被截去。
又如:scanf("MM",&a,&b);
輸入:12345678
將把1234賦予a,而把5678賦予b。
例:
main()
{
int a,b;
scanf("MM",&a,&b);
printf("a=%d,b=%d",a,b);
}
輸入 12345 67890
運行結果 a=1234,b=5
4) 長度:長度格式符為l和h,l表示輸入長整型數據(如%ld) 和雙精度浮點數(如%lf)。h表示輸入短整型數據。
使用scanf函數還必須注意以下幾點:
1)scanf函數中沒有精度控制,如:scanf("%5.2f",&a);是非法的。不能企圖用此語句輸入小數為2位的實數。
2)在輸入多個數值數據時,若格式控制串中沒有非格式字元作輸入數據之間的間隔則可用空格,TAB或回車作間隔。C編譯在碰到空格,TAB,回車或非法數據(如對“%d”輸入“12A”時,A即為非法數據)時即認為該數據結束。
⑥ c語言里怎麼使用printf
printf()函數的調用格式為: printf("<格式化字元串>", <參量表>)。
其中格式化字元串包括兩部分內容:一部分是正常字元,這些字元將按原樣輸出; 另一部分是格式化規定字元,以"%"開始,後跟一個或幾個規定字元,用來確定輸出內容格式。
參量表是需要輸出的一系列參數,其個數必須與格式化字元串所說明的輸出參數個數一樣多, 各參數之間用","分開, 且順序一一對應,否則將會出現意想不到的錯誤。
比如:
inta=1234;
printf("a=%d ",a);
輸出結果為a=1234。
scanf()是C語言中的一個輸入函數。與printf函數一樣,都被聲明在頭文件stdio.h里,因此在使用scanf函數時要加上#include <stdio.h>。
intscanf(constchar*restrictformat,...);
函數scanf() 是從標准輸入流stdin (標准輸入設備,一般指向鍵盤)中讀內容的通用子程序,可以說明的格式讀入多個字元,並保存在對應地址的變數中。
如:
scanf("%d%d",&a,&b);
函數返回值為int型,如果a和b都被成功讀入,那麼scanf的返回值就是2。
(6)c語言printf字元串擴展閱讀:
printf函數使用注意事項
1.域寬問題
%d:按整型數據的實際長度輸出。
如果想輸出指定寬度可以指定域寬,%md-->m域寬,列印出來以後,在控制台上,顯示m位;
如果我們要列印的數的位數如果超過我們設定m則原樣輸出;
如果我們要列印的數的位數如果小於我們設定的位數,則補空白,具體如下:
如果m為正數,則左對齊(左側補空白);
如果m為負數,則右對齊(右側補空白)。
2.轉義字元問題
如果想輸出字元"%",則應該在「格式控制」字元串中用連續兩個%表示。
如:printf("%f%%", 1.0/3);輸出結果: 0.333333%。
參考資料:printf()-網路
scanf-網路
⑦ printf在c語言中什麼意思
向屏幕輸出。
int i=123;
printf("%d",i); //表示以十進制整數格式輸出i的值。
printf()函數是格式化輸出函數, 一般用於向標准輸出設備按規定格式輸出信息。
printf()函數的調用格式為: printf("<格式化字元串>", <參量表>)。
格式輸出,它是c語言中產生格式化輸出的函數(在 stdio.h 中定義)。用於向終端(顯示器、控制台等)輸出字元。格式控制由要輸出的文字和數據格式說明組成。要輸出的的文字除了可以使用字母、數字、空格和一些數字元號以外,還可以使用一些轉義字元表示特殊的含義。
參數列表
在輸出時,普通字元將原樣不動地復制到標准輸出,轉換說明並不直接輸出而是用於控制 printf 中參數的轉換和列印。每個轉換說明都由一個百分號字元(%)開始,以轉換說明結束,從而說明輸出數據的類型、寬度、精度等。
printf 的格式控制字元串 format 中的轉換說明組成如下,其中的部分是可選的:%[flags][width][.precision][length]specifier,即:%[標志][最小寬度][.精度][類型長度]說明符 。轉換說明詳解見下文。
附加參數 -- 根據不同的 format 字元串,函數可能需要一系列的附加參數,每個參數包含了一個要被插入的值,替換了 format 參數中指定的每個 % 標簽。參數的個數應與 % 標簽的個數相同。
以上內容參考:網路-printf
⑧ printf在C語言中什麼意思
printf 是指格式化輸出函數,主要功能是向標准輸出設備按規定格式輸出信息。
printf 是C語言標准庫函數,定義於頭文件 <stdio.h>。printf 函數的一般調用格式為:printf("<格式化字元串>", <參量表>)。輸出的字元串除了可以是字母、數字、空格和一些數字元號以外,還可以使用一些轉義字元表示特殊的含義。
注意事項:
1、函數返回值
printf 函數的返回值為其輸出字元串常量的字元數(注意字元數與字數的區別),注意計數針對所有的列印字元,包括空格和不可見的換行字元(不包括字元串的空字元)。
2、列印較長字元串
有時printf 語句會很長,以至於不能在一行被放下,如果我們必須分割一個字元串,有以下三種方式可以選擇。需要注意的是,我們可以在字元串中使用 " " 換行符來表示換行字元,但是在字元串中不能通過回車鍵來產生實際的換行字元。
⑨ C語言中的printf是什麼意思
printf()是C語言標准庫函數,用於將格式化後的字元串輸出到標准輸出。標准輸出,即標准輸出文件,對應終端的屏幕。printf()申明於頭文件stdio.h。
函數原型:
int printf ( const char * format, ... )。
返回值:
正確返回輸出的字元總數,錯誤返回負值,與此同時,輸入輸出流錯誤標志將被置值,可由指示器ferror來檢查輸入輸出流的錯誤標志。
(9)c語言printf字元串擴展閱讀
printf()函數的調用格式為:printf("格式化字元串",輸出表列)。
格式化字元串包含三種對象,分別為:
(1)字元串常量;
(2)格式控制字元串;
(3)轉義字元。
字元串常量原樣輸出,在顯示中起提示作用。輸出表列中給出了各個輸出項,要求格式控制字元串和各輸出項在數量和類型上應該一一對應。其中格式控制字元串是以%開頭的字元串,在%後面跟有各種格式控制符,以說明輸出數據的類型、寬度、精度等。
註:本文的所有示例代碼均在Linux環境下以g++ 4.4.6編譯成64位程序的執行。