编译警告
㈠ 用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++|常规,自己根据情况降低警告级别(此法不推荐)
注意:高度重视警告:使用编译器的最高警告级别。应该要求构建是干净利落的(没有警告)。理解所有警告。通过 修改代码而不是降低警告级别来排除警告。
编译器是你的朋友。如果它对某个构造发出警告,这经常是说明你的代码中存在潜在的问题。成功的构建应该是无声无息的(没有警告的)。【《
㈡ c语言: 这样的编译警告
在函数a中返回的sth void 不是void* 而你在函数中又试图以void*的方式去使用它,所以要对你作出提醒。
㈢ C语言编译警告,求解
你是在unix下吧,unix下建立的文件末尾都有一个空行,所以编译器也要求正常的文件有一个空行作为末尾。加工空行就行了
㈣ c语言,编译出现警告了
1)警告的原因是编译时,编译器认为p变量没有赋初值;
2)其实程序中已经在if else 中对p的初始值进行了处理,但编译器比较“笨”没有看出来
3)你可以完全不理会这个警告;
4)如果确实你不想让编译器出这样的警告,在scanf语句前,加上 p = 0 , 显式地为p赋初值
㈤ 51编程编译警告,,该怎么处理
有些软件是经过了压缩和加壳的,所以反编译之前如果没用脱壳处理的话可能会出现这种情况,反编之前最好是先用fileinfo之类的软件查看一下这个软件是否加过壳。
㈥ 编译时出现警告,怎么回事
如上图所示, 我用Qt5.5 新建的一个项目, 在运行时下面出现警告 ppsjy:[MyHookProc]__read web cfg: success ----- :
PS: 我是在安装了Qt5.9后出现的这个问题, 之后把Qt5.9和Qt5.5都御载了再安装Qt5.5 可这个警告还在, 怎么回事?
你卸载的时候,可能有QT记录残留,所以警告还在吧。一般QT的运行配置保存在:C:Users用户AppDataRoamingQtProject 和 C:Users用户AppDataLocalQtProject,你可以尝试把这个文件夹一起删了试试!
使用vs版本试试
㈦ c 编译的时候出现这个警告
int node[12][2]
所以系统默认node应该是赋值给一个指向数组长度为2的指针。
也就是说
你应该让它赋值给它默认的才不会有警告,而你程序中
是赋值给一个指向一个数字的指针,也就是长度为1.
void creategraph(int *node,int num)
所以,才会产生警告。
下面我改了下你的程序,也可以输出结果,但是没有警告了。
#include <stdio.h>
typedef int intarray[2];
int matrix[6][6];
/*创建图 */
void creategraph(int *node,int num)
{
int from; /*边的起点*/
int to; /*边的终点*/
int i;
for(i=0;i<num;i++)
{
from=node[i*2];
to=node[i*2+1];
matrix[from][to]=1;
}
}
void creategraph1(intarray *node,int num)
{
int from; /*边的起点*/
int to; /*边的终点*/
int i;
for(i=0;i<num;i++)
{
from=*(*(node+i)+0);
to=*(*(node+i)+1);
matrix[from][to]=1;
}
}
/*主程序:创建图后,将邻接矩阵输出*/
void main()
{
int node[12][2]={ {1,2},{2,1},
{1,3},{3,1},
{2,3},{3,2},
{2,4},{4,2},
{3,5},{5,3},
{4,5},{5,4}};
int i,j;
for(i=1;i<=5;i++)
for(j=1;j<=5;j++)
matrix[i][j]=0;
creategraph1(node,12);
printf("graph is:\n");
for(i=1;i<=5;i++)
{for(j=1;j<=5;j++)
printf("%d ",matrix[i][j]);
printf("\n");}
getch();
}
如上,creategraph1()函数我新写的,可以实现你说的,但是不会产生警告。
其实这种多维数组的传递,确实很考指针,我空间中写过这方面的
http://hi..com/huifeng00/blog/item/83a3c19bdcbf83026f068c37.html
你有时间可以看下,应该算详细吧,不明白hi我。
㈧ java程序可以编译 但是会有警告 为什么呢
告警是编译时检查发现不符合一些常用约定,但是不妨碍执行。
ThestaticfieldText3.ishouldbeaccessedinastaticway
以下是修改过的代码。
publicclassText3{
staticinti=47;//静态方法共用内存
publicvoidcall(){
System.out.println("调用call方法");
for(i=0;i<3;i++){
System.out.print(i+"");
if(i==2){
System.out.println();
}
}
}
publicstaticintgetI(){
returni;
}
publicstaticvoidsetI(inti){
Text3.i=i;
}
publicText3(){
}
publicstaticvoidmain(String[]args){
//TODOAuto-generatedmethodstub
Text3t1=newText3();
Text3t2=newText3();
Text3.setI(60);//这里有警告
Text3.i++;
System.out.println("第一个实例对象调用变量i的结果为i="+Text3.getI());//这里有警告
t1.call();//调用call方法后,i的值变成了3
Text3.i++;
System.out.println("第二个实例对象调用变量i的结果为i="+Text3.getI());//这里有警告
t2.call();
}
}
㈨ C语言编译警告问题
你那个数组赋值有问题。
㈩ C语言编译警告
void
main(void);函数被定义多次,这么明显的错误肯定是其他.c文件定义了main函数了
另外你的这种写法完全不符合c99啊
void
main(void)
应该写成
int
main(void);或者
int
main(char
*argc,char*
argv[])