C6011:取消对NULL指针“_____“的引用解决办法

malloc之后没有检查是不是空间不够返回了空指针NULL

    //向内存申请10个整形的空间
    //p中存放开辟空间的地址
    int* p=(int*)malloc(10*sizeof(int));
    //开辟失败,内存不够,返回空指针NULL
    if(p==NULL)
    {
        //打印错误原因的一个方式
        printf("%s\n",strerror(errno));
        //Not enough space
    }

 

malloc
动态内存开辟函数

库函数声明
void* malloc (size_t size);

简单例子
 

#include
#include
#include
#include
int main()
{
    //向内存申请10个整形的空间
    //p中存放开辟空间的地址
    int* p=(int*)malloc(10*sizeof(int));
    //开辟失败,内存不够,返回空指针NULL
    if(p==NULL)
    {
        //打印错误原因的一个方式
        printf("%s\n",strerror(errno));
        //Not enough space
    }
    else
    {
        //正常使用空间
        int i=0;
        for(i=0;i<10;i++)
        {
            *(p+i)=i;
        }
        for(i=0;i<10;i++)
        {
            printf("%d ",*(p+i));
        }        
    }
    //当动态申请的空间不再使用的时候
    //就应该还给操作系统
    free(p);//主动归还空间,但p还是可以找到这块空间,危险
    p = NULL;
    return 0;//程序结束,被动归还空间
}

相关说明:
这个函数向内存申请一块 连续可用 的空间,并返回指向这块空间的指针。
如果开辟成功,则返回一个指向开辟好空间的指针。
如果开辟失败,则返回一个NULL指针,因此malloc的返回值一定要做检查。
返回值的类型是 void* ,所以malloc函数并不知道开辟空间的类型,具体在使用的时候使用者自己来决定
如果参数 size 为0,malloc的行为是标准是未定义的,取决于编译器。
malloc和free都声明在 stdlib.h 头文件中

你可能感兴趣的:(BUG)