C語言的輸入和輸出函數

C語言提供了兩個控制檯格式化輸入、輸出函數printf() 函數scanf() 函數,這兩個函數可以在標準輸入輸出設備上以各種不同的格式讀寫數據。printf()函數用來向標準輸出設備(屏幕)寫數據; scanf() 函數用來從標準輸入設備(鍵盤)上讀數據。

一、格式化輸出函數—printf()函數

printf()函數是格式化輸出函數,一般用於向標準輸出設備按規定格式輸出信息。在編寫程序時經常會用到此函數。printf()函數的調用格式爲:

printf("<格式化字符串>", <參量表>);

其中格式化字符串包括兩部分內容:一部分是正常字符,這些字符將按原樣輸出;另一部分是格式化規定字符,以 “%”開始,後跟一個或幾個規定字符,用來確定輸出內容格式。參量表是需要輸出的一系列參數,其個數必須與格式化字符串所說明的輸出參數個數一樣多,各參數之間用 “,”分開, 且順序一一對應,否則將會出現意想不到的錯誤。

1、格式化規定符
這裏寫圖片描述
特別注意: %0 和 %x 表示的都是 無符號的整形

說明:
(1)、可以在“%”和字母之間插進數字表示最大場寬。例如: %9.2f 表示輸出場寬爲9的浮點數,其中小數位爲2,整數位爲6,小數點佔一位,不夠9位右對齊。%8s 表示輸出8個字符的字符串,不夠8個字符右對齊。

(2)、可以控制輸出左對齊或右對齊,即在“%”和字母之間加入一個“-”號可說明輸出爲左對齊,否則默認爲右對齊。例如:%-7d 表示輸出7位整數左對齊。

(3)、對於字符串的長度或整型數位數超過說明的場寬,將按其實際長度輸出。但對浮點數,若整數部分位數超過了說明的整數位寬度,將按實際整數位輸出;若小數部分位數超過了說明的小數位寬度,則按說明的寬度以四捨五入輸出。

(4)、若想在輸出值前加一些0,就應在場寬項前加個0。例如:%04d 表示在輸出一個小於4位的數值時,將在前面補0使其總寬度爲4位。

(5)、如果用浮點數表示字符或整型量的輸出格式,小數點後的數字代表最大寬度,小數點前的數字代表最小寬度。例如:%6.9s 表示顯示一個長度不小於6且不大於9的字符串。若大於9,則第9個字符以後的內容將被刪除。

(6)、可以在“%”和字母之間加小寫字母l, 表示輸出的是長型數。例如: %ld 表示輸出long整數%lf 表示輸出double浮點數。

2、一些特殊規定字符
這裏寫圖片描述

例程:

#include <stdio.h>
#include <string.h> 

int main() 
{
    char c, s[20], *p;
    int a=1234, b, *i = &b; 
    float f=3.141592653589;
    double x=0.12345678987654321; 
    p="How do you do"; 
    strcpy(s,"Hello, Comrade");
    *i=12; 
    c='\x41';

    printf("a=%d\n", a);    /*結果輸出十進制整數a=1234*/ 
    printf("a=%6d\n", a);   /*結果輸出6位十進制數a= 1234*/ 
    printf("a=%06d\n", a);  /*結果輸出6位十進制數a=001234*/ 
    printf("a=%2d\n", a);   /*a超過2位, 按實際值輸出a=1234*/ 
    printf("*i=%4d\n", *i); /*輸出4位十進制整數*i= 12*/ 
    printf("*i=%-4d\n", *i);/*輸出左對齊4位十進制整數*i=12*/
    printf("i=%p\n", i);    /*輸出地址i=06E4*/ 
    printf("f=%f\n", f);    /*輸出浮點數f=3.141593*/ 
    printf("f=6.4f\n", f);  /*輸出6位其中小數點後4位的浮點數f=3.1416*/
    printf("x=%lf\n", x);   /*輸出長浮點數x=0.123457*/ 
    printf("x=%18.16lf\n", x);/*輸出18位其中小數點後16位的長浮點數x=0.1234567898765432*/
    printf("c=%c\n", c);    /*輸出字符c=A*/
    printf("c=%x\n", c);    /*輸出字符的ASCII碼值c=41*/ 
    printf("s[]=%s\n", s);  /*輸出數組字符串s[]=Hello, Comrade*/ 
    printf("s[]=%6.9s\n", s);/*輸出最多9個字符的字符串s[]=Hello, Co*/ 
    printf("s=%p\n", s);    /*輸出數組字符串首字符地址s=FFBE*/
    printf("*p=%s\n", p);   /* 輸出指針字符串p=How do you do*/ 
    printf("p=%p\n", p);    /*輸出指針的值p=0194*/ 

    getch(); 
    return 0; 
}

