const和volatile

const只读变量

const修饰的变量是只读的,本质还是变量
const修饰的局部变量在栈上分配空间
const修饰的全局变量在全局数据区分配空间
const只在编译期有用,在运行期无用
const修饰的变量不是真的常量,只是告诉编译器该变量不能出现在赋值符号的左边
#include <stdio.h>
const int g_cc = 2;
int main()
{
	const int cc = 1;
	int* p = (int*)&cc;
	printf("cc = %d\n",cc);
	*p = 3;
	printf("cc = %d\n",cc);
	int* g_cc_p = (int*)&g_cc;
	printf("g_cc = %d\n",g_cc);
	*g_cc_p = 4;
	printf("g_cc = %d\n",g_cc);
	return 0;
}
gcc编译器运行结果:

bcc编译器运行结果:

const的本质

-C语言中const使得变量具有只读属性
-现代C编译器中的const将具有全局生命周期的变量存储于只读存储区
-const不能定义真正意义上的常量
#include <stdio.h>
const int g_array[5] = {0};
void modify(int* p,int v)
{
	*p = v;
}
int main()
{
	int const i = 0;
	const static int j = 0;
	int const array[5] = {0};
	modify((int*)&i,1);
//	modify((int*)&j,2);  //error
	modify((int*)&array[0],3);
//	modify((int*)&g_array[0],4);  /error
	printf("i = %d\n",i);
	printf("j = %d\n",j);
	printf("array[0] = %d\n",array[0]);
	printf("g_array[0] = %d\n",g_array[0]);
	return 0;
}
运行结果:

const修饰函数参数和返回值

-const修饰函数参数表示在函数体内不希望改变参数的值
-const修饰函数返回值表示返回值不可改变,多用于返回指针的情形
注意:
C语言中的字符串字面量存储于只读存储区中,在程序中需要用const char* 指针
#include <stdio.h>
const char* f(const int i)
{
//	i = 5;
	return "taoshigang";
}
int main()
{
	const char* pc = f(0);
	printf("%s\n",pc);
//	pc[6] = '_';
	printf("%s\n",pc);
	return 0;
}
运行结果:


volatile 关键字

volatile可理解为”编译器警告指示字“
volatile告诉编译器必须每次去内存中取变量值
vilatile主要修饰可能被多线程访问的变量
volatile也可以修饰可能被未知数更改的变量

const volatile int i = 0;
解释:变量i每次从内存中取值,编译器不做优化,并且i不能出现在赋值符号的左边

小结:

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
提供的源码资源涵盖了安卓应用、小程序、Python应用和Java应用等多个领域,每个领域都包含了丰富的实例和项目。这些源码都是基于各自平台的最新技术和标准编写,确保了在对应环境下能够无缝运行。同时,源码中配备了详细的注释和文档,帮助用户快速理解代码结构和实现逻辑。 适用人群: 这些源码资源特别适合大学生群体。无论你是计算机相关专业的学生,还是对其他领域编程感兴趣的学生,这些资源都能为你提供宝贵的学习和实践机会。通过学习和运行这些源码,你可以掌握各平台开发的基础知识,提升编程能力和项目实战经验。 使用场景及目标: 在学习阶段,你可以利用这些源码资源进行课程实践、课外项目或毕业设计。通过分析和运行源码,你将深入了解各平台开发的技术细节和最佳实践,逐步培养起自己的项目开发和问题解决能力。此外,在求职或创业过程中,具备跨平台开发能力的大学生将更具竞争力。 其他说明: 为了确保源码资源的可运行性和易用性,特别注意了以下几点:首先,每份源码都提供了详细的运行环境和依赖说明,确保用户能够轻松搭建起开发环境;其次,源码中的注释和文档都非常完善,方便用户快速上手和理解代码;最后,我会定期更新这些源码资源,以适应各平台技术的最新发展和市场需求。
这个模板类的实现比较简单,它使用了 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、付费专栏及课程。

余额充值