C++错误C3848:具有类型“XXX”的表达式会丢失一些 const-volatile 限定符以调用“XXX”

问题 当对set使用自定义排序函数时会出现此问题

我的代码如下

struct myCom {
	bool operator()(int a, int  b) {
		return a > b;
	}
};

然后就报错 :
C++错误C3848:具有类型“int ”的表达式会丢失一些 const-volatile 限定符以调用“int”

解决方案如下:

struct myCom {
	bool operator()(int a, int  b) const{
		return a > b;
	}
};

解释

因为set不允许修改值,所以你的自定义比较函数必须声明为const的函数,表示你不会修改值。

struct a{
const int func1(int a,int b){
//这里表示函数的返回值不可修改
}

}
struct a{
 int func1(int a,int b) const{
//这里表示你的函数不会修改成员的值,也只能访问同类的成员函数
}

}

感谢原作者
原文链接

  • 2
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
这个模板类的实现比较简单,它使用了 C++11 中引入的 `typename` 和 `std::remove_cv` 类型转换工具类。 具体来说,这个模板类定义了一个嵌套的 `type` 类型,用于存储从原始类型中移除了顶层 `const` 和 `volatile` 限定符的新类型。在模板类中,我们首先使用 `std::remove_cv` 工具类,将原始类型中的 `const` 和 `volatile` 限定符移除掉。然后,我们将结果赋值给 `type` 类型,使得 `type` 成员类型指向移除限定符后的新类型。 具体的代码如下: ```cpp template<class _Ty> struct remove_cv { // 使用 std::remove_cv 移除顶层 constvolatile 限定符 typedef typename std::remove_cv<_Ty>::type _T1; // 如果原始类型const volatile 修饰的指针或引用,需要进一步移除修饰符 typedef typename std::conditional< std::is_same<_Ty, _T1>::value, typename std::conditional< std::is_volatile<_Ty>::value, volatile typename std::remove_cv<_Ty*>::type, typename std::remove_cv<_Ty*>::type >::type, typename std::remove_cv<_T1&>::type >::type type; }; ``` 上面的代码中,我们使用了 `std::conditional` 类型转换工具类,根据原始类型是否是 `const volatile` 修饰的指针或引用,来决定是否需要进一步移除修饰符。如果原始类型是 `const volatile` 修饰的指针或引用,则需要先移除指针或引用的 `const` 和 `volatile` 限定符,然后再添加回去。否则,我们可以直接移除引用的 `const` 和 `volatile` 限定符。这样,就得到了一个移除了所有顶层 `const` 和 `volatile` 限定符的新类型

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值