c語言子函數中printf,c語言子函數中定義數組

本文目錄一覽:

在C語言里printf是什麼意思?怎麼用??

在C語言中printf( )是專門用於輸出的語句。 用法如下:

1、printf()函數是格式化輸出函數,一般用於向標準輸出設備按規定格式輸出信息。

2、printf()函數的調用格式為: printf("", )。

3、格式輸出,它是c語言中產生格式化輸出的函數(在 stdio.h 中定義)。用於向終端(顯示器,控制台等)輸出字元。

c語言中scanf()是專門輸入的語句。用法如下:

1、scanf(“%d %lf %Lf”,a,b,c);  //輸入int型變數a,double型變數b了,long double型變數c,並依” “(空格)做為間隔 。

2、scanf(“%f,%c”,d,e);    //輸入float型變數d,char型變數e,並依”,”(逗號)做為間。

3、%o,%x分別為輸入8進位,16進位。

printf在C語言中什麼意思

printf 是指格式化輸出函數,主要功能是向標準輸出設備按規定格式輸出信息。

printf 是C語言標準庫函數,定義於頭文件 stdio.h。printf 函數的一般調用格式為:printf(“格式化字元串”, 參量表)。輸出的字元串除了可以是字母、數字、空格和一些數字元號以外,還可以使用一些轉義字元表示特殊的含義。

注意事項:

1、函數返回值

printf 函數的返回值為其輸出字元串常量的字元數(注意字元數與字數的區別),注意計數針對所有的列印字元,包括空格和不可見的換行字元(不包括字元串的空字元)。

2、列印較長字元串

有時printf 語句會很長,以至於不能在一行被放下,如果我們必須分割一個字元串,有以下三種方式可以選擇。需要注意的是,我們可以在字元串中使用 “\n” 換行符來表示換行字元,但是在字元串中不能通過回車鍵來產生實際的換行字元。

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()是C語言標準庫函數,用於將格式化後的字元串輸出到標準輸出。標準輸出,即標準輸出文件,對應終端的屏幕。printf()申明於頭文件stdio.h。

函數原型:

int printf ( const char * format, ... )。

返回值:

正確返回輸出的字元總數,錯誤返回負值,與此同時,輸入輸出流錯誤標誌將被置值,可由指示器ferror來檢查輸入輸出流的錯誤標誌。

擴展資料

printf()函數的調用格式為:printf("格式化字元串",輸出表列)。

格式化字元串包含三種對象,分別為:

(1)字元串常量;

(2)格式控制字元串;

(3)轉義字元。

字元串常量原樣輸出,在顯示中起提示作用。輸出表列中給出了各個輸出項,要求格式控制字元串和各輸出項在數量和類型上應該一一對應。其中格式控制字元串是以%開頭的字元串,在%後面跟有各種格式控制符,以說明輸出數據的類型、寬度、精度等。

註:本文的所有示例代碼均在Linux環境下以g++ 4.4.6編譯成64位程序的執行。

原創文章,作者:小藍,如若轉載,請註明出處:https://www.506064.com/zh-tw/n/306171.html

(0)
打賞 微信掃一掃 微信掃一掃 支付寶掃一掃 支付寶掃一掃
小藍的頭像小藍
上一篇 2025-01-02 12:00
下一篇 2025-01-02 12:00

相關推薦

  • Python導入數組

    本文將為您詳細闡述Python導入數組的方法、優勢、適用場景等方面,並附上代碼示例。 一、numpy庫的使用 numpy是Python中一個強大的數學庫,其中提供了非常豐富的數學函…

    編程 2025-04-29
  • AES加密解密演算法的C語言實現

    AES(Advanced Encryption Standard)是一種對稱加密演算法,可用於對數據進行加密和解密。在本篇文章中,我們將介紹C語言中如何實現AES演算法,並對實現過程進…

    編程 2025-04-29
  • Python3定義函數參數類型

    Python是一門動態類型語言,不需要在定義變數時顯示的指定變數類型,但是Python3中提供了函數參數類型的聲明功能,在函數定義時明確定義參數類型。在函數的形參後面加上冒號(:)…

    編程 2025-04-29
  • Python返回數組:一次性搞定多種數據類型

    Python是一種多用途的高級編程語言,具有高效性和易讀性的特點,因此被廣泛應用於數據科學、機器學習、Web開發、遊戲開發等各個領域。其中,Python返回數組也是一項非常強大的功…

    編程 2025-04-29
  • 學習Python對學習C語言有幫助嗎?

    Python和C語言是兩種非常受歡迎的編程語言,在程序開發中都扮演著非常重要的角色。那麼,學習Python對學習C語言有幫助嗎?答案是肯定的。在本文中,我們將從多個角度探討Pyth…

    編程 2025-04-29
  • Python定義函數判斷奇偶數

    本文將從多個方面詳細闡述Python定義函數判斷奇偶數的方法,並提供完整的代碼示例。 一、初步了解Python函數 在介紹Python如何定義函數判斷奇偶數之前,我們先來了解一下P…

    編程 2025-04-29
  • Python去掉數組的中括弧

    在Python中,被中括弧包裹的數據結構是列表,列表是Python中非常常見的數據類型之一。但是,有些時候我們需要將列表展開成一維的數組,並且去掉中括弧。本文將為大家詳細介紹如何用…

    編程 2025-04-29
  • Python中的隊列定義

    本篇文章旨在深入闡述Python中隊列的定義及其應用,包括隊列的定義、隊列的類型、隊列的操作以及隊列的應用。同時,我們也會為您提供Python代碼示例。 一、隊列的定義 隊列是一種…

    編程 2025-04-29
  • Python符號定義和使用方法

    本文將從多個方面介紹Python符號的定義和使用方法,涉及注釋、變數、運算符、條件語句和循環等多個方面。 一、注釋 1、單行注釋 # 這是一條單行注釋 2、多行注釋 “”” 這是一…

    編程 2025-04-29
  • Python操作數組

    本文將從多個方面詳細介紹如何使用Python操作5個數組成的列表。 一、數組的定義 數組是一種用於存儲相同類型數據的數據結構。Python中的數組是通過列表來實現的,列表中可以存放…

    編程 2025-04-29

發表回復

登錄後才能評論