c語言中printf直接列印兩個函式介面的返回值問題

2021-12-23 01:32:25 字數 5741 閱讀 6503

1樓:

輸出應該是sunday monday 第一行**是定義一個靜態的指標字串! 第3行是定義一個靜態函式 strcpy(buf, msg[index]);函式的意思吧msg【index]複製到buf字串裡,然後現在計入main函式,輸出 計入函式get_day傳入引數0進入函式就是msg指標陣列msg第一個引數是sunday所以輸出sunday。第二個也一樣 傳入1 同上

2樓:北極沒有雪

列印出來的結果是sunday sunday、printf的引數壓棧順序是自右至左, 也就是那兩個函式呼叫是先執行右邊的後執行左邊的,然後printf才會列印出內容。

然後就是get_day()這個函式是不可重入函式,函式的返回值是buf這個靜態陣列的的首地址。而static變數不管宣告在哪,他的空間都是分配在全域性靜態區的。也就是在整個程式宣告週期中get_day()返回的地址永遠都是buf的首地址(不會改變)。

所以你呼叫這個printf後, 實際上buf這個陣列裡面存的是最後一個執行的結果。也就是get_day(0).所以得到的結果是兩個sunday

3樓:匿名使用者

1,printf()函式是格式化輸出函式, 一般用於向標準輸出裝置按規定格式輸出資訊。

2,printf()函式的呼叫格式為: printf("《格式化字串》", 《參量表》)。

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

格式控制由要輸出的文字和資料格式說明組成。要輸出的的文字除了可以使用字母、數字、空格和一些數字符號以外,還可以使用一些轉義字元表示特殊的含義。

4,作用:在c語言中產生格式化輸出的函式(定義在 stdio.h 中),其向終端(顯示器、控制檯等)輸出字元。

windows api中那個函式可以格式化輸出像c語言中的printf

4樓:great雨點

#include

void main()

就是這樣的,因為c語言中字元型和int型的資料是可以交換的,你所謂的68是d這個字元的ascii碼,希望你能明白。

c語言中scanf和printf都是輸出函式,兩者有什麼區別呢

5樓:匿名使用者

兩者完全不同,scanf是輸入函

數,printf是輸出函式,所以會經常同時出現。兩者也沒有可比性,需要弄清他們的概念。

1.scanf()是c語言中的一個輸入函式。函式 scanf() 是從標準輸入流stdio (標準輸入裝置,一般指向鍵盤)中讀內容的通用子程式,可以說明的格式讀入多個字元,並儲存在對應地址的變數中。

比如:scanf("%d %d",&a,&b);

函式返回值為int型。如果a和b都被成功讀入,那麼scanf的返回值就是2;

如果只有a被成功讀入,返回值為1;

如果a和b都未被成功讀入,返回值為0;

如果遇到錯誤或遇到end of file,返回值為eof。end of file為ctrl+z 或者ctrl+d。

2.printf()函式是格式化輸出函式, 它是c語言中產生格式化輸出的函式(在 stdio.h 中定義)。

用於向終端(顯示器、控制檯等)輸出字元。格式控制由要輸出的文字和資料格式說明組成。

printf 函式的一般形式為:

int printf(const char *format, [argument]);

format 引數是包含三種物件型別的一個字串:

(1)無格式字元複製到輸出流;

(2)轉換規範,每個規範導致在值引數列表中檢索 1 個或更多個項;

(3)轉義序列。

[argument]包含需要輸出的資料,可以是常量(字元常量、數字常量、字串常量),變數,以及運算式。此處的資料應當與前面的format中的格式控制符一一對應(如果不對應會產生錯誤)。

例子:#include

int main()

6樓:何度千尋

在使用scanf和printf函式時要加上#include 。其中scanf()是格式輸入函式,printf()函式是格式化輸出函式。

其通常的用法如下:

#include

int main()

7樓:匿名使用者

一、scanf函式的一般形式

scanf函式是一個標準庫函式,它的函式原型在標頭檔案“stdio.h”中,與printf函式相同,c語言也允許在使用scanf函式之前不必包含stdio.**件。

scanf函式的一般形式為: scanf(“格式控制字串”,地址表列); 其中,格式控制字串的作用與printf函式相同,但不能顯示非格式字串, 也就是不能顯示提示字串。地址表列中給出各變數的地址。

地址是由地址運算子“&”後跟變數名組成的。例如,&a,&b分別表示變數a和變數b 的地址。這個地址就是編譯系統在記憶體中給a,b變數分配的地址。

在c語言中,使用了地址這個概念,這是與其它語言不同的。 應該把變數的值和變數的地址這兩個不同的概念區別開來。變數的地址是c編譯系統分配的,使用者不必關心具體的地址是多少。

變數的地址和變數值的關係如下: &a--->a567 a為變數名,567是變數的值,&a是變數a的地址。在賦值表示式中給變數賦值,如:

a=567 在賦值號左邊是變數名,不能寫地址,而scanf函式在本質上也是給變數賦值,但要求寫變數的地址,如&a。 這兩者在形式上是不同的。&是一個取地址運算子,&a是一個表示式,其功能是求變數的地址。

void main()

注意&的用法!

在本例中,由於scanf函式本身不能顯示提示串,故先用printf語句在螢幕上輸出提示,請使用者輸入a、b、c的值。執行scanf語句,則退出tc螢幕進入使用者螢幕等待使用者輸入。使用者輸入7、8、9後按下回車鍵,此時,系統又將返回tc螢幕。

在scanf語句的格式串中由於沒有非格式字元在“%d%d%d”之間作輸入時的間隔, 因此在輸入時要用一個以上的空格或回車鍵作為每兩個輸入數之間的間隔。

如: 7 8 9或 7

89格式字串

