c++11的新特性:
https://www.cnblogs.com/bluebean/p/5721686.html
关键字语法(auto nullptr(null是宏是无类型的无法解决函数重载的问题,nullptr是有类型的) 范围for lamada表达式(一个简单的函数,可以定义在函数内部的函数))
stl(array 单向链表slist 哈希map,set)
增加了多线程编程
智能指针(share_ptr weak_ptr 两者的差别是后者不会使引用计数增加,weak除了可以解决循环引用的问题还可以解决空悬指针的问题)weak-ptr
其他:function(函数包装器,可以放下一切可调用之物) bind(函数适配器,改变函数的接口)
volatile关键字的作用
防止编译器优化,主要用在多线程编程中修饰多个线程共享的变量,告诉编译器每次都从内存中读取变量的值而不是从寄存器中。但他还是读写分离的因此还是线程不安全的
结构体对齐
- 从0位置开始存储;
- 变量存储的起始位置是该变量大小的整数倍;
- 结构体总的大小是其最大元素的整数倍,不足的后面要补齐;
- 结构体中包含结构体,从结构体中最大元素的整数倍开始存;
- 如果加入pragma pack(n) ,取n和变量自身大小较小的一个。
- 为什么要对齐?
- 主要还是考虑读取数据的效率问题,如果是不对齐的话,那么有可能原来需要一次读取就需要变成两次(比如一个char 一个int,那么这个int在第一次读取内存的时候只能取到前三个字节(还需要移位)还需要读取一次取得最后一个字节),甚至对于有些操作系统如果不对齐的话会读取不到数据。
构造函数调用虚函数?
首先在构造函数中,对象会经历一个不完全的过程,先调用父类的构造函数此时虚函数指针被初始化为父类的虚函数指针,如果在父类的构造函数中有虚函数的话此时一定调用的是父类的版本,(与直观印象相反,直观印象是子类中应该调用子类的版本)而且也不应该调用子类的版本,因为此时子类还没有初始化,如果虚函数中要使用到子类的某个变量那就很不安全了
static成员函数能不能访问非静态成员变量?怎么实现访问
https://www.cnblogs.com/rickyk/p/4238380.html
不能直接访问。一般通过在静态函数的形参中添加一个执行对象的指针,通过这个指针去访问(因为这个指针有实际的指向的对象)。或者通过静态成员变量,因为静态成员函数可以访问静态成员变量,添加一个静态成员变量赋值为this指针