1. 您好我编译的时候又出现了#177-D警告该怎么办,我是把这两个变量当作储存数据的地方
警告是不影响编译的,是编译器认为存在裤液问题的地方。
你在delay函数中声明了一个名为 rec_buf 的临液含时变量,但是却没有用它。编译器对此有些犯嘀咕,所以闹纯笑会提醒你一声,怕你是写错了。temp也是如此。
2. c-free编译器总是出现一个警告,如何消除 warning:no newline at the end of file
解决方法:在文件结尾回车一下
英文的意思就是说文末没有换行符。Unix文档的回车换行符是一个字符
,Windows的是分别的两个
,所以你在Windows下编辑的最后一个字符是
不是
,所以编译器以为有错误。
(2)编译器出现警告扩展阅读
C-Free是一款C/C++集成开发环境(IDE)。目前有两个版本,收费的C-Free 5.0 专业版和免费的C-Free 4.0 标准版。
C-Free中集成了C/C++代码解析器,能够实时解析代码,并且在编写的过程中给出智能的提示。C-Free提供了对目前业界主流C/C++编译器的支持,你可以在C-Free中轻松切换编译器。可定制的快捷键、外部工具以及外部帮助文档,使你在编写代码时得心应手。完善的工程/工程组管理使你能够方便的管理自己的代码。
3. VC++6.0编译时出现警告
警告本身不影响编译器编译程序!
警告是编译器在编译源代码的过程中,经过简单分析源代码之后,简单判断的可能存在风险的代码
编译器给出的警告一般都是很友好的,针对性的处理警告对提高程序稳定性很有帮助。比如它提示变量没有初始化,因为没有初始化的变量中包含的是随机值,对程序很不利;它提示存在没有使用的变量,那么去掉这些变量可以减小内存浪费,等等很多
如果你现在是学习vc的阶段,那么可以不用在意警告,只要程序可以运行,达到你的要求就可以了!
但是如果你是在写成品的软件,那么请一定严肃处理警告,即第一步保证编译正常通过,不出现错误,第二步就是处理警告,保证没有警告的存在(当然,不是使用预编译指令,禁用警告)
不知道你是否听过大名鼎鼎的PCLint,它可以认为是比一般编译器更严格的编译器,它往往将警告设置为错误,目的就是提醒程序员处理潜在的问题。
4. 在C程序中,编译的时候,出现的那个warning,指的是什么意思啊急,谢谢啦!
是警告信息,对于本编译器规则来说,符合编译规则,但是有些是无意义的,或者大了语法的擦边球,不完全符合,但是也能用的。大部分可以忽略。有的时候可以设置警告的等级,视编译器而定。
5. 编译程序时出现没有错误但有警告的原因
没法错误是因为编译器没有检查出语法错误,有警告是因为有些可能写的不太规范,有时也是不标准,比如你定义一个变量,但是在程序中没有使用它,编译程序时就会警告“定义了没有使用的变量”,如果你用fopen打开文件,编译是就会提示“fopen是一个不安全的函数”等等。但是警告一般不会影响程序的正确性。
6. 在#include"stdio.h"命令前插入注释符号"//",程序编译后有警告出现 为什么
你读一下警告的内容。
注释以后,stdio.h就不再包含进来。那么,stdio.h里面的函数就都不可用。如果你的代码里面使用了stdio.h里面的函数,就会警告的。因为编译器枯汪找不到这些函数了颤败稿茄孝。
举个例子:
比如你用到printf,会警告:use of undeclared identifier 'printf'
(使用了没有声明的标识符 printf)
'printf' was not declared of this scope
(printf 没有声明)
7. c++编译器报警告怎么办
警告解决技巧:
典型的指针使用错误,定义了一个指针变量,只能用来保存地址,如果这个地址所指向的空间不是系统分配给它的,那么你对这块袜顷内存的赋值是非法的,就好比“所作所为”。
三重循环是因为非法修改了至少 3*3*5 = 45 字节的内存值,要知道以前 windows 98 的蓝屏大部分是由于非法修改内存引起的。
情况分析
1、keys1的存在性。虽然在这里运行没有出错,但程序是错的。使用了不是由你也不是由系统为分配的存储空间。
2、char** keys1,为一个指针租好亏分配了存储空间。keys这个存储空间不是你应当存取的,你的程序里面没有声明你对这些存储弊神空间的拥有性。
8. c++中编译警告有什么用
无效地址引用,隐式类型转化时的数据丢失,定义但未引用的变量(垃圾变量),不符合函数原型的返回值类型等等,编译器的警告要认真对待,应该尽量编写没有警告的代码,除非你确切的知道编译器为什么产生警告,以及后果.....不过,警告肯定是很重要的,因为排除错误是学习语法,而排除警告是学习编程经验
9. 用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++|常规,自己根据情况降低警告级别(此法不推荐)
注意:高度重视警告:使用编译器的最高警告级别。应该要求构建是干净利落的(没有警告)。理解所有警告。通过 修改代码而不是降低警告级别来排除警告。
编译器是你的朋友。如果它对某个构造发出警告,这经常是说明你的代码中存在潜在的问题。成功的构建应该是无声无息的(没有警告的)。【《