C 语言

关注公众号 jb51net

关闭
首页 > 软件编程 > C 语言 > VS报错C6011

VS报错C6011的问题:取消对NULL指针的引用(解决方法)

作者:一只名叫Me的猫

这篇文章主要介绍了VS报错C6011的问题:取消对NULL指针的引用(解决方法),C6011:取消对NULL指针的引用,发现是没有进行空指针的判断,解决方案跟随小编一起看看吧

VS报错C6011:取消对NULL指针的引用 解决方法

写了这样一段代码,第4、5行报错:

C6011:取消对NULL指针的引用

void EnQueue(LinkQueue& Q, ElemType x) {
    LinkNode* s = (LinkNode*)malloc(sizeof(LinkNode));
    s->data = x;
    s->next = NULL;
    Q.rear->next = s;
    Q.rear = s;
}

发现是没有进行空指针的判断。

于是改为如下代码,报错消失:

void EnQueue(LinkQueue& Q, ElemType x) {
    LinkNode* s = (LinkNode*)malloc(sizeof(LinkNode));
    if (!s)cout << "Invalid value!" << endl;  // 判断空指针
    else s->data = x;
    Q.rear->next = s;
    Q.rear = s;
}

扩展:

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<stdio.h>
#include<stdlib.h>
#include<string.h>
#include<errno.h>
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 头文件中

到此这篇关于VS报错C6011:取消对NULL指针的引用 解决方法的文章就介绍到这了,更多相关VS报错C6011内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

您可能感兴趣的文章:
阅读全文