//////——————常见的动态内存错误
////——1 对NULL指针的解引用操作
//void test()
//{
//    int* p = (int*)malloc(40);
//    *p = 20;//如果p的值是NULL,就会有问题,所以在使用malloc、realloc、calloc时的返回值p进行相关的检测。
// //为空指针,代码就此结束(return即可)
//    free(p);
//}
////——2 对动态开辟空间的越界访问
//#include<stdio.h>
//#include<stdlib.h>
//#include<errno.h>
//void test()
//{
//    int i = 0;
//    int* p = (int*)malloc(10 * sizeof(int));
//    if (NULL == p)
//    {
//        printf("%s\n",strerror(errno));
//    }
//    for (i = 0; i <= 10; i++)//可循环11次,返回值p会越界(44>40)
//    {//i应为i<10
//        *(p + i) = i;//当i是10的时候越界访问。*(p+i)=p[i]
//    }
//    free(p);
//}
////——3 对非动态开辟内存使用free释放
//void test()
//{
//    int a = 10;
//    int* p = &a;//此时p指向的是栈区的空间,并不是动态开辟出来的。
//    free(p);//而free释放的只能是malloc、calloc、realloc所拿到的空间
//}
////——4 使用free释放一块动态开辟内存的一部分
//#include<stdio.h>
//#include<stdlib.h>
//void test()
//{
//    int* p = (int*)malloc(100);
//    int i=0;//此时返回值p在被释放的时候并没有指向起始位置(free不可以只释放其中一部分)
//    for (i = 0; i < 10;i++)
//    {
//        *p = i;
//        p++;
//    }
//    free(p);//p不再指向动态内存的起始位置
//    p=NULL;//不可以用const去保护p,因为怕、还要被赋值为NULL
//}
////——5 对同一块动态内存未赋值NULL之前再次释放
//void test()
//{
//    int* p = (int*)malloc(100);
//    free(p);//加一句赋值NULL即可
//    free(p);//释放空指针无意义,但不会报错,若不赋值NULL,则p被回收后再次释放时,空间已被回收,
//  //但p中依然存着原来的地址,导致p为野指针,也无法进行任何操作。
//}
////——6 动态开辟内存忘记释放(内存泄漏:内存用完不还)
////例一
//#include<stdlib.h>
//void test()
//{
//    int* p = (int*)malloc(100);
//    int flag=0;
//    if (flag == 5)//当flag=5时,申请的空间用完后不会被释放,倒是内存泄漏
//        return;
//    free(p);
//    p = NULL;
//}
//int main()
//{
//    test();
//    return 0;
//}
////例二
//#include<stdlib.h>
//int  test()
//{
//    int* p = (int*)malloc(100);
//    int flag=0;
//    if (flag == 5)//当flag=5时,申请的空间用完后不会被释放,倒是内存泄漏
//        return p;
//}
//int main()
//{
//    int* ret=test();
//    //函数将返回的地址赋给新的变量,但是赋值后没有进行释放
//    return 0;
//}

////注意:忘记释放不再使用的动态开辟的空间会造成内存泄漏。
////      动态开辟的空间一定要释放,并且正确释放。