GEEK学习笔记— —程序员面试宝典笔记(二)

来源:互联网 发布:自己录制电台软件 编辑:程序博客网 时间:2024/06/02 05:46

所谓笔记,就是比较个人的东西,把个人觉得有点意思的东西记录下来~~

程序员面试宝典笔记(一)基本概念
程序员面试宝典笔记(二)预处理、const和sizeof
程序员面试宝典笔记(三)auto_ptr、递归
程序员面试宝典笔记(四)面向对象、类型转换、static
程序员面试宝典笔记(五)数据结构基础
程序员面试宝典笔记(六)软件测试

题目

写一个“标准”宏MIN,这个宏输入两个参数并返回较小的一个。

解析

为什么要把如此简单的题目也放进来呢?为了强调宏定义里面括号的重要性!!!

答案

#define MIN(A,B) ((A) <= (B) ? (A) : (B))

题目

const与指针的关系?const成员函数?以及mutable!

解析

一般分为4种情况:

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

答案

1)先看情况1。如果const位于星号的左侧,则const就是用来修饰指针所指向的变量,即指针指向为常量;如果const位于星号的右侧,const就是修饰指针本身,即指针本身是常量。因此,1和2的情况相同,都是指针所指向的内容为常量(const放在变量声明符的位置无关),这种情况下不允许对内容进行更改操作。对于情况1,可以先不进行初始化。因为虽然指针内容是常量,但指针本身不是常量。
2)情况2与情况1相同。
3)情况3为指针本身是常量,这种情况下不能对指针本身进行更改操作,而指针所指向的内容不是常量。对于情况3,定义时必须同时初始化。
4)对于情况4为指针本身和指向的内容均为常量。
下面再说一下const成员函数是什么?
我们定义的类的成员函数中,常常有一些成员函数不改变类的数据成员,也就是说,这些函数是“只读”函数,而有一些函数要修改类数据成员的值。如果把不改变数据成员的函数都加上const关键字进行标识,显然,可提高程序的可读性。其实,它还能提高程序的可靠性,已定义成const的成员函数,一旦企图修改数据成员的值,则编译器按错误处理。
在const成员函数中,用mutable修饰成员变量名后,就可以突破const的限制,修改类的成员变量了。

题目

const与#define相比有什么不同?

答案

C++语言可以用const定义常量,也可以用#define定义常量,但是前者比后者有更多的优点:
● const常量有数据类型,而宏常量没有数据类型。编译器可以对前者进行类型安全检查,而对后者只进行字符替换,没有类型安全检查,并且在字符替换中可能会产生意料不到的错误(边际效应)。
● 有些集成化的调试工具可以对const常量进行调试,但是不能对宏常量进行调试。在C++程序中只使用const常量而不使用宏常量,即const常量完全取代宏常量。

题目

下面两段程序分别输出什么?
代码一

#include <iostream>using namespace std;class A{private:    bool a;    int b;    bool c;};class B{private:    int b;    bool a;    bool c;};int main(){    cout << sizeof(A) << endl;    cout << sizeof(B) << endl;    return 0;}

代码二

#include <iostream>using namespace std;#pragma pack(1)class A{private:    static bool a;    int b;    bool c;};class B{private:    int b;    bool a;    bool c;};int main(){    cout << sizeof(A) << endl;    cout << sizeof(B) << endl;    return 0;}

解析

很明显,这道题是考察结构的对齐。一般来说,为了方便对结构体内元素的访问和管理,结构体的长度一定是最长的数据元素的整数倍。
代码一类A的对齐为
|bool|—-|—-|—-|
|——–int———|
|bool|—-|—-|—-|
代码一类B的对齐为
|——–int———|
|bool|bool|—-|—-|
而代码二用pack预处理指令来禁止对齐调整。所以就是本身的内存大小。但是需要注意sizeof是计算栈中分配的内存大小,静态变量是存放在全局数据区,不会被计算在内。

答案

代码一:类A 12字节;类B 8字节
代码二:类A 5字节;类B 6字节

0 0