C++ 语句函数再探

1. 表达式只计算,抛弃计算结果;

2. 空语句什么也不做;

3.switch case语句漏写break,将会从匹配到的情况开始执行,直到语句结束

int main()
{
   int i = 0;
   i + 100;     //表达式
   ;            //空语句
   while(cin >> i && i != 0)
   ;            //空语句
   switch(i){
       case 1:
       cout << "1" << endl;
       case 0:  //开始执行
       cout << "0" << endl;
       case 2:
       cout << "2" << endl; 
       default:
       cout << "3" << endl;//执行结束
   }
   return 0;
}

4. 形参、实参、局部变量、静态局部变量

所谓形参就是占位之用,在函数开始时申请空间,并由传入实参进行实例化(也可称拷贝构造)。一般是局部的,即只能在函数体内可见。

实参用来实例化/初始化形参

局部变量的作用域是函数体或者语句内部,但是加上static修饰就变成了静态局部变量,它作用域还是该函数体,但生命期延长到了程序终止。

int countCalls(int a, int b)
{
    static int calls = 0;//静态局部变量
    return ++calls;
}

int main()
{
    for(int i=0; i<5; i++)
        cout << countCalls(1, 2) << endl;
    //cout << calls << endl;//无法访问
    return 0;
}

5. 函数返回值,还是发生了拷贝,即用函数体内的某变量初始化函数调用点的某临时量。

6. 不要返回局部变量的引用或指针,返回后就销毁了,没地儿去找了。

7. 引用返回左值,其他类型返回的是右值。

8. 内联函数适用于优化规模较小、流程直接、频繁调用的函数。

9. 有趣的返回错误信息的宏(静态变量)

void trouble(int m)
{
    if(m == 0)
    {
        cout << "Error : " << __FILE__;
        cout << " in function  " << __func__;
        cout << " at line " << __LINE__;
        cout << " complie on " << __DATE__;
        cout << " at " << __TIME__;
    }
}

10.函数重载二义性

(1)无参函数VS有参有默认值,歧义

int get(){
    return a;
}
int get(int a = 5){
    return a;
}
//调用get()

(2)传值VS传引用,歧义

int get(int a){
    return a;
}
int get(int &a){
    return a;
}
//int m = 10;
//调用get(m)

(3)参数存在隐式类型转换,歧义

int get(int m){
    return m;
}

long get(long m){
    return m;
} 
//double m = 10.123
//调用get(m)

参考资料

【1】https://blog.csdn.net/chenxiaohua/article/details/2128899 (有点问题)

【2】https://blog.csdn.net/loving_forever_/article/details/51472127 (有点问题)

原文地址:https://www.cnblogs.com/yocichen/p/11108670.html