格式字串的一般形式為: %[*][輸入資料寬度][長度]型別 其中有方括號的項為任選項。各項的意義如下:

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("%5d",&a);

輸入:12345678

只把12345賦予變數a,其餘部分被截去。又如: scanf("%4d%4d",&a,&b);

輸入:12345678將把1234賦予a,而把5678賦予b。

4.長度

長度格式符為l和h,l表示輸入長整型資料(如%ld) 和雙精度浮點數(如%lf)。h表示輸入短整型資料。

使用scanf函式還必須注意以下幾點:

a. scanf函式中沒有精度控制,如: scanf("%5.2f",&a); 是非法的。不能企圖用此語句輸入小數為2位的實數。

b. scanf中要求給出變數地址,如給出變數名則會出錯。如 scanf("%d",a);是非法的,應改為scnaf("%d",&a);才是合法的。

c. 在輸入多個數值資料時,若格式控制串中沒有非格式字元作輸入資料之間的間隔則可用空格,tab或回車作間隔。c編譯在碰到空格,tab,回車或非法資料(如對“%d”輸入“12a”時,a即為非法資料)時即認為該資料結束。

d. 在輸入字元資料時,若格式控制串中無非格式字元,則認為所有輸入的字元均為有效字元。例如:

scanf("%c%c%c",&a,&b,&c);

輸入為:

d e f

則把'd'賦予a, 'f'賦予b,'e'賦予c。只有當輸入為:

def時,才能把'd'賦於a,'e'賦予b,'f'賦予c。 如果在格式控制中加入空格作為間隔,如 scanf ("%c %c %c",&a,&b,&c);則輸入時各資料之間可加空格。

void main()

scanf("'c14f14%c%c",&a,&b);

printf("%c%c ",a,b);

由於scanf函式"%c%c"中沒有空格,輸入m n,結果輸出只有m。

而輸入改為mn時則可輸出mn兩字元,見下面的輸入運**況:

input character a,b

mnmn

void main()

scanf("%c %c",&a,&b);

本例表示scanf格式控制串"%c %c"之間有空格時, 輸入的資料之間可以有空格間隔。e. 如果格式控制串中有非格式字元則輸入時也要輸入該非格式字元。

例如:scanf("%d,%d,%d",&a,&b,&c); 其中用非格式符“ , ”作間隔符,故輸入時應為: 5,6,7

又如

則輸入應為

a=5,b=6,c=7g. 如輸入的資料與輸出的型別不一致時,雖然編譯能夠通過,但結果將不正確。

void main()

由於輸入資料型別為整型, 而輸出語句的格式串中說明為長整型,因此輸出結果和輸入資料不符。如改動程式如下:

void main()

執行結果為:

input a long integer

1234567890

1234567890 當輸入資料改為長整型後,輸入輸出資料相等。

鍵盤輸入函式

getchar函式getchar函式的功能是從鍵盤上輸入一個字元。其一般形式為: getchar(); 通常把輸入的字元賦予一個字元變數,構成賦值語句,如:

char c;

c=getchar();#include

void main()

使用getchar函式還應注意幾個問題:

1.getchar函式只能接受單個字元,輸入數字也按字元處理。輸入多於一個字元時,只接收第一個字元。

2.使用本函式前必須包含檔案“stdio.h”。

3.在tc螢幕下執行含本函式程式時,將退出tc 螢幕進入使用者螢幕等待使用者輸入。輸入完畢再返回tc螢幕。

void main()

輸入三個小寫字母

輸出其ascii碼和對應的大寫字母。

void main()

輸出各種資料型別的位元組長度。

二、printf printf的格式控制中,寬度是指輸出的資料要佔多少格,並不是說資料本身是多少格,比如我完全可以設定單獨的一個數字1佔20格.當然,設定的寬度如果比要輸出的數的實際寬度小的話,就失去作用了.比如12345,你設定寬度為4的話,它照樣輸出12345.

再比如這裡-3.2e+03的寬度是8,已經超過6了.這種情況,資料會原樣輸出,不管寬度.

至於是-3.2還是-3.22,我在自己電腦上執行結果是3.

22,而且根據我看過的書上的解釋,也應該是3.22.只能認為tc 2.

0的作者沒能很好地理解標準了,因此在tc 3.0的時候修正了這個錯誤.

最後,根據我所知道的,%e是以科學計數法形式輸出,而科學計數法規定了數的標準形式是整數位只有1位.所以你想控制數字位數的想法是無法實現的.

c語言中scanf和printf函式的問題關於雙精度

其實嚴格來說 兩個是一樣的 輸入的時候要用 lf 輸出的時候也要用 lf 的 f能輸出double 我也不懂 哈哈 你就按照 double 對應 lf 理解就可以了能輸出不影響 lf 不能輸入輸出double的時候再問也不遲 lf長浮點型,f浮點型 1f 小數點後1位 如果是 輸出printf 的輸...

c語言中單獨輸出轉義字元n如printfn代

格式字元裡 n 是換一來行的源意思。printf nabc 先bai 換一行,再列印du字元abc.printf abc n 先打zhi印字元abc,再換一行.printf nabc n 先 換一行,再列印字元abc,然後dao再換一行。是printf n 就是換行的意思 沒有區別,都是換行的意思 ...

c語言中printf語句以小數形式輸出單 雙精度實數的問題

這個問題其實屬於計算機組成原理的範疇了,你需要先認識到浮點數是如何儲存的。目前已知的所有的c c 編譯器都是按照ieee 國際電子電器工程師協會 制定的ieee 浮點數表示法來進行運算的。這種結構是一種科學表示法,用符號 正或負 指數和尾數來表示,底數被確定為2,也就是說是把一個浮點數表示為尾數乘以...