1.  C语言中的const

(1)const修饰的变量是只读的,使得变量具有只读属性,但本质还是变量。所以不是真正的常量,它只是告诉编译器该变量不能出现在赋值符号的左边。

(2)const修饰的局部变量栈上分配空间全局变量只读存储区分配空间

(3)const只在编译期有用,在运行期无用

【编程实验】C/C++中的const

#include <stdio.h>

int main()
{
const int c = ; //C语言中会为变量c分配内存
int* p = (int*)&c; //C++中遇到&才为c分配内存 printf("Begin...\n"); *p = ; //内存中的值己被改为5. printf("c = %d\n", c);//C语言会输出内存中的5.
//C++中会从符号表(而不是内存)中取值
//所以为0. printf("End...\n");
return ;
}

2. C++中的const

(1)C++在C的基础上对const进行了优先处理,当碰见const声明时在符号表中放入常量。

(2)编译过程中若发现使用常量,则直接以符号表中的值替换

(3)编译过程中若发现对const常量使用了extern&操作符,则会给对应的常量分配存储空间。注意,C++编译器虽然可能为const常量分配空间,但不会使用其存储空间中的值。

3. 对比C/C++中的const

C语言

C++

本质

只读变量

常量

分配内存

会分配

当使用&操作符对const常量取地址时分配

当const常量为全局,并且需要在其它文件中使用时会分配内存

4. C++中的const与宏的区别

C++中的const

定义

const int c = 5;

#define c 5

处理方式

编译器处理,编译器会进行类型检查作用域检查

预处理器处理,只是简单的文本替换

【编程实验】const与宏

#include <stdio.h>

void f()
{
//宏由预编译处理,其后面的宏起作用
#define a 3 const int b = ;//作用域仅限于f函数
} void g()
{
printf("a = %d\n", a); //合法,只要是宏定义之后都可以使用 //printf("b = %d\n", b); //非法b的作用域仅限于f函数
} int main()
{
const int A = ;
const int B = ;
int array[A + B] = {};//C++中合法,因为它认为A、B都是常量。
//而C语言的const本质还是变量,数组大小只能是常量 int i = ; for(i=;i<(A + B); i++)
{
printf("array[%d] = %d\n", i, array[i]);
} f();
g(); return ;
}

5. 小结

(1)与C语言不同,C++中的const不是只读变量

(2)C++中的const是一个真正意义上的常量

(3)C++编译器可能会为const常量分配空间

(4)C++完全兼容C语言中的const常量的语法特性

第3课 进化后的 const分析的更多相关文章

  1. 第3课 进化后的const分析

    C语言中的const const修饰的变量是只读的,本质还是变量 const修饰的局部变量在栈上分配空间(改变这个空间的值,这个变量就会改变) const修饰的全局变量在只读存储区分配空间 const ...

  2. 进化后的const分析

    C语言中的const const修饰的变量是只读的,本质还是变量 const修饰的局部变量在栈上分配空间 const修饰的全局变量在只读存储区分配空间 const只在编译期有用,在运行期无用 注意:c ...

  3. C++解析(2):进化后的 const 分析

    0.目录 1.C语言中的const 2.C++中的const 3.对比 3.1 C语言与C++中的const 3.2 C++中的const与宏定义 4.小结 1.C语言中的const const修饰的 ...

  4. 第3课.进化后的const

    1.c语言中 const修饰的变量是只读的,本质上还是变量 const修饰的局部变量在栈上分配空间(因为在栈上分配空间,所以我们可以通过改变这个空间的值.间接去改变这个变量.) const修饰的全局变 ...

  5. C++ 成员函数前和函数后加const修饰符区别

    博客转载自: https://www.iteblog.com/archives/214.html 分析以下一段程序,阐述成员函数后缀const 和 成员函数前const 的作用 #include< ...

  6. [阿里DIEN] 深度兴趣进化网络源码分析 之 Keras版本

    [阿里DIEN] 深度兴趣进化网络源码分析 之 Keras版本 目录 [阿里DIEN] 深度兴趣进化网络源码分析 之 Keras版本 0x00 摘要 0x01 背景 1.1 代码进化 1.2 Deep ...

  7. [Reprint]C++函数前和函数后加const修饰符区别

    c++中关于const的用法有很多,const既可以修饰变量,也可以函数,不同的环境下,是有不同的含义.今天来讲讲const加在函数前和函数后面的区别.比如: 01 #include<iostr ...

  8. C++函数前和函数后加const修饰符区别

    class Test(){ public: Test(){} const int foo(int a); const int foo(int a) const; }; 一.概念 当const在函数名前 ...

  9. C++类的成员函数的形参列表后面的const

    看到(C++ Primer)类的成员函数这里,突然对成员函数形参列表后面的const感到迷惑. 因为书中开始说是修饰隐含形参this的,然后又说是声明该函数是只读的. 大为不解! 翻资料.找人讨论.. ...

随机推荐

  1. Android中Parcel的分析以及使用

    简单点来说:Parcel就是一个存放读取数据的容器, Android系统中的binder进程间通信(IPC)就使用了Parcel类来进行客户端与服务端数据的交互,而且AIDL的数据也是通过Parcel ...

  2. android系列9.LinearLayout学习

    <!-- <LinearLayout> 线性版面配置,在这个标签中,所有元件都是按由上到下的排队排成的 --> <LinearLayout xmlns:android=& ...

  3. 【linux基础】core dump debug

    1.check core dump; ulimit -c or ulimit -a nvidia@tegra-ubuntu:~$ ulimit -a core data seg size (kbyte ...

  4. TX2-start 6 CPU kernel-开启高功耗模式

    1.TX2简介 Jetson TX2是由一个GPU和一个CPU集群组成.CPU集群由双核denver2处理器和四核ARM Cortex-A57组成,通过高性能互连架构连接.拥有6个CPU核心和一个GP ...

  5. cloneNode

  6. / is not a valid selector

  7. grandstack 基于graphql&&react&& apollo&& neo4j 的全栈开发工具

    grandstack是一个基于graphql&&react&& apollo&& neo4j 的全栈开发工具. 有篇关于graphql 的5个常见问题的 ...

  8. fork 开源项目后如何参与项目

    好的开源项目都很想参与到开源活动中,并且会 fork 一份. 经过几个月的学习,大概明白了如果参与开源项目. 当完成 fork 后,就需要在本地 git clone 一份. 有新的功能或需要修复的就开 ...

  9. Spring Cloud Netflix项目进入维护模式

    任何项目都有其生命周期,Spring Could Netflix也不例外,官宣已进入维护模式,如果在新项目开始考虑技术选型时要考虑到这点风险,并考虑绕道的可能性. 原创: itmuch  IT牧场 这 ...

  10. JUC集合之 ConcurrentSkipListSet

    ConcurrentSkipListSet介绍 ConcurrentSkipListSet是线程安全的有序的集合,适用于高并发的场景. ConcurrentSkipListSet和TreeSet,它们 ...