const 和volatile

const:修饰的变量是只读的;

            修饰的变量会在内存占用空间;

            本质上const只是对编译器有用,在程序运行时无用;

            修饰的值可以通过指针来改变,故const不是真正意义上的常量;

            修饰的数组空间不可被改变。

volatile:可理解为“编译器告警指示字”;

               告诉编译器每次去内存中取变量的值;

               主要修饰可被多个线程访问的变量;

               也可修饰可能被未知因素更改的变量。

综上const volatile int i=0;是合法的,const定义了一个只读变量,即i不能为左值,但是当取用i时会到内存中读取,因为既然是const的,i认为是不变的。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 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、付费专栏及课程。

余额充值