文章目录

    • 一、C/C++中的return value
      • 1.value产生的条件
      • 2.value值和错误代码的区别
    • 二、一些令人崩溃的value值
      • 1.退出代码为3221225477
      • 2.退出代码为3221225725
      • 3.退出代码为3221225620

这两天稍闲一点就手痒帮别人写了两篇课设,然后被打脸了,本以为C/C++的控制台程序我一晚上就写完了,然后被疯狂打脸,那一行”process exited with value xxxxxx”真的是太无语了。

所以来看看C/C++里面这些value值分别代表什么意思,什么时候会出现这些value值。(个人理解,欢迎指出错误)

一、C/C++中的return value

1.value产生的条件

当你用C/C++写的程序因为一些原因结束进程的时候就会产生一个退出的代码,就是一个数字,例如,我们常见的退出代码一般都是0(程序没有问题的情况下O(∩_∩)O)。这是程序在退出的时候产生的一个标志,可以在项目中去捕获这些异常,然后进行处理。这个value值是返回给操作系统的。

2.value值和错误代码的区别

一般来说,错误代码是在进行编译的时候就不能编译过去的,常常出现的问题一般是不符合语法要求、不符合当前使用的语言版本、这个时候的程序是无法运行的,因为它连编译都不能编译过去,也就无法生成一个可运行的文件。
退出代码一般是因为某些原因导致了进程结束而退出的,这是可以编译过去的,但是在程序运行过程中,遇到了某些问题,导致程序崩溃或结束。

二、一些令人崩溃的value值

1.退出代码为3221225477

这个错误代码的意思是操作了没有分配的内存。遇到这个问题就很无语了(前两天刚遇到),你得在一大堆代码里面找是哪个指针还是数组操作了未分配的内存。
可能的原因:
(1)数组越界:
我们知道,数组在创建的时候是分配了内存的,但是如果你的数组越界了,那么越界的部分就是访问了没有分配内存的区域,例如下面这个例子:

#includeusing namespace std;int main(){string a[5];a[6]="ss";}

运行后结果:

这就是数组越界产生的非法访问。
(2)访问了局部变量的地址
局部变量我们知道在局部作用完成后,将释放这一部分的空间,那么释放了这一部分空间以后,这个变量就不再具有地址了,如果这个时候我们再访问这个地址,那么就会出现这个错误代码例如下面这个。

#includetypedef struct{int a;char b;} test;void add(test** t){test s={1,'a'};*t=&s;}int main(){test* t;add(&t);printf("%s",t->b);}

错误代码与上面一样,我们来看,在add函数中,变量s的作用域只有add函数,所以当add函数结束时,s的地址也就不存在了,这个时候,即使你把地址付给了t但是add结束以后,t指向的位置内容空间被释放了,也就是空的,那么此时访问就会造成这一错误代码。
改成下面这样就好:

#include#includetypedef struct{int a;char b;} test;void add(test** t){test* s=(test*)malloc(sizeof(test));s->a=1;s->b='a';*t=s;}int main(){test* t;add(&t);printf("%c",t->b);}

这样,我们给指向局部变量的指针分配了空间,那么这个变量虽然在子函数内,但是由于分配了内存,就不会被释放掉,那么就可以用指针去访问它。
(3)空指针异常
其实前两个本质都是空指针异常,就是指向的地方没有东西,例如下面这个例子

int main(){int *t;printf("%d",*t);}

指针没有指向任何地方,所以会产生这个退出代码。

2.退出代码为3221225725

这个代码一般是栈溢出异常,通俗的来说就是有死循环在你的代码里面,也是可以编译过去,但是当你的代码运行到那一行的时候就会出现这个异常。
可能的原因:
(1)无穷递归
递归必须得有条件让其结束递归,不然就会造成栈溢出错误,如下面这个例子

#include#includeint digui(int a,int b){int s=a+b;int t=a*b;return digui(s,t);}int main(){digui(2,3);}

可以看出来他一直处于递归状态,造成了栈溢出,说白了就是运行内存不够了,一直递归下去造成了堆栈空间不足了。
解决方案

#include#includeint digui(int a,int b){int s=a+b;int t=a*b;if(t>500){return t;}else{return digui(s,t);}}int main(){int a=digui(2,3);printf("%d",a);}

(2)运算量大于了你的堆栈空间(一般不太容易)
一般程序给出的堆栈空间只有1~2M,如果定义的变量超过了这个范围,就会出现栈溢出的异常。
例如下面这个

int main(){double a[2000][2000];}

3.退出代码为3221225620

这是一个除零异常,就是小学学的那个,0作除数的时候就会出现这个问题。

int main(){int a=2/0;}

其实还有很多退出代码,这几种感觉经常遇到,就只总结这三种了,但是很多时候知道是什么类型的bug,但是就是找不到是哪的bug。

愿大家的代码都没bug