二、格式化輸入函數—scanf()函數

scanf()函數是格式化輸入函數,它從標準輸入設備(鍵盤) 讀取輸入的信息。其調用格式爲:

scanf("<格式化字符串>", <地址表>);

格式化字符串包括以下三類不同的字符;
1、格式化說明符:格式化說明符與printf()函數中的格式說明符基本相同。
2、空白字符:空白字符會使scanf()函數在讀操作中略去輸入中的一個或多個空白字符。
3、非空白字符:一個非空白字符會使scanf()函數在讀入時剔除掉與這個非空白字符相同的字符。

地址表是需要讀入的所有變量的地址,而不是變量本身。這與printf()函數完全不同,要特別注意。各個變量的地址之間同“,”分開。

例 1:

int i,j;
scanf("%d, %d", &i, &j);

上例中的scanf()函數先讀一個整型數,然後把接着輸入的逗號剔除掉,最後讀入另一個整型數。如果“,”這一特定字符沒有找到,scanf()函數就終止。若參數之間的分隔符爲空格,則參數之間必須輸入一個或多個空格。

幾點說明:
(1)、對於字符串數組或字符串指針變量,由於數組名和指針變量名本身就是地址,因此使用scanf()函數時,不需要在它們前面加上“&”操作符。

例2:

int main()
{
    char *p, str[20];
    scanf("%s", p);//本就是地址,無需加&
    scanf("%s", str);
    printf("%s\n", p);
    printf("%s\n", str);
}

(2)、可以在格式化字符串中的“%”各格式化規定符之間加入一個整數,表示任何讀操作中的最大位數。
如例2中若規定只能輸入10字符給字符串指針p, 則第一條scanf() 函數語句變爲:

scanf(“%10s”, p);

程序運行時一旦輸入字符個數大於10,p就不再繼續讀入,而後面的一個讀入函數即scanf(“%s”, str)就會從第11個字符開始讀入。實際使用scanf()函數時存在一個問題,下面舉例進行說明:
當使用多個scanf()函數連續給多個字符變量輸入時,例如:

例3:

int main()
{
  char c1, c2;
  scanf("%c", &c1);//注意是連續輸入字符變量char
  scanf("%c", &c2);
  printf("c1 is %c, c2 is %c", c2, c2);
}

運行該程序,輸入一個字符A後回車 (要完成輸入必須回車), 在執行scanf(“%c”, &c1)時, 給變量c1賦值”A”, 但回車符仍然留在緩衝區內,執行輸入語句scanf(”%c”, &c2)時, 變量c2輸出的是一空行,如果輸入AB後回車, 那麼輸出結果爲: c1 is A, c2 is B。要解決以上問題,可以在輸入函數前加入清除函數fflush(stdin)。修改以上程序變成:

#include<stdio.h>
int main()
{
  char c1, c2;
  scanf(“%c”, &c1);
  fflush(stdin);
  scanf(“%c”, &c2);
  printf(“c1 is %c, c2 is %c”, c1, c2);
}

三、非格式化輸入輸出函數

非格式化輸入輸出函數可以由上面講述的標準格式化輸入輸出函數代替,但這些函數編譯後代碼少,相對佔用內存也小,從而提高了速度,同時使用也比較方便。下面分別進行介紹。

