这两天一直遇到标题上的问题,我相信很多朋友在执行代码的时候都会遇到这样的问题,我在网上也找了很多的资料解决这个问题,虽然有些方法能解决,但是总觉得总结的不是很全面,这里我自己在相对全面的总结一下,如果有不对的地方还请各位看官指正。

首先要交代一下背景情况,我执行的这段代码是别人写的,这段时间是我一直在维护,因为平台不一样,所以读库的方式不一样,我先在liunx的环境下编译了程序,执行都没有问题,可以按照我接口的方式读到数据库的数据。但是我用vs2010的window环境下编译的时候就出现了以下图片的问题。

字面上翻译过来的话就是:栈溢出了。

意思就是你分配的内存太小了,而你程序中有的数据太大,这里导致了栈溢出的情况。

于是我就在网上找资料来查询这个问题,一搜一大堆。

其中普遍的解决方式就是在   属性-》链接器-》系统-》堆栈保留大小和堆栈提交大小  中将数据增加,我这里将这两个数值都改成了16000000。如下图所以:

程序确实是可以运行起来了,但是我在想一个问题,一般我们程序都是使用的默认值,出现这样的问题归根到底的原因是什么呢?

其实还是回到我上面说到的那个问题 堆栈溢出了,vs在程序启动的时候一般分配的堆栈大小是1M的空间,如果你的全局变量或者静态变量有很大的值的话,这里就会出现这样的堆栈溢出的问题。

于是我就在代码里面找是否有较大数据的全局变量,发现了一个宏定义如下图所示:

这个宏定义一下就是1M了,加上其他的一些定义,肯定就超过了1M,如果你是在DEBUG的情况下去调试程序的时候,你会发现连主函数都进不去,因为有全局变量在主函数执行之前就已经栈溢出了,就好像下面这种情况,断点无效。

但是领导那边的要求是程序必须通过命令行的方式编译也要通过,因为客户那边只会操作命令行。

操作命令不难就是在有pro文件的情况下在命令行输入qmake,生成了makefile文件,再执行nmake,生成可执行文件。那么问题来了我用这种方式也执行成功了,也生成了可执行文件exe,但是当我双击exe的时候程序并没有起来,而且没有任何打印信息,这里我想到了可能还是这个栈溢出的问题,pro文件中应该也需要设置一下上面提到的堆栈保留大小和堆栈提交大小。那么在pro文件中如何去设置这两个量呢?

在pro文件中添加上以下两个量就可以了:

QMAKE_CXXFLAGS += /F 16000000
QMAKE_LFLAGS   += /STACK:16000000

这个设置跟vs2010上面的设置是一样的,当然大小自己可以定的,我这里还是设置的大小为16000000。

最后总结:

其实把问题都真正弄清楚了再会看一点都不难,但是在处理的过程中感觉还是比较费劲儿的,所有的提示都是比较精准的,最后找其原因还是回到了最本质的问题,我建议的话还是尽量将全部变量的大小设置的小一点,1024*1024就有点大了,我维护的这段代码并不是我写的,所以我还是准从开发的意愿吧。

希望这边文章对大家还是有所帮助 谢谢!!!

