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内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!
您可能感兴趣的文章:
- VSCode远程连接服务器报错:Could not establish connection to
- vscode编译运行c语言报错乱码的解决
- vscode中的vue项目报错Property ‘xxx‘ does not exist on type ‘CombinedVueInstance<{ readyOnly...Vetur(2339)
- 快速解决VS Code报错:Java 11 or more recent is required to run. Please download and install a recent JDK
- 解决安装vs2019后原vs2017项目无法编译各种报错的问题
- VS2017添加EF的MVC控制器报错的解决方法
- VS2015使用scanf报错的解决方法