记录C/C++中那一行万恶的process exited with return value xxxxxxx


这两天稍闲一点就手痒帮别人写了两篇课设,然后被打脸了,本以为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)数组越界:
我们知道,数组在创建的时候是分配了内存的,但是如果你的数组越界了,那么越界的部分就是访问了没有分配内存的区域,例如下面这个例子:

#include<iostream>
using namespace std;
int main(){
    string a[5];
    a[6]="ss";
}

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

#include<stdio.h>
typedef 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<stdio.h>
#include<stdlib.h>
typedef 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<stdio.h>
#include<stdlib.h>
int digui(int a,int b){
    int s=a+b;
    int t=a*b;
    return digui(s,t);
}
int main(){
    digui(2,3);
}

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

#include<stdio.h>
#include<stdlib.h>
int 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
在这里插入图片描述