C语言 所有的类型输出符

作者&投稿:郭物 (若有异议请与网页底部的电邮联系)
C语言 所有的类型输出符~

%d:输入输出为整形
%ld
长整型
%hd短整型
%hu无符号整形
%u
%lu
%s:输入输出为字符串
%c字符
%f:输入输出为浮点型
%lf双精度浮点型

%a,%A 读入一个浮点值(仅C99有效)
%c 读入一个字符
%d 读入十进制整数
%i 读入十进制,八进制,十六进制整数
%o 读入八进制整数
%x,%X 读入十六进制整数
%s 读入一个字符串,遇空格、制表符或换行符结束。
%f,%F,%e,%E,%g,%G 用来输入实数,可以用小数形式或指数形式输入。
%p 读入一个指针
%u 读入一个无符号十进制整数
%n 至此已读入值的等价字符数
%[] 扫描字符集合
%% 读%符号

在C语言中,输入输出函数有着相当重要的地位,它是我们的程序与用户交互的唯一途径,现在我就将C语言中比较常见的几个输入输出函数介绍给大家,以下这些讲解都是针对VC调试平台。

(一) 格式化输入输出函数

(1)scanf( )格式化输入函数

格式输入函数scanf( )函数,它的格式为scanf(“格式字符串”,输入列表)。“格式字符串”包含三种类型的字符:a、格式字符,以%开头的字符,用以说明输入列表的数据以何种类型及格式的形式输入。b、普通字符,要求在输入时必须原样一起输入的字符。C、空白字符(空格、跳格键、回车键)作为相邻两个数据的默认分隔符。

在scanf( )函数中有以下地方需要注意:

[1] 在scanf()函数中的格式字符串不存在转义字符,所以:格式字符串中的字符除了格式字符外全部都要原样输入。

如:

int a;

scanf(“%d\n”,&a);如果我们想把10赋值给a,就需要在键盘上输入的是:

10\n回车,才能把10赋值给a,这里\n已经不是转义字符,而是普通字符。

[2] 输入列表的变量如果是基本类型(即整型、实型、字符型)一定要使用取地址符&(输入字符串到字符数组的情况除外),而且&后必须是变量,不允许是常量或表达式。

如:

int a,b;

scanf("%d%d",a,b); 这是不合法的。Scanf函数的作用是:按照a、b在内存的地址将a、b的值存进去。“&a”指a在内存中的地址。

[3] 输入数据时,企图规定精度

float a;

scanf("%.2f",&a);

这样做是不合法的,输入数据时不能规定精度,这里要记住一个程序是不能控制操作它的人来输入数据的精度的。

[4] 输入数据的方式与要求不符

① scanf("%d%d",&a,&b);

输入时,不能用逗号作两个数据间的分隔符,如下面输入不合法:3,4 输入数据时,在两个数据之间以一个或多个空格间隔,也可用回车键,跳格键tab。

②scanf("%d,%d",&a,&b);

C规定:如果在“格式控制”字符串中除了格式说明以外还有其它字符,则在输入数据时应输入与这些字符相同的字符。下面输入是合法的:3,4

此时不用逗号而用空格或其它字符是不对的。3 4

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

输入应如以下形式:a=3,b=4

[5] 输入字符的格式与要求不一致

在用“%c”格式输入字符时,“空格字符”和“转义字符”都作为有效字符输入。

scanf("%c%c%c",&c1,&c2,&c3);

如输入a b c

字符“a”送给c1,字符“ ”送给c2,字符“b”送给c3,因为%c只要求读入一个字符,后面不需要用空格作为两个字符的间隔。

[6] 使用格式字符”%c”录入单个字符时,空格和回车键等字符都会作为有效字符输入,所以需要注意fflush(stdin)的使用。

[7] 注意输入列表中的元素的个数要与格式字符串中的格式字符个数相同。

[8] 在输入长整形数据和双精度浮点数时,必须使用长度修饰符”l”。

[9] 不要在不该使用取地址符的地方使用取地址符。

如:char str[10];

Scanf(%c,&str);这里不应该加取地址符&。

(2)printf( )格式输出函数

格式输出函数printf( ),它的格式为printf(“格式字符串”,输出列表)。这里的格式字符串也包含三种类型的字符,但这里和scanf( )函数的字符稍有不同。这三种类型的字符分别是:a、格式字符,以%开头的字符,用以说明输出列表的数据以何种格式的形式输出。B、转义字符,提供特殊的格式化控制,由一个“\”和一个字符组成。反斜杠会使printf( )函数以特殊的方式解释一个字符。C、普通字符,除格式字符和转义字符外的其他字符。

