const和 define在常量定义上的差别 在C++中,我们可以使用const 或者 宏define来定义常量.但是C++鼓励使用const定义常量,而不是宏define.原因有很多. 1.define是C遗留下来的老古董,const比define更优雅,更符合符号常量的本意. 2.define用在复杂的代码中,不理解define的实质的人就会出问题.define是代码字面上的替换,预处理阶段还原替换的内容. const定义的常量可以说是“不变的变量“,因为它确实用了一个变量取保存某个不会发生…
一.引用 (1).引用是给一个变量起别名 定义引用的一般格式:类型  &引用名 = 变量名: 例如:int a=1;  int  &b=a;// b是a的别名,因此a和b是同一个单元 注意:定义引用时一定要初始化,指明该引用是谁的别名 在实际应用中,引用一般用作参数传递与返回值 引用不是变量,引用仅仅只是变量的别名,引用没有自己独立的空间,引用要与它所引用的变量共享空间,对引用所做的改变实际上是对它所引用的变量的改变,引用在定义的时候要进行初始化,引用一经初始化,不能重新指向其他变量. (…
const可以放在成员方法的三个地方,前.中.后. 首先考虑在中间: 1.const修饰形参,表示形参是否为const 2.如果const修饰引用(指针指向的对象),可以进行过载,如果不是修饰引用(指针指向的对象),不能进行过载.为什么? 首先考虑引用,引用是一个对象的别名,在调用的时候,编译器根据原对象的常量性,可以找到一个最匹配的方法.const修饰指针指向的对象,和引用是同样的道理.如果const不是修饰引用或者指针指向的对象,就不能过载.因为,这种情况下,是整体拷贝,拷贝后的对象和原对象…
问题1:const什么时候为只读变量?什么时候是常量? const常量的判别准则: a.只有用字面量初始化的const常量才会进入符号表(直接初始化过的const为常量) b.被使用其他变量初始化的const常量仍然是只读变量(间接初始化的const为只读变量) c.被volatile修饰的const常量不会进入符号表(volatile:易变的.每次都要去内存中取出值.所以也是只读变量.voaltile易变的在这里决定了cosnst不可能是一个常量:const则说明在当前的作用域当中,修饰的变量…
[源码下载] 不可或缺 Windows Native (18) - C++: this 指针, 对象数组, 对象和指针, const 对象,  const 指针和指向 const 对象的指针, const 对象的引用 作者:webabcd 介绍不可或缺 Windows Native 之 C++ this 指针 对象数组 对象和指针 const 对象 const 指针和指向 const 对象的指针 const 对象的引用 示例1.CppEmployee 类CppEmployee.h #pragma…
1.Lambda表达式与接口之间的关系 只要Lambda表达式的声明形式与接口相一致,在很多情况下都可以替换接口.见如下代码 Thread t1 = new Thread(new Runnable() { public void run() { System.out.println("hi"); } }); t1.start(); Thread t2 = new Thread(() -> System.out.println("hi")); t2.start(…
一.函数原型声明: 1.函数声明告诉编译器函数的名称,和如何调用函数(返回类型和参数):函数定义提供了函数的实际主体. 2.强制性的:在C++中,如果函数调用的位置在函数定义之前,则要求在函数调用之前必须对所调用的函数作函数原型声明. 3.在函数声明中,参数名称并不重要,只有参数类型是必须的.即下述两种写法都被允许: int max(int x,int y); int max(int,int); 4.当函数定义 (func.cpp) 与代码主体 (main.cpp) 分开时,在 main.cpp…
1. const指针和 指向const的指针 指向const的指针: 不允许通过指针来改变其指向的const值 const double *cptr *cptr = 42;  // error! 指针代表的值无法修改 const double pi =3.14 double *ptr = &pi //error ! 无法将指向const的指针赋值给非非const指针: const double *cptr = &pi //ok const 指针:本身值无法修改,即指针指向的地址无法修改 i…
const与指针类型 定义一个指针*p: const int* p = NULL; int const* p = NULL; int* const p = NULL; 上面两行定义完全等价,第三行则不同. 下面两行定义也完全等价: const int* const p = NULL; ; const int* p = &x; //p=&y; 正确 ; int* const p = NULL; ; const int* const p = &x; ; const int& y…
const和指针到底有何姻缘呢? char const *p = NULL; //char const 和 const char 是一样的,p 是一个指向常整型的指针变量 ,指针变量的值不能改变 char * const p = NULL; //p 是一个指向整型的常量指针 ,指针的值不能改变 例证: 总结: *左const ,指针变量值不变 *右const ,指针不变…