const关键字以及const和#define的区别

1.const

- 1.const修饰变量、参数、返回值:

在C++中const修饰变量,使变量变成常量,在声明的同时必须初始化;C++的const修 饰的全局变量可以作为属组的初始化的大小,而C不可以,同时变量的值不能被修改;C++利用const的这一属性,代替C中的define进行全局常量的定义;C++会将const修饰的常量进行优化,将常量存储在寄存器中,如果需要在内存中读取需要使用volatile关键字修饰,保证内存可见性。在C中const会将变量修饰为常变量,存储在静态文本段,只有读权限,不能被修改。

- 2.const修饰指针:

const在*左边,不能改变指针指向的值,const在*右边不能改变指针的指向

- 3.const修饰引用:

可以把引用绑定到const对象上,常量的引用不能修改它所绑定的对象

- 4.const修饰成员变量:

const修饰的成员变量必须在初始化列表里面初始化;除此之外,必须在初始化列表初始化的还有引用类型的数据成员,没有默认构造函数的 对象成员,如果存在继承关系,如果父类没有默认的构造函数,则也 必须在初始化列表中被初始化,初始化列表对数据成员的初始化顺序 是按照数据成员的声明顺序严格执行的;

- 5.const修饰成员函数:

一般放在成员函数的最后面,修饰的是类的成员,在成员函数的后面加上const,const修饰this指针指向的对象,代表不可以通过this指针修改类的数据 成员,声明形式例如: Base::void fun() const; 也就是保证调用const成员函数的对象在成员函数内部不会改变。const修饰的成员函数只能调用const成员变量,非const修饰的成员函数可以调用const成员函数和const成员函数

2. 宏和const常量的区别

- 1.宏没有类型检查,只是字符的替换,而且可能由于边际效应在字符替换时产生意料不到的错误;const常量有严格的类型检查
- 2.宏常量不开辟内存空间,const常量开辟内存空间
- 3.有些集成化的调试工具可以对const常量进行调试,但不能对宏常量进行调试
- 4.c++中const完全取代宏

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值