linux c/c++面试知识点整理(七)

61、for_each的用法?

       for_each是C++STL中用来遍历容器的函数模板,有3个参数:
       第一个是容器开始,例如:map.begin()
       第二个是容器结束,例如:map.end();
       第三个是operator(),仿函数,函数对象
       当第三个函数有其他参数时,与bind1st和bind2nd一起使用。
例如:

    void record(const int &n)
    {
        cout << n << endl;
    }
    int num [5] = {1,2,3,4,5};
    for_each(num,num+sizeof(num)/sizeof(num[0]),record);

62、什么是事务以及事务包含哪些属性?

       事务是用户定义的一个数据库操作序列,这些操作要么全做,要么全不做,是不可分割的。
       sql语言中,定义事务的语句有3条:
       begin transaction;
       … //这里嵌入sql语句
       commit transaction;
       rollback transaction;
       事务的4个属性:
 原子性:事务中的所有元素作为一个整体提交或回答,事务的每个元素是不可分的,事务是一个完整操作
 一致性:事务完成时,数据必须是一致的,也就是不能破坏数据
 隔离性:事务允许多个用户对同一个数据进行并发访问,而不破坏数据的完整性和正确性。同时,并行事务的修改必须与其他并行事务的修改相独立
 持久性:事务结束后,事务处理的结果必须能够得到固化

63、c++强制转换

  • const_cast
    用于去除const属性,把const类型的指针变为非const类型的指针,如:
const int *fun(int x,int y){}  
int *ptr=const_cast(fun(2.3))
  • static_cast
    最常用的类型转换符,用于基本类型的强制转换
  • dynamic_cast
    该操作符用于运行时检查该转换是否类型安全,但只在多态类型时合法,即该类至少具有一个虚拟方法。dynamic_cast与static_cast具有相同的基本语法,dynamic_cast主要用于类层次间的上行转换和下行转换,还可以用于类之间的交叉转换。在类层次间进行上行转换时,dynamic_cast和static_cast的效果是一样的;在进行下行转换时,dynamic_cast具有类型检查的功能,比static_cast更安全。如:
class C

{
  //…C没有虚拟函数
};
class T{
  //…
}
int main()
{
  dynamic_cast (new C);//错误
}
此时如改为以下则是合法的:
class C

{
public:
  virtual void m() {};// C现在是 多态
}
  • reinterpret_cast
    interpret是解释的意思,reinterpret即为重新解释,此标识符的意思即为数据的二进制形式重新解释,但是不改变其值。如:
int i; 
char *ptr="hello freind!";
 i=reinterpret_cast(ptr);

这个转换方式很少使用,一般用于不同类型指针之间的转换,最常用的就是不同类型之间函数指针的转换

64、linux手动的让内核崩溃

cd /proc/sys/kernel
echo 1 > sysrq
cd /proc
echo c > sysrq-trigger

65、mutable关键字

       mutable加在类型前面,表示即使是常量也可以修改

66、带外数据

       OOB数据,也叫带外数据,send/sendto发送数据时以MSG_OOB标记,它的属性如下:

  • 带外数据只支持tcp,不支持udp
  • 带外数据发送时不优先,接收时优先;
  • 接收带外数据的系统会发送一个SIGURG信号

67、自定义类型作为map键时需注意什么?

  1. 重载 “<” 操作符,因为需要自动排序
  2. 无法重载时,用自定义仿函数代替map第三个参数
  • map 第一个参数是key
  • 第二个参数是value
  • 第三个参数是compare比较函数
  • 第四个参数是内存配置对象

68、虚基类的用法

       虚继承+多重继承时防止二义性问题。
       从类A派生出B和C,类D又继承自B和C,此时类D的对象就包含了两个类A的对象,这样类D调用类A的成员变量和成员函数时就会产生二义性。
       解决办法:B虚继承A,C也虚继承A,此时就不会再有二义性了。

69、析构函数能否为虚函数,为什么?什么情况下析构函数一定要是虚函数。

       析构函数可以是虚函数,因为它是对象结束时才调用,不影响虚表构建。
       构造函数不能是虚函数,因为调用构造函数时,虚表才建立。
       当类有派生类时,析构函数要是虚函数。
       删除指向派生类的基类指针时,只会删除基类对象,而不删除子类对象,造成内存泄露。
       公有继承时,基类对派生类和对象的操作,只能影响那些继承下来的成员,如果要对非继承成员,例如子类析构函数进行操作,则这个函数必须定义为虚函数。

70、怎样防止类对象被拷贝和赋值?

 拷贝构造函数和赋值函数定义为私有的
 私有继承基类

你可能感兴趣的:(linux c/c++面试知识点整理(七))