C++中的编译器警告(级别1) C4172 返回局部变量或临时对象的地址

编译器警告(级别1) C4172 返回局部变量或临时对象的地址

对于这样一个警告,其实是在告诉你不要对一个非成员函数,做返回局部对象的地址or局部变量的地址这样的SB操作!

你又不需要这个函数do链式编程等工作(事实上也do不来!),你想啥呢?干啥要返回这个变量/对象对应类型的引用&呢?

请看以下代码:

//这是个给运算符定义优先级函数 (简易版本)

multimap<char, int>& createOperatorYouxianji(char* operaTor)
{
	multimap<char, int> mmp;
	for (int j = 0; j < MAXOPERATOR; j++) {
		switch (operaTor[j])
		{
		case '+':mmp.insert(make_pair(operaTor[j], 0));; break;//把+ - 号的优先级定义为0
		case '-':mmp.insert(make_pair(operaTor[j], 0));; break;
		case '*':mmp.insert(make_pair(operaTor[j], 1));; break;//把* / 号的优先级定义为1
		case '/':mmp.insert(make_pair(operaTor[j], 1));; break;
		case '%':mmp.insert(make_pair(operaTor[j], 2));; break;//把  % 号的优先级定义为1
		default: break;
		}
	}
	return mmp;
}

你这里就很明显返回了multimap<char, int>&

而return 的mmp 是个临时的multimap容器类的对象啊,你这样搞肯定报错的!

因为:

multimap<char, int>& 明显是错误的返回值类型!因为这个函数不是成员函数,你这样用没意义的同时当函数调用完毕之后临时的对象or临时的变量因为是作为栈帧在调用该函数时给push进OS的栈区中的当你调用该函数完毕后,栈区会pop掉这个函数的all的栈帧,也即这里的mmp对象给pop掉了,给释放掉了那么你此时返回的multimap<char, int>&类型的变量由于和你这个临时变量共用一个内存地址(谁叫你返回一个引用&呢?这就使用引用&的后果),那么此时最终的结果就是存储这个函数返回值的内存地址被释放掉了,你再也没有权限去访问这块内存地址了,此时当然IDE会给你一个异常error啦!

正确的写法是把上面的&符号去掉!

  • 1
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

Fanfan21ya

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值