二维数组必须指定列的数量,行的数量可以不指定
define的宏定义仅仅是直接简单文本替换ifndef/define/endif 的含义:如果未定义 / 那么定义 / 完成假设 同样避免重复引用的#pragma once
建立派生类对象时,3种构造函数分别是a(基类的构造函数)、b(派生类的成员对象的构造函数)、c(派生类的构造函数) 顺序是abc如果b为基类的成员对象时为bac
创建类对象时先调用类成员的构造函数再调用类的构造函数
sizeof()
数组当做参数时退化为指针
char p[]="abcd"//sizeof(p)为5,结尾处有\0
char *p="abcd"//sizeof(p)为4,为sizeof()一个指针大小(32位机器下.32bit/8=4Byte)
char p[10]//sizeof(p)为10
void func(char p[10])//sizeof(p)为4,为sizeof()一个指针大小
void func(char (& p)[10])//sizeof(p)为10,p是装10个char类型数据的数组的引用
sizeof(char[2])//为2,对装有2个char数组的计算
sizeof(char &)//为1,对char的直接计算
模板类
1.可用来创建动态增长和减小的数据结构(模板声明的参数类型T可以是内置类型,也可以是自定义结构类型,自定义结构类型再用模板即可实现动态扩展缩小)
2.它是类型无关的,因此具有很高的可复用性
3.编译时检查数据类型,保证类型安全
4.与平台无关,可移植性
5.可用于基本数据类型
友元函数重载时,参数列表为1,说明是1元,为2说明是2元
成员函数重载时,参数列表为空,是1元,参数列表是1,为2元
printf“%s”输出直到'\0'的字符串
ASIIC码中0为空字符
'\0' ASCII码值为0,'0'ASCII码值为48.
char a=0;a为'\0'
对于std::vector::iterator
1.++、--用于双向迭代,迭代器最基本的功能.
2.*用于复引迭代器,用于引用迭代器对应的元素,也是基本操作.
3.==用于判断两个迭代器是否相等,迭代的时候需要判断迭代器是否到某个位置.
4.迭代器可以看成一个指针,指针没有移位运算.
堆是向高地址扩展的数据结构,是不连续的内存区域.由系统是用链表来存储的.
栈是向低地址扩展的数据结构,栈区大小一般是定的2M
short,char运算时都转换成int型计算
float运算时都转换成double型计算
int->long->unsigned->double运算过程中默认转换的顺序