几个编译警告的问题 怎么修改能去掉警告啊

轻描淡写Sophia 2012-05-11 02:19:24
1.
LPCTSTR CRegEx::GetValueSZ(LPCTSTR szName)
{
TCHAR tchPath[MAX_PATH];
GetValueSZ(szName,tchPath,MAX_PATH);
return tchPath;
}

编译后警告:warning C4172: returning address of local variable or temporary

2.
char cTemp = '-1';

编译后警告:
warning C4309: 'initializing' : truncation of constant value

3.
头文件 atlosapice.h 和 Pwinuser.h 中 WM_NCDESTROY 重定义了
warning C4005: 'WM_NCDESTROY' : macro redefinition Pwinuser.h

我查了 一下,工程中没有添加“atlosapice.h”头文件,不晓得是不是哪个头文件中包含了它,
关于WM_NCDESTROY的定义:
“atlosapice.h”文件中是这样:

#ifndef WM_NCDESTROY
#define WM_NCDESTROY (WM_APP - 1)
#endif

“Pwinuser.h”件中是这样:

#define WM_NCDESTROY 0x0082


这个怎么解决呀?
...全文
564 10 打赏 收藏 转发到动态 举报
写回复
用AI写文章
10 条回复
切换为时间正序
请发表友善的回复…
发表回复
baichi4141 2012-05-11
  • 打赏
  • 举报
回复
除非你清楚一个警告的原因并且确定这个原因无关紧要,否则把所有警告当做错误看待
帅得不敢出门 2012-05-11
  • 打赏
  • 举报
回复
尽量没有警告,而不是忽略它

不要返回临时变量地址

char cTemp = '-1'; // 这个都两个字符了
轻描淡写Sophia 2012-05-11
  • 打赏
  • 举报
回复
[Quote=引用 6 楼 的回复:]

引用 5 楼 的回复:

引用 2 楼 的回复:

1 这个警告可不是闹着玩的,改成如下即可
std::string CRegEx::GetValueSZ(LPCTSTR szName)
{
TCHAR tchPath[MAX_PATH];
GetValueSZ(szName,tchPath,MAX_PATH);
return std::string(tchPath);
……
[/Quote]
那个值不也是局部的吗?
轻描淡写Sophia 2012-05-11
  • 打赏
  • 举报
回复
[Quote=引用 1 楼 的回复:]

TCHAR tchPath[MAX_PATH];为函数的局部变量,那么函数结束后该变量就失去了意义。外部的就不可以再用这变量了。如果真的需要返回函数内部的东西,请定义指针p = (char*)malloc(size)

2 char cTemp = '-1'; 你说一个字符能表示多少东西?'-1'我也不清楚需要多少个,但是一个字符肯定放不下。

3 在Pwinuser.h里同样的使用
……
[/Quote]
第一个问题如果定义成指针分配空间,什么时候释放呀?还是就不能释放了?
yuyoucuobei 2012-05-11
  • 打赏
  • 举报
回复
[Quote=引用 5 楼 的回复:]

引用 2 楼 的回复:

1 这个警告可不是闹着玩的,改成如下即可
std::string CRegEx::GetValueSZ(LPCTSTR szName)
{
TCHAR tchPath[MAX_PATH];
GetValueSZ(szName,tchPath,MAX_PATH);
return std::string(tchPath);
}

2 #pragma w……
[/Quote]

你返回的是一个局部指针,2楼返回的是值
轻描淡写Sophia 2012-05-11
  • 打赏
  • 举报
回复
[Quote=引用 2 楼 的回复:]

1 这个警告可不是闹着玩的,改成如下即可
std::string CRegEx::GetValueSZ(LPCTSTR szName)
{
TCHAR tchPath[MAX_PATH];
GetValueSZ(szName,tchPath,MAX_PATH);
return std::string(tchPath);
}

2 #pragma warning(dis……
[/Quote]

第一个为什么要这样改呀?tchPath不还是局部变量么?
所有的警告都可以用#pragma warning(disable:XXXX)解决掉,但是我担心这样写会影响程序的质量。
第三个问题按照1楼的方法解决啦。。
这些警告都没影响程序功能,就是担心程序运行久了会有bug。
赵4老师 2012-05-11
  • 打赏
  • 举报
回复
#pragma warning(disable:4996)
gemo 2012-05-11
  • 打赏
  • 举报
回复
1 如果编译通不过,把std::string换成std::wstring即可,当然首先要包括头文件#include <string>
gemo 2012-05-11
  • 打赏
  • 举报
回复
1 这个警告可不是闹着玩的,改成如下即可
std::string CRegEx::GetValueSZ(LPCTSTR szName)
{
TCHAR tchPath[MAX_PATH];
GetValueSZ(szName,tchPath,MAX_PATH);
return std::string(tchPath);
}

2 #pragma warning(disable : C4309)

3 第三个应该没什么问题吧,测试下
W170532934 2012-05-11
  • 打赏
  • 举报
回复
TCHAR tchPath[MAX_PATH];为函数的局部变量,那么函数结束后该变量就失去了意义。外部的就不可以再用这变量了。如果真的需要返回函数内部的东西,请定义指针p = (char*)malloc(size)

2 char cTemp = '-1'; 你说一个字符能表示多少东西?'-1'我也不清楚需要多少个,但是一个字符肯定放不下。

3 在Pwinuser.h里同样的使用
#ifndef WM_NCDESTROY
#define WM_NCDESTROY ox0082
#endif

64,647

社区成员

发帖
与我相关
我的任务
社区描述
C++ 语言相关问题讨论,技术干货分享,前沿动态等
c++ 技术论坛(原bbs)
社区管理员
  • C++ 语言社区
  • encoderlee
  • paschen
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告
  1. 请不要发布与C++技术无关的贴子
  2. 请不要发布与技术无关的招聘、广告的帖子
  3. 请尽可能的描述清楚你的问题,如果涉及到代码请尽可能的格式化一下

试试用AI创作助手写篇文章吧