在printf( )函数中有以下地方需要注意:

[1] 输出列表由若干个输出项组成,输出项可以是常量、变量,也可以是表达式。

[2] 格式字符串中的格式字符要与后边输出列表中的元素类型一一对应。

如:

float a=1.9999;

printf("%d",a);最终的输出结果是一些乱码。

再如:

int a=12;

printf("%f",a);最终的输出结果是0.000000,这里没有进行类型转换。

但是,如果想把上面的整数a以浮点数的形式输出,必须进行强制类型转换。如:

int a=12;

printf("%f",(float)a);输出的结果是12.000000。

[3] 格式字符串中的格式字符的个数要与输出列表中的元素个数相同。

如:

int a=12;

printf("%d, %d",a);将在屏幕上输出一个12以及一个乱码。

[4] 在以%.nf这样的格式进行输出浮点数时,有四舍五入。

如:

float a=1.9999;

printf(“%.2f”,a);最终的输出结果是2.00。

[5] 长度修饰符“l”在输出长整形数据时可不要,因为在VC中,long和int占用的字节长度都是4,所有可以不加上“l”。

[6] 格式符%±nd中,n表示一个十进制整数输出时在屏幕上占n个字符的宽度,如果n前面是+号,则表示输出的整数右对齐,那么输出的整数左边补空格;如果n前面是-号,则表示输出的整数左对齐,输出的整数右边补空格。

[7] 在-128~127之间的整数可以以字符的格式输出,字符也可以以整型的格式输出。

如:

int a=97;

printf("%c",a);输出的结果是’a’,因为‘a’存储在内存中是以ASCII码的形式存储的。

再如:

char a='a';

printf("%d",a);输出的结果是97,原因同上。

(二) 单字符输入、输出函数

C语言提供了两个无格式控制的,专门用于输入、输出单个字符的函数getchar( )和putchar( )。

(1) 单字符输入函数getchar( )

[1] getchar( )函数没有参数,有返回值,返回的就是输入的那个字符。

[2] getchar( )函数一次只能接收一个字符。

[3] getchar( )函数同样将空格和回车键等字符都会作为有效字符输入,所以注意和fflush(stdin)函数的结合使用。

(2) 单字符输出函数putchar( )

[1] putchar()函数有参数,无返回值。参数就是它要输出的那个字符,可以是字符变量或着字符常量

[2] putchar()函数一次向显示器输出一个字符。

(三) 字符串输入、输出函数

C语言还提供了两个无格式控制的专门对字符串处理的函数,gets( )和puts( )。

(1) gets( )用来接收用户输入的字符串,这是个有参数的函数,参数是一个字符数组类型,输入的字符串通过传址的方式传到这个字符数组中。

(2) puts()用来向用户显示一个字符串,它需要一个字符串参数,显示该参数并自动换行。

如:

puts(“hello, world.”);与printf(“hello,world.\n”);的效果相同,如果是puts(“hello.world.\n”)则要输出两个换行。也就是说,puts( )中的字符串可以包含转义字符。

输入字符串:

scanf("%s",in_buff);

——可以格式化输入;第二个参数是地址,可以是字符指针或者字符数组;不提供字符数组数据越界检查;以回车结束输入。

gets(in_buff);

——参数为地址,可以使字符指针或者字符数组;不提供字符数组越界检查;以回车结束输入。

fgets(in_buff,BUFFER_SIZE + 1,stdin);

——参数1为字符指着或者字符数组,参数2为要输入的字符个数,+1表示字符串结束标志,参数3为标准是输入;提供越界检查,以buffer_size+1为标准;以回车结束输入。

输入字符:

getch();

——从控制台读取一个字符,但是不回显在屏幕上;不需要回车结束。

getche();

——从控制台读取一个字符,回显屏幕;不需要回车结束。

getchar();

——从控制台读取一个字符,回显屏幕;需要回车结束(如果连续使用该函数,要注意下次调用该函数,会读取上次输入的回车符)。

scanf("%c",char *);

——从控制台读取一个字符,回显屏幕;需要回车结束(注意事项同上)。

这就是C语言中常用到的几个输入输出函数,而且这几个函数都包含在stdio.h头文件中。在这几个函数中,格式输入输出的用途最多也最容易出问题,希望提起大家的注意。


