scanf什么时候用??c语言
这里所说的其实就是一个地址
所以当变量是一个指针或者表示一个地址时就不中&
&就是求地址的运算符
如数组名是数组第一个元素的地址
所以数组名就可以不用加&进行运算
比如
int a;
int *p=&a;
scanf("%d",p);
则不需要使用&运算符
这里所说的其实就是一个地址
所以当变量是一个指针或者表示一个地址时就不中&
&就是求地址的运算符
如数组名是数组第一权个元素的地址
所以数组名就可以不用加&进行运算
比如
int a;
int *p=&a;
scanf("%d",p);
则不需要使用&运算符
扩展资料:
在C语言中,输入变量的语法是:scanf("格式控制","变量地址")
可以看出,第二个的格式为变量地址。
在C语言中,变量在定义之后,就会在计算机内存中非配一块空间给这个变量,该空间在内存中的地址称为变量的地址。
为了得到变量的地址,需要在变量前加一个&(称为取地址运算符),也就是“&变量名”的写法。
参考资料来源:百度百科-scanf (计算机语言函数)
scanf函数原型折叠
int scanf( const char *format, ... );
scanf()函数是格式化输入函数,它从标准输入设备(键盘) 读取输入的信息。
其调用格式为: scanf("<格式化字符串>",<地址表>);
函数 scanf() 是从标准输入流 stdin 中读内容的通用子程序,可以读入全部固有类型的数据并自动转换成机内形式。
scanf的返回值折叠
scanf()函数返回成功赋值的数据项数,读到文件末尾出错时则返回EOF。
如:
scanf("%d,%d", &a, &b);
如果a和b都被成功读入,那么scanf的返回值就是2
如果只有a被成功读入,返回值为1
如果a和b都未被成功读入,返回值为0
如果遇到错误或遇到end of file,返回值为EOF。
且返回值为int型.
例:使用scanf函数输入数据。
#include<stdio.h>
int main()
{
int a,b,c;
printf("输入 a, b, c
");scanf("%d,%d,%d", &a, &b, &c);
printf("a = %d b = %d c = %d
", a, b, c);fflush(stdin);
return 0;
}
注意上面的scanf("%d,%d,%d",&a,&b,&c);中%d,%d,%d之间如果有逗号,在输入数据时也要加逗号,如果去掉逗号,输入时就不用逗号,而用空格、tab键或回车键将各个数据隔开
格式字符说明折叠
在 C99 中,format 用 restrict 修饰。
format 指向的控制串由以下三类字符组成:
格式说明符折叠
转换字符(就是%后跟的部分)
a 读浮点值(仅适用于 C99)
A 读浮点值(仅适用于 C99)
c 读单字符
d 读十进制整数
i 读十进制、八进制、十六进制整数
e 读浮点数
E 读浮点数
f 读浮点数
F 读浮点数(仅适用于 C99)
g 读浮点数
G 读浮点数
o 读八进制数
s 读字符串
x 读十六进制数
X 读十六进制数
p 读指针值
n 至此已读入值的等价字符数
u 读无符号十进制整数
[ ] 扫描字符集合
% 读 % 符号(百分号)
附加格式说明字符表修饰符说明
L/l 长度修饰符 输入"长"数据
h 长度修饰符 输入"短"数据
W 整型常数 指定输入数据所占宽度
* 表示本输入项在读入后不赋值给相应的变量
空白符折叠
空白字符会使scanf()函数在读操作中略去输入中的一个或多个空白字符。
非空白符折叠
一个非空白字符会使scanf()函数在读入时剔除掉与这个非空白字符相同的字符。
说明:
(1)%s 表示读串而 %d 表示读整数。格式串的处理顺序为从左到右,格式说明符逐一与变元表中的变元匹配。为了读取长整数,可以将 L / l 放在格式说明符的前面;为了读取短整数,可以将 h 放在格式说明符的前面。这些修饰符可以与 d、i、o、u 和 x 格式代码一起使用。
(2)默认情况下,a、f、e 和 g 告诉 scanf() 为 float 分配数据。 如果将 L / l放在这些修饰符的前面,则 scanf() 为 double 分配数据。使用 L 就是告诉 scanf(),接收数据的变量是 long double 型变量。
(3)如果使用的现代编译器程序支持 1995 年增加的宽字符特性, 则可以与 c 格式代码一起,用 l 修饰符说明类型 wchar_t 的宽字符指针;也可以与 s 格式代码一起,用 l 修饰符说明宽字符串的指针。l 修饰符也可以用于修饰扫描集,以说明宽字符。
(4)控制串中的空白符使 scanf() 在输入流中跳过一个或多个空白行。空白符可以是空格(space)、制表符(tab)和新行符(newline)。 本质上,控制串中的空白符使 scanf() 在输入流中读,但不保存结果,直到发现非空白字符为止。
(5)非空白符使 scanf() 在流中读一个匹配的字符并忽略之。例如,"%d,%d" 使 scanf() 先读入一个整数,读入中放弃逗号,然后读另一个整数。如未发现匹配,scanf() 返回。
(6)scanf() 中用于保存读入值的变元必须都是变量指针,即相应变量的地址。 对于字符串数组或字符串指针变量,由于数组名和指针变量名本身就是地址,因此使用scanf()函数时,不需要在它们前面加上"&"操作符。
(7)在输入流中,数据项必须由空格、制表符和新行符分割。逗号和分号等不是分隔符,比如以下代码:
scanf( "%d %d", &r, &c );
将接受输入 10 20,但遇到 10,20 则失败。
(8)百分号(%)与格式符之间的星号(*)表示读指定类型的数据但不保存。因此,
scanf( "%d %*c %d", &x, &y );
对 10/20 的读入操作中,10 放入变量 x,20 放入 y。
(9)格式命令可以说明最大域宽。 在百分号(%)与格式码之间的整数用于限制从对应域读入的最大字符数。例如,希望向 address 读入不多于 20 个字符时,可以书写成如下形式:
scanf( "%20s", address );
如果输入流的内容多于 20 个字符,则下次 scanf() 从此次停止处开始读入。 若达到最大域宽前已遇到空白符,则对该域的读立即停止;此时,scanf() 跳到下一个域。
(10)虽然空格、制表符和新行符都用做域分割符号,但读单字符操作中却按一般字符处理。例如,对输入流 "x y" 调用:
scanf( "%c%c%c", &a, &b, &c );
返回后,x 在变量 a 中,空格在变量 b 中,y 在变量 c 中。
注意,控制串中的其它字符,包括空格、制表符和新行符,都用于从输入流中匹配并放弃字符,被匹配的字符都放弃。例如,给定输入流 "10t20",调用:
scanf( "%dt%d", &x, &y );
将把 10 和 20 分别放到 x 和 y 中,t 被放弃,因为 t 在控制串中。
(11)ANSI C 标准向 scanf() 增加了一种新特性,称为扫描集(scanset)。 扫描集定义一个字符集合,可由 scanf() 读入其中允许的字符并赋给对应字符数组。 扫描集合由一对方括号中的一串字符定义,左方括号前必须缀以百分号。 例如,以下的扫描集使 scanf() 读入字符 A、B 和 C:
%[ABC]
使用扫描集时,scanf() 连续吃进集合中的字符并放入对应的字符数组,直到发现不在集合中的字符为止(即扫描集仅读匹配的字符)。返回时,数组中放置以 null 结尾、由读入字符组成的字符串。
用字符 ^ 可以说明补集。把 ^ 字符放为扫描集的第一字符时,构成其它字符组成的命令的补集合,指示 scanf() 只接受未说明的其它字符。
对于许多实现来说,用连字符可以说明一个范围。 例如,以下扫描集使 scanf() 接受字母 A 到 Z:
%[A-Z]
重要的是要注意扫描集是区分大小写的。因此,希望扫描大、小写字符时,应该分别说明大、小写字母。
(12) scanf() 返回等于成功赋值的域数的值,但由于星号修饰符而读入未赋值的域不计算在内。遇到文件结束则返回EOF;若出错则返回0.
(13)C99 为 scanf() 增加了几个格式修饰符:hh、ll、j、z 和 t。hh 修饰符可用于 d、i、o、u、x、X 或 n。它说明相应的变元是 signed 或 unsigned char 值,或用于 n 时, 相应的变元是指向 long char 型变量的指针。ll 修饰符也可用于 d、i、o、u、x、X 或 n。它说明相应的变元是 signed 或者 unsigned long long int 值。
j 格式修饰符应用于 d、i、o、u、x、X 或 n,说明匹配的变元是类型 intmax_t 或 uintmax_t。这些类型在 <stdint.h>; 中声明,并说明最大宽度的整数。
z 格式修饰符应用于 d、i、o、u、x、X 或 n,说明匹配的变元是指向 size_t 类型对象的指针。该类型在 <stddef.h>; 中声明,并说明 sizeof 的结构。
t 格式修饰符应用于 d、i、o、u、x、X 或 n,说明匹配的变元是指向 ptrdiff_t 类型对象的指针。该类型在 <stddef.h>; 中声明,并说明两个指针之间的差别。
注意问题折叠编辑本段
(1) 对于字符串数组或字符串指针变量,由于数组名和指针变量名本身就是地址,因此使用scanf()函数时,不需要在它们前面加上"&"操作符。
(2) 可以在格式化字符串中的"%"各格式化规定符之间加入一个整数,表示任何读操作中的最大位数。
(3) scanf()函数中没有精度控制。
如: scanf("%5.2f",&a); 是非法的。不能企图用此语句输入小数为2位的实数。
(4) scanf中要求给出变量地址,如给出变量名则会出错
如 scanf("%d",a);是非法的,应改为scanf("%d",&a);才是合法的。
(5) 在输入多个数值数据时,若格式控制串中没有非格式字符作输入数据之间的间隔则可用空格,TAB或回车作间隔。
C编译在碰到空格,TAB,回车或非法数据(如对“%d”输入“12A”时,A即为非法数据)时即认为该数据结束。
(6) 在输入字符数据(%c)时,若格式控制串中无非格式字符,则认为所有输入的字符均为有效字符。
例如:scanf("%c%c%c",&a,&b,&c);
输入为:
d e f
则把'd'赋予a, ' (空格)'赋予b,'e'赋予c。因为%c 只要求读入一个字符,后面不需要用空格作为两个字符的间隔,因此把' '作为下一个字符送给b。
只有当输入为:def 时,才能把'd'赋于a,'e'赋予b,'f'赋予c。 如果在格式控制中加入空格作为间隔,
如 scanf ("%c %c %c",&a,&b,&c);则输入时各数据之间可加空格。
我们用一些例子来说明一些规则:
#include <stdio.h>
void main()
{
char a,b;
printf("input character a,b/n");
scanf("%c%c",&a,&b); /*注意两个%c之间没有任何符号*/
printf("%c%c/n",a,b);
}
由于scanf函数"%c%c"中没有空格,输入M N,结果输出只有M。而输入改为MN时则可输出MN两字符,见下面的输入运行情况: input character a,b
MN (你输入的值)
MN (屏幕上显示的值)
#include <stdio.h>
void main()
{
char a,b;
printf("input character a,b/n");
scanf("%c %c",&a,&b); /*注意两个%c之间有个空格*/
printf("/n%c%c/n",a,b);
}本例表示scanf格式控制串"%c %c"之间有空格时, 输入的数据之间可以有空格间隔。
(7) 如果格式控制串中有非格式字符则输入时也要输入该非格式字符。
例如:
scanf("%d,%d,%d",&a,&b,&c); 其中用非格式符“ , ”作间隔符,故输入时应为: 5,6,7 (与scanf 双引号之间的格式必须一样)
又如: scanf("a=%d,b=%d,c=%d",&a,&b,&c);
则输入应为 a=5,b=6,c=7
如输入的数据与输出的类型不一致时,虽然编译能够通过,但结果将不正确。
#include <stdio.h>
void main()
{
int a;
printf("input a number");
scanf("%d",&a);
printf("%ld",a);
}
由于输入数据类型为整型, 而输出语句的格式串中说明为长整型,因此输出结果和输入数据不符。输出并不是输入的值。
如将Scanf("%d",&a); 语句改为 scanf("%ld",&a);
输入数据为长整型,输入输出数据才相等。
问题一折叠
如何让scanf()函数正确接受有空格的字符串?如: I love you!
#include <stdio.h>
int main()
{
char str[80];
scanf("%s",str);
printf("%s",str);
return 0;
}
输入:I love you!
上述程序并不能达到预期目的,scanf()扫描到"I"后面的空格就认为对str的赋值结束,并忽略后面的"love you!".这里要注意是"love you!"还在键盘缓冲区(关于这个问题,网上我所见的说法都是如此,但是,我经过调试发现,其实这时缓冲区字符串首尾指针已经相等了,也就是说缓冲区清空了,scanf()函数应该只是扫描stdin流,这个残存信息是在stdin中)。我们改动一下上面的程序来验证一下:
#include <stdio.h>
#include<windows.h>
int main()
{
char str[80], str1[80], str2[80];
scanf("%s", str); /* 此处输入:I love you! */
printf("%s
", str);Sleep(5000); /* 这里等待5秒,告诉你程序运行到什么地方 */
/* 不是sleep(5)
1,函数名是Sleep不是sleep。
2,C/C++中,unsigned Sleep(unsigned)应该是毫秒ms.
*/
scanf("%s", str1); /* 这两句无需你再输入,是对stdin流再扫描 */
scanf("%s", str2); /* 这两句无需你再输入,是对stdin流再扫描 */
printf("%s
", str1);printf("%s
", str2);return 0;
}
输入:I love you!
输出:
I
love
you!
好了,原因知道了,所以结论是:残留的信息 love you是存在于stdin流中,而不是在键盘缓冲区中。那么scanf()函数能不能完成这个任务?回答是:能!别忘了scanf()函数还有一个 %[] 格式控制符(如果对%[]不了解的请查看本文的上篇),请看下面的程序:
#include <stdio.h>
int main()
{
char str[50];
scanf("%49[^
]", str); /* scanf("%s",string); 不能接收空格符 */printf("%s
", str);return 0;
}
问题二折叠
键盘缓冲区残余信息问题
#include <stdio.h>
int main()
{
int a;
char c;
do
{
scanf("%d", &a);
scanf("%c", &c);
printf("a = %d c = %c
", a, c);/* printf("c = %d
", c); */} while(c != 'N');
return 0;
}
scanf("%c", &c);这句不能正常接收字符,什么原因呢?我们用printf("c = %d
", c);将C用int表示出来,启用printf("c = %d
", c);这一句,看看scanf()函数赋给C到底是什么,结果是c=10 ,ASCII值为10是什么?换行即
.对了,我们每击打一下"Enter"键,向键盘缓冲区发去一个“回车”(),一个“换行"(
),在这里被scanf()函数处理掉了(姑且这么认为吧^_^),而
被scanf()函数“错误”地赋给了c.解决办法:可以在两个scanf()函数之后加个fflush(stdin);,还有加getch(), getchar()也可以,但是要视具体scanf()语句加那个,这里就不分析了,读者自己去摸索吧。但是加fflush(stdin);不管什么情况都可行。(
函数名: fflush
功 能: 清除一个流
用 法: int fflush(FILE *stream);
)
#include <stdio.h>
int main()
{
int a;
char c;
do
{
scanf("%d", &a);
fflush(stdin);
scanf("%c", &c);
fflush(stdin);
printf("a=%d c=%c
",a,c);} while(c!='N');
return 0;
}
这里再给一个用“空格符”来处理缓冲区残余信息的示例:
/////////////版本1//////////////////////运行出错的程序///////////////////////////////////////////
#include <stdio.h>
int main()
{
int i;
char j;
for (i = 0; i < 10; ++i)
scanf("%c", &j); /* 这里%前没有空格 */
printf("%c", j); /* 在输入十个字符之后,验证打印出来的字符是否是自己输入的最后一个字符(即输入的第十个字符)*/
return 0;
}
//////////////////////////////////////////////////////////////////////////////////////////////////////////////
/////////////版本2//////////////////////使用了空格控制符后///////////////////////////////////
#include <stdio.h>
int main()
{
int i;
char j;
for (i = 0; i < 10; ++i)
scanf(" %c", &j);/* 注意这里%前有个空格 */
printf("%c", j);/* 在输入十个字符之后,验证打印出来的字符是否是自己输入的最后一个字符(即输入的第十个字符)*/
return 0;
}
////////////////////////////////////////////////////////////////////////////////////////////////////////////
接着,我们运行看看,首先,运行第一个版本(错误的程序)
我们输入:0 1 2 3 4 5 6 7 8 9
结果是一个空字符
再运行第二个版本(正确的程序)
同样输入:0 1 2 3 4 5 6 7 8 9
这一次就显示字符9,故此程序正确。
那么为什么第二个程序就正确呢,原因何在,在%前面加一个空格就这么有用,答案是肯定的,就是%前面的空格在起作用,读者看看此文章的前面部分,在scanf的使用过程中应注意的问题中已经指出:“scanf()的格式控制串可以使用空白字符或其它非空白字符,使用空白字符会使scanf()函数在读操作中略去输入中的一个或多个空白字符。”
所以在%前面加上了空格(空格属于空白字符,此外还有像制表符等也属于空白字符),在输入过程中,将略去输入中的一个或多个空白字符,所以我们输入的0 1 2 3 4 5 6 7 8 9这些字符中的空白字符就被略去了,字符9也就正确的打印出来了,这样子解释,相信大家都看明白勒吧!
问题三折叠
如何处理scanf()函数误输入造成程序死锁或出错?
#include <stdio.h>
int main()
{
int a, b, c;
scanf("%d,%d", &a, &b);
c = a + b; /*计算a+b*/
printf("%d + %d = %d", a, b, c);
return 0;
}
如上程序,如果正确输入a,b的值,那么没什么问题,但是,你不能保证使用者每一次都能正确输入,一旦输入了错误的类型,你的程序不是死锁,就是得到一个错误的结果,呵呵,这可能所有人都遇到过的问题吧?解决方法:scanf()函数执行成功时的返回值是成功读取的变量数,也就是说,你这个scanf()函数有几个变量,如果scanf()函数全部正常读取,它就返回几。但这里还要注意另一个问题,如果输入了非法数据,键盘缓冲区就可能还个有残余信息问题。正确的例程:
#include <stdio.h>
int main()
{
int a,b,c;
while (scanf("%d,%d", &a, &b) != 2)
fflush(stdin);
c = a + b;
printf("%d + %d = %d", a, b, c);
return 0;
}
补充折叠
fflush(stdin)这个方法在GCC下不可用。(在VC6.0下可以)
以下是 C99 对 fflush 函数的定义:
int fflush(FILE *stream);
如果stream指向输出流或者更新流(update stream),并且这个更新流
最近执行的操作不是输入,那么fflush函数将把任何未被写入的数据写入stream
指向的文件(如标准输出文件stdout)。否则,fflush函数的行为是不确定的。
C和C++的标准里从来没有定义过 fflush(stdin)。
fflush(NULL)清空所有输出流和上面提到的更新流。如果发生写错误,fflush
函数会给那些流打上错误标记,并且返回EOF,否则返回0。
由此可知,如果 stream 指向输入流(如 stdin),那么 fflush 函数的行为是不确定的。故而使用
fflush(stdin) 是不正确的,至少是移植性不好的。
可采用如下方法:
方法一:
/* 此函数可以和scanf函数一起使用,但使用%c输入时要注意,即此函数只能用于缓冲区非空的情况 */
#include <stdio.h>
void flush()
{
char c;
while ((c = getchar()) != '
' && c != EOF) ;}
int main()
{
int a,b,c; /*计算a+b*/
while (scanf("%d,%d", &a, &b) != 2)
flush();
c = a + b;
printf("%d + %d = %d", a, b, c);
}
方法二:
使用getchar()代替fflush(stdin)
程序示例:
#include <stdio.h>
int main()
{
int i, c;
while (1 )
{
printf("Please input an integer: ");
scanf("%d", &i);
if (feof(stdin) || ferror(stdin))
{
/* 如果用户输入文件结束标志(或文件已被读完), */
/* 或者发生读写错误,则退出循环 */
/* do something */
break;
}
/* 没有发生错误,清空输入流。 */
/* 通过 while 循环把输入流中的余留数据“吃”掉 */
while ( (c = getchar()) != '
' && c != EOF ) ; /*可直接将这句代码当成fflush(stdin)的替代,直接运行可清除输入缓存流*//* 使用 scanf("%*[^
]"); 也可以清空输入流, *//* 不过会残留
字符。 */printf("%d
", i);}
return 0;
}
发展
使用scanf函数进行输入,必须指定输入的数据的类型和格式,不仅繁琐复杂,而且很容易出错.C++保留scanf只是为了和C兼容,以便过去用C语言写的程序可以在C++的环境下运行。C++的编程人员都愿意使用cin进行输入,很少使用scanf。
scanf 的意思是把输入的值给送到地址,因此,如果参数已经是地址了,那么不需要 &,否则 需要用&取一下地址
scanf 格式输入函数
函数作用:按照变量在内存的地址将变量值存进去。
一般格式:scanf(格式控制,地址表列)
其中,格式控制:
%d:以带符号的十进制形式输出整数
%o:以八进制无符号形式输出整数
%x:以十六进制无符号形式输出整数
%u:以无符号十进制形式输出整数
%c:以字符形式输出,只输出一个字符
%s:输出字符串
%f:以小数形式输出单,双精度数,隐含输出六位小数
%e:以指数形式输出实数
%g:选用%f或%e格式中输出宽度较短的一种格式,不输
出无意义的0
在格式控制的字母前面可以用几种常见的格式符的修饰符,作用如下:
L:用于长整型整数,可加在格式符d,o,x,u前面
M(代表一个正整数):数据最小宽度
N(代表一个正整数):对实数,表示输出n位小数;
对字符串,表示截取的字符个数
地址列表:是由若干个地址组成的表列,可以是变量的地址,或字符串的首地址
举例:
用scanf函数输入数据。
#include<stdio.h>
void main()
{
int a,b,c;
scanf(“%d%d%d”,&a,&b,&c);
printf(“%d,%d,%d\n”,a,b,c);
}
运行情况:3 4 5 (回车) (输入a,b,c的值)3,4,5 (输出a,b,c的值)
使用scanf函数时应注意的问题 :
(1)scanf函数中的“格式控制”后面应当是变量地址,而不应
是变量名。
(2) 如果在“格式控制”字符串中除了格式说明以外还有其他字符,
则在输入数据时在对应位置应输入与这些字符相同的字符。
(3) 在用“%c”格式输入字符时,空格字符和“转义字符”都作为
有效字符输入
(4) 在输入数据时,遇以下情况时认为该数据结束。
① 遇空格,或按“回车”或“跳格”(Tab)键;
② 按指定的宽度结束,如“%3d”,只取3列;
③ 遇非法输入。
当你需要通过键盘输入数据时使用,一般是先定义变量,然后根据题目要求适当时候采用这个输入,如同给变量赋初始值一样,区别是数据来源不同而已。
c语言中,gets 和getchar及scanf是如何判断你输入的字符或者字符串结束...
scanf()是什么都可以输入,scanf()是以回车代表输入结束 scanf()中会用到空格 是用作分隔符的 因为scanf()可以输入多个变量,如 canf("%d%d",&a,&b);\/\/表示输入两个整形的数分别赋给变量a、b 在输入另个数时用空格间隔开 但如果canf("%d,%d",&a,&b);\/\/如果两个%d中间...
C语言用scanf给数组赋值问题
你甚至可以在输入完5个数之后,再输入一个字母,也是可以的(只要不是空白字符就行)。这是C语言的特性,你有空可以多读读C标准库的书。
C语言中想用s字符串指针和canf获取一个输入的字符串,然后再输出在屏幕上...
没有为ss分配内存空间 将char *ss改为char *ss[100];就可以了 也可以使用动态申请空间的方法 include <stdio.h> include <malloc.h> int main(){ int length;printf("please enter the length of the word:\\n");scanf("%d",&length);char *ss=(char*)malloc(sizeof(char)*length+1);p...
C语言printf跟scanf的区别?
比如 scanf(“%d”,a); printf("%df
函数是干什么的
函数的近代定义是给定一个数集A,假设其中的元素为x,对A中的元素x施加对应法则f,记作f(x),得到另一数集B,假设B中的元素为y,则y与x之间的等量关系可以用y=f(x)表示,函数概念含有三个要素:定义域A、值域B和对应法则f。其中核心是对应法则f,它是函数关系的本质特征。函数,最早由中国...
如何用c语言创建一个文件?并按格式保存?
1、打开C-Free5.0新建一个空白页面,然后将C语言的基础格式写完,注意格式缩进。如下图所示。2、用“FILE”来做声明。FILE 是变量类型,实际上是C语言定义的标准数据结构,用于文件。FILE *fp 是声明,声明fp是指针,用来指向FILE类型的对象。3、然后利用fp=fopen("c:\\\\czb_one.txt","wb") 来...
c语言求两个数的加减乘除余
canf那句改成下面这样 scanf("%d %d", &a, &b);if ( 0 == a || 0 == b ){ printf("输入错误!\\n");return;} 请采纳。
C语言输出文件
C语言输入输出函数 1. fopen()函数 fopen函数用于打开文件, 其调用格式为: FILE *fopen(char *filename, *type); 在介绍这个函数之;前, 先了解一下下面的知识。 (1) 流(stream)和文件(file) 流和文件在Turbo C2.0中是有区别的, Turbo C2.0 为编程者和被访问的设 备之间提供了一层抽象的东西, 称...
C语言编程的时候出现“程序已停止工作”的原因有哪些?
int * p = i; \/\/错误!这与在sccanf里没有加上“&”号的原因大致相同。指针问题属于程序逻辑错误,很多时侯编译器只会给你一个警告。要注意警告发生的位置自己是否有把握。如果你多次编译或忽视编译警告而进行链接,编译器会认为你对这些警告是有把握的,完全地信任了你,也就没有警告了。
(C语言)ASCII码为7的那个控制字符是干什么用的?
012 014 00C 00001100 FF (Form Feed)013 015 00D 00001101 CR (Carriage Return)014 016 00E 00001110 SO (Shift Out)015 017 00F 00001111 SI (Shift In)016 020 010 00010000 DLE (Data Link Escape)017 021 0...