深入全面探究有未经处理的异常: 0xC00000FD: Stack overflow(栈溢出)问题!的更多相关文章

  1. 有未经处理的异常: 0xC00000FD: Stack overflow

    将“项目属性.链接器.系统.堆栈保留大小”设大一点比如16000000 这是我在网上找到的答案,很好的解决了我的问题,忘了是哪位大神了,总之,向大神致敬

  2. 未处理的异常 stack overflow

    今天在编译程序时遇到“0x00e304f7 处有未经处理的异常: 0xC00000FD: Stack overflow”的错误,也就是栈溢出了,google了一下,原来是我申请的一个变量太大了,con ...

  3. w2wp.exe 已附加有调试器,但没有将该调试器配置为调试此未经处理的异常

    一.问题描述 昨天系统联调,用到了VS2010 附件进程,把w2wp.exe 进程添加到vs2010 的调试进程中,这样其他系统访问我们系统,就可以捕获断点进行调试 但是,今天F5 调试的时候,发现直 ...

  4. “System.BadImageFormatException”类型的未经处理的异常在 PurchaseDevices.Access.dll 中发生 其他信息: 未能加载文件或程序集“System.Data.SQLite, Version=1.0.66.0, Culture=neutral, PublicKeyToken=db937bc2d44ff139”或它的某一个依赖项。试图加载格式不正确

    引用sqlite的程序集时,有时会报如下异常:  "System.BadImageFormatException"类型的未经处理的异常在 PurchaseDevices.Acces ...

  5. System.Runtime.Serialization.SerializationException”类型的未经处理的异常在 System.Runtime.Serialization.dll 中发生

    异常信息: “System.Runtime.Serialization.SerializationException”类型的未经处理的异常在 System.Runtime.Serialization. ...

  6. 使用C#在VS中开发:未处理AccessViolationException “System.AccessViolationException”类型的未经处理的异常

    未处理AccessViolationException: “System.AccessViolationException”类型的未经处理的异常在System.Data.dll中发生 其他信息:尝试读 ...

  7. OpenCV问题集锦,图片显示不出来,WaitKey(0),imread()不能读图片,未经处理的异常,等问题集合

    昨天根据uc伯克利的人工图像分割文件.seg,显示图像的时候调用了OpenCV的库函数,图片都能用imwrite写好,但是imshow死活显示不出来. 今天早上发现原来是imshow()后面应该加上: ...

  8. “System.FormatException”类型的未经处理的异常在 System.IdentityModel.dll 中发生 其他信息: 十六进制字符串格式无效。

    如果你的 WebService 客户端证书配置都没问题,唯独调用接口会出现这个错误 “System.FormatException”类型的未经处理的异常在 System.IdentityModel.d ...

  9. c#重命名文件,报错“System.NotSupportedException”类型的未经处理的异常在 mscorlib.dll 中发生”

    修改远程服务器的文件名,报错“System.NotSupportedException”类型的未经处理的异常在 mscorlib.dll 中发生”,“System.NotSupportedExcept ...

随机推荐

  1. MySQL性能优化以及常用命令

    1.将查询操作SELECT中WHERE条件后面和排序字段建立索引 2.按需查询,需要哪个字段就查哪个字段,禁止使用"SELECT * " 3.数据库引擎最好选用InnoDB,少用M ...

  2. Appium与Appium Desktop的区别

    Appium-Server的配置,在之前的博文已有介绍,基于Python的Appium环境搭建合集,所以在此处就不详细介绍了.今天主要来分享下Appium-Server和Appium desktop在 ...

  3. Angular7 HttpClient处理多个请求

    1. MergeMap - 串联请求 后一个请求需要前一个请求的返回结果时,需要使用串联请求. 可以使用MergeMap实现, 优势是减少嵌套,优化代码: 代码如下: import {HttpClie ...

  4. Flask框架踩坑之ajax跨域请求

    业务场景: 前后端分离需要对接数据接口. 接口测试是在postman做的,今天才开始和前端对接,由于这是我第一次做后端接口开发(第一次嘛,问题比较多)所以在此记录分享我的踩坑之旅,以便能更好的理解,应 ...

  5. Python列表的深度排序

    实例1:>>>L = [2,3,1,4]>>>L.sort()>>>L>>>[1,2,3,4] 实例2:>>> ...

  6. 下载git2.2.1并将git添加到环境变量中

    ># wget https://github.com/git/git/archive/v2.2.1.tar.gz > # tar zxvf v2.2.1.tar.gz ># cd g ...

  7. dedecms新增联动类别后的使用方法

    近期用织梦的联动类别,后台明明可以直接新增联动类别,但是你直接调用是绝对调用不出来的............. 折腾了好几天终于全部解决,回忆下过程以便日后再遇到的时候参考. 第一步:先按照常规的在后 ...

  8. vultr恢复快照后更改密码(CentOs7)

    vultr恢复快照之后发现Xshell连不上了,仔细想想应该是之前换服务器的时候恢复快照导致密码更改了, 但是我已经把之前的服务器删了,没记住密码,这就很难受 只好改密码了 首先去官网 打开终端: 最 ...

  9. Mysql高手系列 - 第20篇:异常捕获及处理详解(实战经验)

    Mysql系列的目标是:通过这个系列从入门到全面掌握一个高级开发所需要的全部技能. 这是Mysql系列第20篇. 环境:mysql5.7.25,cmd命令中进行演示. 代码中被[]包含的表示可选,|符 ...

  10. Spring Boot 二十个注解

    Spring Boot 二十个注解 占据无力拥有的东西是一种悲哀. Cold on the outside passionate on the insede. 背景:Spring Boot 注解的强大 ...