C++学习(63)

1 float x与“零值”比较的if语句为:if(fabs(x)<0.00001f)或 if(Math.abs(x)<0.00001f)

分析:folat类型的还有double类型的,这些小数类型在趋近于0的时候直接等于0的可能性很小,一般都是无限趋近于0.因此不能用==来判断。应该用|x-0|<err来判断,这里|x-0|表示绝对值,err表示限定误差 。用程序表示就是fabs(x)<0.00001f 


不可将浮点变量用“==”或“!=”与任何数字比较。  千万要留意,无论是float还是double类型的变量,都有精度限制。所以一定要避免将浮点变量用“==”或“!=”与数字比较,应该设法转化成“>=”或“<=”形式。假设浮点变量的名字为x,应当将 if (x == 0.0) 转化为   if ((x>=-EPSINON) && (x<=EPSINON)) 
或者 if ( fabs(x) <=EPSINON)  // fabs(x)取x的绝对值 。其中EPSINON是允许的误差(即精度)。


2.因为静态成员存在于内存,非静态成员需要实例化才会分配内存,所以静态成员函数不能访问非静态的成员。因为静态成员存在于内存,所以非静态成员函数可以直接访问类中静态的成员。


3 下面有关C++类说法正确的是(AD)

  • 对基类成员的访问必须是无二义性的
  • 基类的公有成员在派生类中仍然是公有的
  • this指针保证基类保护成员在子类中可以被访问
  • 派生类一般都用公有派生
分析:AD
B:基类的公有成员在派生类中权限由派生规则决定
C:this 代表本类

基类成员在派生类当中的属性根据继承方式不同而有别,B错误; 
this只对本类的非静态成员有效,C不正确。 


4  如下程序用于输出"Welcome to Huawei Test",指出错误:1、 3

char * GetWelcome(void){
    char * pcWelcome;
    char * pcNewWelcome;
    pcWelcome="Welcome to Huawei Test";
    pcNewWelcome=(char *)malloc(strlen(pcWelcome));    //1
    if(NULL==pcNewWelcome){
        return NULL;        //2
    }
    strcpy(pcNewWelcome, pcWelcome);    //3
    return pcNewWelcome;            //4
}
分析:1处,正确形式是:pcNewWelcome=(char*)malloc(strlen(pcWelcome)*sizeof(char)) ,当然形式上对了。但是逻辑上呢?strlen()统计字符个数,不含结尾符'\0',所以这样子分配会少一个字节。3处,由1处,既然新分配的空间少了一个字节,你用原来的来复制到新的里?能装下吗?不能。



分析二:第一处:malloc动态分配的内存是在堆上的,需要进行free()函数释放,这里假设是分配正确的,这样第四处就可以认为是正确的,因为它还没有释放。 第二处:可以认为是在strcpy函数执行前的自检测,如果为NULL,由实现者决定其返回值,一般为NULL。 第三处:strcpy函数的功能是把从src地址开始且含有'\0'结束符的字符串复制到以dest开始的地址空间。但是在第一处进行动态分配内存的时候使用的是strlen而不是sizeof,这样就少了'\0'结束符,不能正确进行复制操作。 因此,第一处和第三处是错误的。

5 C++语言中,有关类的初始化叙述正确的是(AD)

A 静态函数不能出现this指针

B 可以在类定义时,对对象直接初始化

C 一般数据类型可以在类的外部进行初始化

D 静态数据类型可以在类的外部进行初始化


分析:静态常量可不可以在内部初始化,这个跟编译器支持有关,即使支持也只对整数常量。 static是类的,构造函数是对象的,所以不能在构造函数中初始化。const static仍然是static


A:静态函数属于类本身,不与类绑定,因此不能用this指针。A选项正确。 
B:在类定义时,无法使用构造函数,因而无法完成对象的初始化 
C:一般成员变量需要在类内进行初始化 
D:静态成员变量必须在类外初始化,静态成员常量在类中初始化。D选项正确。  

6 .在C++STL中常用的容器和类型,下面哪些支持下标"[]"运算?
A vector
B list
C deque
D map
E set
F unordered_map
G unordered_set
H stack
I string

分析:支持随机访问就支持[] ACDFI
vector:随机访问迭代器,复杂度O(1)
deque:同上,O(1)
map:双向迭代器,不过由于是关联容器,需要通过key访问alue的方法,O(h),h为树的高度
unordered_map:前向迭代器,同上,平摊复杂度O(1),最差O(n),也与散列函数的好坏有关。
string:同vector


  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值