揭阳市15195231550: C语言 所有的类型输出符
底隶如意: %d:输入输出为整形 %ld 长整型 %hd短整型 %hu无符号整形 %u %lu%s:输入输出为字符串 %c字符%f:输入输出为浮点型 %lf双精度浮点型

揭阳市15195231550: 学习过的c语言程序的数据类型和运算符有哪些 -
底隶如意: C的数据类型包括:整型、字符型、实型或浮点型(单精度和双精度)、枚举类型、数组类型、结构体类型、共用体类型、指针类型和空类型 C语言的运算符包含的范围很广泛,共有34种运算符.C语言把括号、赋值、强制类型转换等都作为运...

揭阳市15195231550: C语言的输出控制符有哪些?能不能帮我列出来以下? -
底隶如意: 最简单的是printf()函数.你可以简单看看这个函数的功能.如果以后你做嵌入式的话,你可以选择很多输出控制.望采纳,谢谢.

揭阳市15195231550: C语言格式输出符 -
底隶如意: A、整形变量的输出格式还有%i(与%d一样)、%o(无符号八进制数)、%c(单个字符)等等.B、%x只适用int类型数据,无符号十六进制数 C、%8lx格式的意思是,8代表字段宽度为8,l表示将整数作为long类型打印,x解释见B

揭阳市15195231550: C语言转换格式符大全? -
底隶如意: int printf(const char *format,[argument]);format 参数输出的格式,定义格式为:%[flags][width][.perc] [F|N|h|l]type规定数据输出方式,具体如下:1.type 含义如下:d 有符号10进制整数i 有符号10进制整数o 有符号8进制整数u 无符号10进制...

揭阳市15195231550: 谁能帮我说说C语言中的各个符号代表什么 比如什么scanf、int的
底隶如意: 短整型short 整型int 长整型long 单精度型float 双精度型double 字符类型char 结构体struct 共用体union 枚举类型enum 空类型void 定义类型typedef

揭阳市15195231550: C语言中,各种类型的标识符输出格式 都有那些 例如:short ,还有就是各种类型的取值范围,例如:int ( - 32768~+32767). -
底隶如意: 你指的是数据类型吧?这个网页上有张表: http://wapwenku.baidu.com/view/77dd0d8502d276a200292ef7.html?ssid=0&from=2001c&uid=B44C66739FA5380422975CF8DD80C03C&pu=sz%401320_1003%2Cta%40iphone_2_4.0_1_9.1%2Cusm%400&bd_page_type=1&tj=wenkuala_1_0_10_title#page/1/1375008321943

揭阳市15195231550: C语言输出格式和类型 -
底隶如意: 大概前面调用字符串文件,然后你定义一个变量用来存放Hello World! 再printf("%s\n",a(就是你定义的那个变量));也许这样可以,,,不过我字符串还不怎么会用....#include"stdio.h"#include"string.h" main() { char a[15];/*好像13就够大了,,,*/ a[15]=Hello World!;/*加上空格什么的,好像还要有一个用于表示结束的,一共就需要13个长度.也许还要把这个字符串用双引号括起来,这个我不是很清楚,还没学,,*/ printf("%s\n",a[15]); } 你自己再在书上看一下吧,,我这个大概有很多错误,,,呵呵

揭阳市15195231550: 急求C语言中的格式字符表 -
底隶如意: 1.%d格式符.它的作用是将其对应的表达式的值按照十进制整数方式输出.(2)%md格式符.它的作用是按照m指定的宽度进行输出.(3)%ld格式符.它的作用是将其对应的表达式的值按照长整数方式输出.(4)%mld格式符.这个格式符的作...

揭阳市15195231550: C语言中的格式符哪个比较常用? -
底隶如意: 按十六进制格式输出%d 输出数字长度为变量数值的实际长度 %f 按实数格式输出,整数部分按实际位数输出,6位小数 %lf 表示输出长的精度 %ld 表示输出“长整型”数据 %s 字符串输出 %c 字符输出 %g 以%f%e中较短的输出宽度输出单.(偶尔用用) u格式符:用于输出unsigned类型数据:按八进制格式输出.(偶尔用用) x格式符、双精度的实数 e格式符:以指数形式输出实数.(偶尔用用) o格式符.(有时用) 没写出来的基本更少用

本站内容来自于网友发表,不代表本站立场,仅表示其个人看法,不对其真实性、正确性、有效性作任何的担保
相关事宜请发邮件给我们
© 星空见康网