1、 puts()函數
puts()函數用來向標準輸出設備(屏幕)寫字符串並換行,其調用格式爲:

puts(s);//s爲字符串變量(字符串數組名或字符串指針)

puts()函數的作用與語printf(“%s\n”, s)相同。

例:

int main()
{
  char s[20], *f;
  strcpy(s, "Hello! Turbo C2.0");
  f="Thank you";
  puts(s);
  puts(f);
}

說明:
(1)、puts()函數只能輸出字符串,不能輸出數值或進行格式變換。
(2)、可以將字符串直接寫入puts()函數中。如:puts(“Hello, Turbo C2.0”);

2、gets()函數
gets()函數用來從標準輸入設備(鍵盤)讀取字符串直到回車結束,但回車符不屬於這個字符串。其調用格式爲:

gets(s);//s爲字符串變量(字符串數組名或字符串指針)

gets(s)函數與scanf(“%s”, &s)相似,但不完全相同,使用scanf(“%s”,&s)函數輸入字符串時存在一個問題,就是如果輸入了空格會認爲輸入字符串結束,空格後的字符將作爲下一個輸入項處理,但gets() 函數將接收輸入的整個字符串直到回車爲止,gets()會吸收空格

例:

int main()
{
    char s[20], *f;
    printf("What's your name?\n");
    gets(s);  /*等待輸入字符串直到回車結束*/
    puts(s);  /*將輸入的字符串輸出*/
    puts("How old are you?");
    gets(f);
    puts(f);
 }

說明:
gets(s)函數中的變量s爲一字符串。如果爲單個字符, 編譯連接不會有錯誤, 但運行後會出現”Null pointer asignmemt”的錯誤。

3、putchar()函數
putchar()函數是向標準輸出設備輸出一個字符,其調用格式爲:

putchar(ch);//其中ch爲一個字符變量或常量

putchar()函數的作用等同於printf(“%c”, ch);

例:

int main()
{
    char c;          /*定義字符變量*/
    c='B';           /*給字符變量賦值*/
    putchar(c);      /*輸出該字符*/
    putchar('\x42'); /*輸出字母B*/
    putchar(0x42);   /*直接用ASCII碼值輸出字母B*/
 }

從本例中的連續四個字符輸出函數語句可以分清字符變量的不同賦值方法。

4、getchar()函數
getchar()函數也是從鍵盤上讀入一個字符,並回顯。它與前面函數的區別在於:getchar()函數等待輸入直到按回車才結束,回車前的所有輸入字符都會逐個顯示在屏幕上,但只有第一個字符作爲函數的返回值。getchar()函數的調用格式爲:

getchar();

例:

int main()
{
    char c;
    c=getchar();   /*從鍵盤讀入字符直到回車結束*/
    putchar(c);    /*顯示輸入的第一個字符*/
    getch();       /*等待按任一健*/
}

5、getch()和getche()函數
這兩個函數都是從鍵盤上讀入一個字符。其調用格式爲:

getch(); 
getche();

兩者的區別是getch()函數不將讀入的字符回顯在顯示屏幕上,而getche()函數卻將讀入的字符回顯到顯示屏幕上。

例:

int main()
{
    char c, ch;
    c=getch();     /*從鍵盤上讀入一個字符不回顯送給字符變量c*/
    putchar(c);    /*輸出該字符*/
    ch=getche();   /*從鍵盤上帶回顯的讀入一個字符送給字符變量ch*/
    putchar(ch);
}

利用回顯和不回顯的特點,這兩個函數經常用於交互輸入的過程中完成暫停等功能。如下例子所示:

例:

int main()
{
    char c, s[20];
    printf("Name:");
    gets(s);
    printf("Press any key to confinue...");
    getch(); /*等待輸入任一鍵,按鍵內容不會顯示*/
}
發佈了5 篇原創文章 · 獲贊 60 · 訪問量 18萬+
發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章