进程终止,状态为-1073741571(0分钟,3秒)

时间:2019-06-21 14:58:52

标签: c++ c++17

构建此代码后,出现以下错误:进程终止,状态为-1073741571(0分钟,0秒)。那我该怎么解决这个问题呢?

我正在使用Code :: Blocks 16.01。我已经尝试了很多次,但始终会收到此错误。但是,如果此代码在Ideone上运行,就可以了。

#include <bits/stdc++.h>
#define ll long long
using namespace std;
struct matrix
{
    ll val[3005][3005];
    ll row, col;
};
matrix operator * (matrix a, matrix b)
{
    matrix res;
    if(a.col != b.row)
        return res;
    for(ll i = 1; i <= a.row; i++)
        for(ll j = 1; j <= b.col; j++)
            for(ll k = 1; k <= a.col; k++)
                   res.val[i][j] = res.val[i][j] + a.val[i][k] * b.val[k] 
[j];
    res.row = a.row; res.col = b.col;
    return res;
}
matrix a,b,c;
int main()
{
    ios_base::sync_with_stdio(false);
    cin.tie(0); cout.tie(0);
    cin>>a.row>>a.col>>b.row>>b.col;
    for(ll i = 1; i <= a.row; i++)
        for(ll j = 1; j <= a.col; j++)
            cin>>a.val[i][j];
    for(ll i = 1; i <= b.row; i++)
        for(ll j = 1; j <= b.col; j++)
            cin>>b.val[i][j];
    c = a * b;
    for(ll i = 1; i <= c.row; i++)
    {
        for(ll j = 1; j <= c.col; j++)
            cout<<c.val[i][j]<<" ";
        cout<<endl;
    }
    return 0;
}

非常感谢您的帮助!

1 个答案:

答案 0 :(得分:1)

正如之前的评论所提到的,您很可能在这里遇到堆栈溢出问题。线程的默认堆栈大小取决于平台,因此有意义的是,您的代码将在某些环境中导致崩溃,而在其他环境中起作用。

解决此问题的一种可能方法是在启用AddressSanitizer的情况下运行它。例如(我的代码在“ main.cc”中):

$ g++ main.cc
$ ./a.out
Segmentation fault
$ g++ -fsanitize=address main.cc
$ ./a.out
ASAN:DEADLYSIGNAL
=================================================================
==224881==ERROR: AddressSanitizer: stack-overflow on address 0x7ffc3567b098 (pc 0x5586c57fe932 bp 0x7ffc39b5fd40 sp 0x7ffc3567b0a0 T0)
    #0 0x5586c57fe931 in main (~/a.out+0x2931)
    #1 0x7fddf00c052a in __libc_start_main (/lib/x86_64-linux-gnu/libc.so.6+0x2352a)
    #2 0x5586c57fe509 in _start (~/a.out+0x2509)

SUMMARY: AddressSanitizer: stack-overflow (~/a.out+0x2931) in main
==224881==ABORTING

仅出于教育目的(我实际上建议不要这样做),如果我们手动增加堆栈限制,我们可以观察到您的程序正常工作。在Linux上,如果我们插入

struct HackRunBeforeMain {
  HackRunBeforeMain() {
    // See http://man7.org/linux/man-pages/man2/getrlimit.2.html
    // Not checking any errors to keep the example simple.
    struct rlimit rlim;
    getrlimit(RLIMIT_STACK, &rlim);
    // Set the current thread's stack size to 1GB!
    rlim.rlim_cur = 1024 * 1024 * 1024;
    setrlimit(RLIMIT_STACK, &rlim);
  }
};
HackRunBeforeMain hack_run_before_main;

运行到程序中,不会导致段错误(至少在我的机器上)。

对于长期修复,您应该研究确保每个matrix的数据都在堆上,而不是堆栈上。您可以通过mallocnewstd::make_unique<T>之类的工具来完成此操作。修改原始程序的做法留给了问询者。