1. 哑元 哑元可以显示的告诉函数调用者,这个位置参数没用,仅仅是为了兼容旧代码。 2. 内联函数 上图左是正常的函数调用过程,从主函数开始执行,中间红色的线是调用的函数。一个函数的调用过程就是先保存当前栈区的数据,即“保护现场”,然后从当前的函数调用语句跳转到函数所在代码段的位置,去执行函数的代码,执行结束以后,再继续回到当前位置,等“恢复现场”以后,继续往下执行。恢复现场是需要一点时间的。如果一个函数被调用多次,这会影响函数的调用效率。内联函数的用处就是,用已编译好的二进制代码来替换掉函数的调用语句,这样就没有程序跳入跳出的过程了,顺次往下执行,提高了代码的执行效率如上图右。比较像宏定义,但宏本质上并不是一个函数,它只是代码原样的文本替换,且是在预处理时完成的替换。而内联函数是在编译器编译时完成。而且内联函数可以使用函数的语法规则。可读性和安全性都比宏好一点。 3. 动态内存管理 new、delete 操作符 3.1 分配释放内存 new可以分配动态内存的同时初始化 3.2 new/delete 数组 new一个数组,parr 指向数组中的第一个元素,并且可以再new的时候对数组进行初始化。如果delete一个数组记得加[] : delete [ ] parrdelete野指针(指向内存地址不确定的指针变量)后果不确定。不能delete两次 3.3 代码示例 #include <iostream> using namespace std; int main(void){ // new 单个元素 int *pi = new int(100); cout << *pi << endl; delete pi; // 避免内存泄漏 pi = NULL; // 避免野指针 // new 数组 int *parr = new int[10]; for (int i = 0; i < 10; i++) { cout << *(parr + i) << ' '; // 等同于 cout << parr[i] << ' '; } cout << endl; delete [] parr; parr = NULL; return 0; } $ g++ a.cc $ ./a.out 100 0 0 0 0 0 0 0 0 0 0