c语言中scanf的用法的用法你知道吗?下面小编就跟你们详细介绍下c语言中scanf的用法的用法,希望对你们有用。

c语言中scanf的用法的用法如下:

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语言scanf中 作用,c语言中scanf的用法相关推荐

  1. %s在c语言中有什么作用,c语言中%s的用法

    c语言中%s的用法 C语言是计算机软件领域非常经典的编程语言,unix.linux等众多操作系统均是由C语言编写而成.而在硬件控制.底层驱动等应用领域,C语言更是具有不可替代的作用.下面小编就跟你们详 ...

  2. c语言数组中define,c语言中#define的用法

    c语言中#define的用法 C语言中,可以用 #define 定义一个标识符来表示一个常量.其特点是:定义的标识符不占内存,只是一个临时的符号,预编译后这个符号就不存在了. 预编译又叫预处理.预编译 ...

  3. c语言new的作用,C语言中new的用法?

    温温酱 new是C++中用于动态内存分配的运算符,在C语言中一般使用malloc函数.new有三种用法:new operator.operator new.placement new1.new ope ...

  4. scanf在c语言中的作用,c语言中scanf的基本用法

    前言 scanf()是C语言的格式输入函数,和printf函数一样被声明在stdio.h头文件中,它的基本使用很简单: 1 int a; 2 scanf("%d",&a); ...

  5. sort在c语言中的作用,c语言中sort的用法详解.docx

    c语言中sort的用法详解.docx C语言中SORT的用法详解C语言的学习很多是比较复杂的,那么C语言中SORT的用法的用法你知道吗下面学习啦小编就跟你们详细介绍下C语言中SORT的用法的用法,希望 ...

  6. sprintf在c语言中的作用,c语言中sprintf的用法

    c语言中sprintf的用法的用法你知道吗?下面小编就跟你们详细介绍下c语言中sprintf的用法的用法,希望对你们有用. c语言中sprintf的用法的用法如下: sprintf函数的用法 1.该函 ...

  7. c语言atan的作用,C语言中的atan和atan2

    在C语言的math.h或C++中的cmath中有两个求反正切的函数atan(double x)与atan2(double y,double x)  他们返回的值是弧度 要转化为角度再自己处理下. 前者 ...

  8. c语言int作用,c语言中int的用法有哪些

    c语言中int的用法有哪些 C/C++编程语言中,int表示整型变量,是一种数据类型,用于定义一个整型变量,在不同编译环境有不同的大小,不同编译运行环境大小不同下面小编给大家整理了c语言中int的用法 ...

  9. c语言数组前const的作用,c语言中const的用法

    C语言作为一门新型高级编程语言,在计算机软件编程中具有较为广泛的应用和实现.下面小编就跟你们详细介绍下c语言中const的用法,希望对你们有用. c语言中const的用法如下: const的基本解释 ...

最新文章

  1. java处理视频_Java使用FFmpeg处理视频[视频直播三]
  2. 【Leetcode】岛屿问题(数量,周长,面积)
  3. linux ffmpeg加速和合并视频命令
  4. jsf按钮响应事件_如何从JSF获取JSON响应?
  5. PHP中一些有用的函数
  6. Qt:Qt使用WM_COPYDATA消息进行进程通信
  7. c#随机数生成编号_忘掉 Snowflake,感受一下性能高出587倍的全局唯一ID生成算法...
  8. embedding_Keras嵌入层
  9. 小米捐赠5亿启动“小米青年学者”项目 5年支持100所高校
  10. Python3爬取豆瓣图书Top250并写入txt文件当中
  11. mysql 代替分号_php – mysql FIND_IN_SET()用分号代替逗号
  12. Java的JAR包, EAR包 ,WAR包内部结构
  13. Luogu1373 小a和uim之大逃离
  14. android NFC getId()后进制转换
  15. 机器人阿郎_机械人阿郎
  16. 使用Kettle 进行行Oracle数据迁移时处理编码转换处理US7ASCII 编码
  17. pl0运行栈中间代码类P-code解析
  18. c++ 回车键无法换行
  19. 雷达人体存在感应器成品,广泛应用于感应灯控制,实时精准感知方案
  20. CSDN高校俱乐部“名师高校行”——贵州遵义站

热门文章

  1. div+css静态作业——洛阳城旅游(34页) HTML+CSS+JavaScript dreamweaver作业静态HTML网页设计模板 出游
  2. App推广经验|优派网助你了解读如何从零开始做好校园推广。
  3. 「美菜网」招高级前端工程师啦
  4. redis设置远程链接
  5. 用python求数列前n项的平方和
  6. 解决OSX 10.9 HD4000 屏幕亮度低的问题
  7. 案例|RAC 添加表空间误将数据文件放本地处理办法
  8. Golang 基础之基础语法梳理 (一)
  9. @程序员,这四个学习建议值得收藏
  10. 人类基因组本地化及简单分析