❶ C语言编译过程中为什么显示警告
此程序应该没问题,如果有的话可能是你安装的编译系统有问题,建议你在别的编译系统上试试(TC/WIN-TC)。
至于为什么会出现警告,是由于你的程序中存在不和要求的输入,但是警告一般不影响程序的应行,不过程序的结果一般来说是错误的,而且这时候程序能通过编译,建议编译时用快睫键(ALT+F9(TC编译器))。
❷ 请c语言高手看看下面这个程序哪里出错了,编译后怎么有一个警告
1)警告的原因是编译时,编译器认为p变量没有赋初值;
2)其实程序中已经在if
else
中对p的初始值进行了处理,但编译器比较“笨”没有看出来
3)你可以完全不理会这个警告;
4)如果确实你不想让编译器出这样的警告,在scanf语句前,加上
p
=
0
,
显式地为p赋初值
❸ 为什么c程序每次编译都有一个警告
你好!
是这个警告吗 ?warning: no newline at end of file
如果是,那么你在最后一个 } 的后面,按一下回车就好了,也就是结尾出现一个空号
❹ 在C++6.0的环境中,编辑好程序后,在编译时提示有一个警告,应该怎么处理啊
一般的话,警告出现,可能不会影响程序运行,但可能失去程序的精度,当然你不处理程序照样能够正常运行。如果出现警告,可能是你的程序当中的数据类型,或者其他的一些原因,还是要看提示。
❺ 在C程序中,编译的时候,出现的那个warning,指的是什么意思啊急,谢谢啦!
是警告信息,对于本编译器规则来说,符合编译规则,但是有些是无意义的,或者大了语法的擦边球,不完全符合,但是也能用的。大部分可以忽略。有的时候可以设置警告的等级,视编译器而定。
❻ c-free编译器总是出现一个警告,如何消除 warning:no newline at the end of file
解决方法:在文件结尾回车一下
英文的意思就是说文末没有换行符。Unix文档的回车换行符是一个字符
,Windows的是分别的两个
,所以你在Windows下编辑的最后一个字符是
不是
,所以编译器以为有错误。
(6)双编译有一个警告扩展阅读
C-Free是一款C/C++集成开发环境(IDE)。目前有两个版本,收费的C-Free 5.0 专业版和免费的C-Free 4.0 标准版。
C-Free中集成了C/C++代码解析器,能够实时解析代码,并且在编写的过程中给出智能的提示。C-Free提供了对目前业界主流C/C++编译器的支持,你可以在C-Free中轻松切换编译器。可定制的快捷键、外部工具以及外部帮助文档,使你在编写代码时得心应手。完善的工程/工程组管理使你能够方便的管理自己的代码。
❼ 用VS编译C 出现一个警告 什么意思啊
警告 2 warning C4013: “getch”未定义;假设外部返回 int d:\文件类\c语言\c 语言项目\c\c\2.c 12 C源代码是# include <stdio.h
void main(){int a[10];int i;for(i=0;i<10;i++){scanf("%d",&a[i]);}a[5]=a[5]+5;
printf("%d",a[5]);getch();}回答:很多涉及字符串的函数是不检查越界的, 不安全。 所以后来有一套新的安全函数替代这个, 第一个warning就是建议你用 scanf_s代替scanf 第二个 warning是说你用的 getch()没定义, 所以编译器假定它是 int getch(void)。 用的函数最好先 include好头文件
warning C4996: 'sprintf': This function or variable may be unsafe. Consider using sprintf_s instead. To disable deprecation, use _CRT_SECURE_NO_WARNINGS
已经是安全主导的年代了,这些老旧的东西微软提供了一些新函式来取代,很简单他在后面加了_s ,例如gets == gets_s ,strcpy == strcpy_s原因解释这种微软的警告,主要因为那些C库的函数,很多函数内部是不进行参数检测的(包括越界类的),微软担心使用这些会造成内存异常,所以就改写了同样功能的函数,改写了的函数进行了参数的检测,使用这些新的函数会更安全和便捷。关于这些改写的函数你不用专门去记忆,因为编译器对于每个函数在给出警告时,都会告诉你相应的安全函数,查看警告信息就可以获知,在使用时也再查看一下MSDN详细了解。库函数改写例子:
mkdir改写为 _mkdir
fopen”改写为 fopen_s
stricmp改写为 stricmp_s
strcpy改写为strcpy_s解决方案:1 根据下面的warning提示:参见“fopen”的声明
消息:“This function or variable may be unsafe. Consider using fopen_s instead. To disable deprecation, use _CRT_SECURE_NO_DEPRECATE. See online help for details.”
所以可以将函数按warning提示的第二句,改为使用fopen_s函数即可:
例如:FILE *pFile=fopen("1.txt", "w");改为:FILE* pFile;
fopen_s(&pFile, "1.txt", "w");
2 还是根据warning提示的地三句话:use _CRT_SECURE_NO_DEPRECATE
项目|属性|配置属性|C/C++|命令行|附加选项,加入【/D "_CRT_SECURE_NO_DEPRECATE" 】(注:加入中括号中完整的内容)
3 降低警告级别:项目|属性|配置属性|C/C++|常规,自己根据情况降低警告级别(此法不推荐)
注意:高度重视警告:使用编译器的最高警告级别。应该要求构建是干净利落的(没有警告)。理解所有警告。通过 修改代码而不是降低警告级别来排除警告。
编译器是你的朋友。如果它对某个构造发出警告,这经常是说明你的代码中存在潜在的问题。成功的构建应该是无声无息的(没有警告的)。【《
❽ 用 keil编译的时候有两个警告怎么回事
warning
l15:
multiple
call
to
segment
这个问题必须注意,可能引起程序冲突,假设你用于自动化领域,则可能导致信号产生尖峰。
产生这一警告的一个根源是:你在主循环里调用了一个函数(如aaa),而在中断服务函数里,你用调用了这个函数(如aaa)。这样当主循环运行到该函数中是,一旦产生中断,则在中断里又再次调用该函数!这时,很可能出错!
避免这种情况的方法很多:如,在进中断的时候置需调用该函数的标志,而在主循环中调用该函数
你可以在中断函数设置标志
flag_display
=
1;
在主函数里判断这个标志:
if(flag_display)
valuedisplay();
更新后,清除显示标志:
flag_display
=
0;
❾ c++中编译警告有什么用
无效地址引用,隐式类型转化时的数据丢失,定义但未引用的变量(垃圾变量),不符合函数原型的返回值类型等等,编译器的警告要认真对待,应该尽量编写没有警告的代码,除非你确切的知道编译器为什么产生警告,以及后果.....不过,警告肯定是很重要的,因为排除错误是学习语法,而排除警告是学习编程经验