一、范围for语句,用于遍历一个序列
int v[] {12, 13, 14, 15};
//for (auto x : v)//数组v中每个元素依次拷贝x中,打印x的值
for(auto &x : v)//x成了v的引用,省略拷贝动作,提高效率
{
cout << x << endl;
}
for (auto x : { 10,20,30,40 })
{
cout << x << endl;
}
二、动态内存分配问题
c++中把内存分为5个区域:
(1)、栈:一般函数的局部变量都会放在这里,由编译器分配与释放
(2)、堆:程序员使用malloc/new分配,用free/delete释放。程序运行结束后,系统也会释放
(3)、全局/静态存储区:放全局变量与静态变量static,程序结束后释放
(4)、常量存储区
(5)、程序代码区
栈和堆的用途与区别:
栈,空间有限,int a = 4; 分配速度快,由系统决定,程序不能控制。
堆,只要不超过实际物理内存,都可以分配,速度比栈慢,可以随时使用malloc/new分配,用free/delete释放
malooc和free:在c语言中使用,是动态内存函数
new/delete是运算符。c++中使用new/delete分配和释放内存
new 一般使用格式:
指针变量名 = new 类型标识符;
指着类型名 = new 类型标识符(初始值);
指着类型名 = new 类型标识符[内存单元个数]
int *myint = new int;//相当于 int *myint=(int *)malloc(sizeof(int)); 开辟一个4字节的内存空间,myint指向该内存空间
if (myint != NULL)
{
*myint = 10;
cout << *myint << endl;//10
delete myint;//释放内存
}
int *pa = new int[100];//开劈一个100整形大小空间
if (pa != NULL)
{
int *p = pa;
*p++ = 10;//[0]=10;* 与++优先级相同,都是右结合
*p++ = 12;//[1]=12;
cout << *pa << endl;//10
cout << *(pa+1) << endl;//12
释放内存
delete[] pa;//new时候有[],释放就必须有[],不写数组大小
}
三、nullptr c++11中新引入关键字
nullptr 也是空指针
char *p = NULL;//NULL实际就是0
char *q = nullptr;
int a = nullptr;//不可以
int b = NULL;//可以
使用nullptr能够避免整数与指针之间发生混淆,与指针有关的场合用nullptr,不用NULL