C++对C的加强 总结(3)

三目运算符增强


int main()

{

int a = 10;

int b = 20;

//返回一个最小数 并且给最小数赋值成3

//三目运算符是一个表达式 ,表达式不可能做左值

(a < b ? a : b )= 30;

printf("a = %d, b = %d\n", a, b);

system("pause");

return 0;

}

1)C语言返回变量的值 C++语言是返回变量本事

2)

C语言中的三目运算符返回的是变量值,不能作为左值使用

C++中的三目运算符可直接返回变量本身,因此可以出现在程序的任何地方

注意:

3)

三目运算符可能返回的值中如果有一个是常量值,则不能作为左值使用

(a < b ? 1 : b )= 30;

4)C语言如何支持类似C++的特性那?

变量的本质是内存空间的别名,是一个标号。

const专题讲座


const int a;

int const b;

const int *c;

int * const d;

const int * const e ;

含义:

//第一个第二个意思一样 代表一个常整形数

//第三个 c是一个指向常整形数的指针(所指向的内存数据不能被修改,但是本身可以修改)

//第四个 d 常指针(指针变量不能被修改,但是它所指向内存空间可以被修改)

//第五个 e一个指向常整形的常指针(指针和它所指向的内存空间,均不能被修改)


结论:

C语言中的const变量

C语言中const变量是只读变量,有自己的存储空间

C++中的const常量

可能分配存储空间,也可能不分配存储空间

当const常量为全局,并且需要在其它文件中使用

当使用&操作符取const常量的地址

符号表、编译过程中若发现对const使用了extern或者&操作符,则给对应的常量分配存储空间(兼容C)


int main()

{

const int a = 10;

int *p = (int*)&a;

printf("a===>%d\n", a);

*p = 11;

printf("a===>%d\n", a);

printf("Hello......\n");

return 0;

}


C++中的const常量类似于宏定义

const int c = 5; ≈ #define c 5

C++中的const常量在与宏定义不同

const常量是由编译器处理的,提供类型检查和作用域检查

宏定义由预处理器处理,单纯的文本替换

引用专题讲座


1、 引用是C++的概念,属于C++编译器对C的扩展

int main()

{

int a = 0;

int &b = a; //int * const b = &a

b = 11;  //*b = 11;

return 0;

}


2、 普通引用有自己的空间吗?

struct Teacer {

int &a;

int &b;

};

int main()

{

printf("sizeof(Teacher) %d\n", sizeof(Teacer));

system("pause");

return 0;

}


3、 //当实参传给形参引用的时候,只不过是c++编译器帮我们程序员手工取了一个实参地址,传给了形参引用(常量指针)

C++对C函数增强

内联函数


1)内联函数在编译时直接将函数体插入函数调用的地方

2)inline只是一种请求,编译器不一定允许这种请求

3)内联函数省去了普通函数调用时压栈,跳转和返回的开销


默认参数

函数默认参数的规则

只有参数列表后面部分的参数才可以提供默认参数值

一旦在一个函数调用中开始使用默认参数值,那么这个参数后的所有参数都必须使用默认参数值


/*

函数占位参数

占位参数只有参数类型声明,而没有参数名声明

一般情况下,在函数体内部无法使用占位参数

*/


默认参数和占位参数

int func(int a, int b, int = 0)

{

return a + b;

}

int main66(int argc, char *argv[])

{

printf("func(10, 20) = %d\n", func(10, 20));

printf("Press enter to continue ...");

getchar();

return 0;

}

C++对C的加强 总结(3),布布扣,bubuko.com

时间: 2024-10-03 22:47:26