传智播客旗下品牌:  黑马程序员  |  博学谷  |  传智专修学院

一样的教育,不一样的品质     全国咨询热线:400-618-4000

C/C++技术:最容易犯错的知识点(一)

更新时间:2017年11月30日15时32分 来源:传智播客

1、赋值构成一个表达式,具有值,其值为赋值符左边表达式的值。表达式和语句的一个重要区别是,表达式有值,而语句没有值。

2、隐式类型转换总是朝着表达数据能力更强的方向,并且转换总是逐个运算符进行的。如

float f=3.5;

int n=6;

long k=21;

double ss=f*n+k/2;//在计算ss时,首先将f和n转换成double,算得21,然后计算k/2得10,再将10(long int)转换成double,最后得31。

27、C++基础笔记(一) - EdwardLewis - 墨涵天地

有符号数向无符号数转换。

3、当又有声明又有定义时,定义中不允许出现默认参数,如果函数只有定义,才允许默认参数出现在定义中。默认值可以是一个全局变量,全局常量,或是一个函数,但是不能是局部变量,因为默认参数的函数调用是在编译时确定的,而局部变量的位置和值在编译时是无法确定的。如

int a=1;

void fun()

{

int i;

void g(int x=i); //not right

int g(int x=a); //right

}

4、define宏定义指令

1) 使用其定义常量已被C++中的const定义语句所代替。

2) 用来定义带参数的宏,已被C++的内联函数所代替。

3) 其一个有效的使用是在条件编译中。

5、编译时必须知道数组的大小。如

int a[]={1,2,3,4,5};//编译器会自动去数

for(int i=0;i

...

6、C++会把注释当做空格。

7、Free和malloc

int* a;

a=(int*)malloc(sizeof(int));

cout<

free((void*)a);

int* b;

b=(int*)malloc(12*sizeof(int));

cout<

指向常量的指针常量:具有上述两具指针的特点,须在定义时初始化,且一旦赋值,则以后该指针的值将不会再发生变化,且通过指针不能改变所指向的变量的值,形如const int* const cpc="perfect";注意,这种情况下,*cpc的值也是不能改变的,如*cpc=n是不对的。

int main()

{

char* const pc="abcd";

cout<

cout<<*pc<

//*pc='b'; //有些编译器可以通过,但是结果不对的

//cout<

const char* const cpc="perfect";

cout<

cout<<*cpc<

*cpc='n';//not right

cout<

return 1;

}

9、sum(int array[],int n)与sum(int* array,int n)是等价的。

10、函数返回值,可以返回堆地址,也可以返回全局或静态变量的地址,但是不能返回局部变量的地址。

11、void指针是空类型指针,它不指任何类型,它仅仅是一个地址,不能进行指针运算,也不能进行间接引用。

NULL与void* 是不同的概念,NULL是一个指针值,任何类型的指针都可赋予该值。而void* 是一种类型(语法上是一个类型,本质上不是,没有任何一个变量或对象,其类型为void),是一种无任何类型的指针。不允许对void进行引用。

12、由引号(" ")标识,但不是用来初始化数组的字符串,是字符串常量,如cout<<"hello"<

由于字符串常量的地址属性,两个同样字符组成的字符串常量是不相等的, 字符串常量的比较是地址的比较。

字符串常量,字符数组名(常量指针),字符指针均属于同一种数据类型。

13、不能建立引用的数组,因为数组是某个数据类型的集合,数组名表示起始地址,它不是数据类型。如

int a[10];

int& a1[10]=a; //not right

引用本身不是一种数据类型(int&不是类型,定义时也不产生内存空间),所以没有引用的引用。也没有引用的指针。引用是变量或对象的引用,而不是类型的引用,所以有空指针,但是没有空引用。

Int& ri=NULL //没有意义

可以用引用返回值。在通常情况下,C++会建立一个临时变量以将函数返回值带回。但是如果用引用,则不用建立临时变量。

C++规定,临时变量或对象的生命周期在一个完整的语句表达式结束后便宣告结束。所以如果以返回值初始化一个引用,应当先建立一个变量,将函数返回值赋于这个变量,作如下处理:

int x=fn1(5.0); //在这一句后临时变量生命周期将结束

int& b=x;

*************************

float temp;

float& fn2(float r)

{

temp=10*r;

return temp;

}

用如上的方法,则函数返回值将不再创建临时变量,而直接与全局变量temp共享内存单元

*******************************

以引用的初始化,可以是变量,也以是常量,也可以是一定类型的堆空间变量,但是引用不是指针,如下表达是不对的:

int& a=new int(2); //not right

下面是用堆空间变量初始化引用的一个例子:

#include

#include

using namespace std;

int main()

{

double* pd=new double;

if(pd==NULL)

{printf("failed");exit(1);}

cout<

本文版权归传智播客C/C++学院所有,欢迎转载,转载请注明作者出处。谢谢!
作者:传智播客C/C++学院
首发:http://www.itcast.cn/c/