前几天从网上下了个图像分析的mfc小程序,是VC6的

用VC6在本地编译生成都没问题。执行起来弹出一个未处理的错误,程序崩溃退出。

想起来原来遇到过打开文件对话框方面的问题,当时项目时间紧张未能深究。

这次要好好看下这个问题。

详细做法就是深入仔细的跟踪、跟踪、跟踪。

。。

应用代码,跟进

MFC的代码,跟进

Alt+8调出反汇编,跟进。

重复多次重复追踪、缩小目标。确定问题是:在CFileDialog 的析构函数中,调用了CString 的析构函数,

恰恰是析构CSring 出错了。

CFileDialog 的定义例如以下,就是析构这个 m_strFilter 出错的。

class CFileDialog : public CCommonDialog

{

 DECLARE_DYNAMIC(CFileDialog)

public:

// Attributes

 OPENFILENAME m_ofn; // open file parameter block

// Constructors

 CFileDialog(BOOL bOpenFileDialog, // TRUE for FileOpen, FALSE for FileSaveAs

  LPCTSTR lpszDefExt = NULL,

  LPCTSTR lpszFileName = NULL,

  DWORD dwFlags = OFN_HIDEREADONLY | OFN_OVERWRITEPROMPT,

  LPCTSTR lpszFilter = NULL,

  CWnd* pParentWnd = NULL);

......省略n 多行

protected:

 BOOL m_bOpenFileDialog;       // TRUE for file open, FALSE for file save

 CString m_strFilter;          // filter string

      // separate fields with '|', terminate with '||\0'

 TCHAR m_szFileTitle[64];       // contains file title after return

 TCHAR m_szFileName[_MAX_PATH]; // contains full path name after return

OPENFILENAME*  m_pofnTemp;

virtual BOOL OnNotify(WPARAM wParam, LPARAM lParam, LRESULT* pResult);

};

发现这里面找的m_strFilter 的地址就不正确

0012F7EC 是 CFileDialog 实例的地址

析构m_strFilter 找的是0012F8A8,再运行就会出错。去这个地址瞄一眼。感觉就不正确啊

于是在构造函数跟踪时。发现m_strFilter 的地址是0012F89C

比較两次合成ecx 中m_strFilter的this指针时。非常明显不同

add ecx 0b0h  ;构造时

add ecx 0bch  ;析构时

喔喔,算偏移嘛。怎么会不一样呢,这个,再花时间研究下吧。

嗐呀,说不定有人研究过啦。灵机一动,bing 下"add ecx 0b0h",果然。第一条就命中

http://blog.titilima.com/show-590-1.html。这里已有答案。

感谢作者李马先生 :-)

原因讲的非常清楚了。

但是怎么改呢,难道去动vs 的源代码。

当然VS的源代码也是能够改的。只是呢,通过定义追溯文件发现到了

C:\Program Files\Microsoft SDKs\Windows\v7.1\Include 以下

当初MFC4.2 的年代应该还没有v7.1 的版本号呀,去看下文件夹设定吧

v7.1 的include 在最上面。

果断移到最下。所有又一次生成,没问题啦,奥也。

自已是否动过这个设定记不清了。亦或是后来装VS2010或DDK的时候影响了??

总之呢,我们能够觉得。就VC6本身来说还是没问题的,因为安装多个开发环境造成的冲突是本问题出现的原因。



MFC程序打开文件对话框出错的问题解决的更多相关文章

  1. 4.使用CFileDialog打开文件对话框,获得文件路径 -windows编程

    引言:没想到2022年还有很多工业软件公司依然使用MFC,微软也一直在更新MFC的库,这次使用MFC封装的CFileDialog类,写一个获得选定文件路径,名称,扩展名的程序. 个人技术博客(文章整理 ...

  2. 打开文件对话框在xp和win7上的实现文件任意多选

    作者:朱金灿 来源:http://blog.csdn.net/clever101 在xp系统上进行文件多选,实际上其文件字符串数组的缓冲区是有限,并不能支持选择任意多个文件,为此以前我还写过一篇文章: ...

  3. VS2012下自定义打开文件对话框

    VS2012下自定义打开文件对话框,MFC的CFileDialog封装了太多,太复杂,绕得头晕,自己封装一个得了 #pragma once #include <objbase.h> #in ...

  4. java中文件保存、打开文件对话框

    package com.soft.test; //AWT: FileDialog类 + FilenameFilter类 可以实现本功能 //Swing: JFileChooser类 + FileFil ...

  5. QT 打开文件对话框汇总

    Qstring fileName = QFileDialog::getOpenFileName(this, tr("open file"), " ",  tr( ...

  6. qt: 系统默认程序打开文件或者软件;

    Qt提供了QDesktopServices类, 可以利用openUrl函数调用默认程序打开文件: 源码参考: #ifdef Q_OS_WIN32 m_szHelpDoc = QString(" ...

  7. C# OpenFileDialog打开文件对话框(详解)

    一.打开文件对话框(OpenFileDialog) 1. OpenFileDialog控件的基本属性 InitialDirectory:对话框的初始目录 Filter: 获取或设置当前文件名筛选器字符 ...

  8. [javaSE] GUI(打开文件对话框)

    使用FileDialog可以打开文件对话框,根据模式不同,可以分为打开文件和保存文件对话框 获取FileDialog对象,new出来,参数:所属Frame对象,String的标题,FileDialog ...

  9. Qt打开文件对话框

    项目中需要打开文件对话框,就查了一下,不得不说Qt的帮助文档做的真好,非常详细.要实现这个功能有两种方式,使用QFileDialog的静态方法,实例化QFileDialog对象. 基本算是照抄帮助文档 ...

随机推荐

  1. 关于Servlet一些东西

    ---- 概念 Servlet是一种服务器端的Java应用程序,具有独立于平台和协议的特性,可以生成动态的Web页面. 它担当客户请求(Web浏览器或其他HTTP客户程序)与服务器响应(HTTP服务器 ...

  2. Oracle中exit,return,continue

    记录exit和return的用法 exit用来跳出循环 loop IF V_KBP IS NULL THEN           EXIT;    END IF; end loop; return跳出 ...

  3. luogu3960 列队

    参考这篇 #include <iostream> #include <cstdio> #include <vector> using namespace std; ...

  4. Couchbase III(Python Library)

    Couchbase III(Python Library) 第一步 安装 使用pip安装: >pip install couchbase --quiet 确认是否安装成功: >python ...

  5. 80. Hibernate 5.0命名策略使用naming-strategy 不起作用【从零开始学Spring Boot】

    [原创文章,转载请注明出处] 事情的起因:一不小心从1.3.3升级到了1.4.0版本,结果就碰到了各种悲催的事情了,好吧,Hibernate5.0的新特性就是其中一个坑,我们会发现我们配置的namin ...

  6. C# easyui json类

    using System; using System.Data; using System.Text; namespace Common { public class JsonHelp { priva ...

  7. SPOJ DCEPC11I

    题目大意: 就是给定一段区间令其中的数增加一个递增序列(也就是说第一个+1,第二个+2.....) 询问操作是区间的和 这里的查询很简单,但是对于添加递增序列入区间就比较搞脑子了 我们需要一个add[ ...

  8. bzoj 3772 精神污染 主席树+dfs序

    精神污染 Time Limit: 10 Sec  Memory Limit: 64 MBSubmit: 637  Solved: 177[Submit][Status][Discuss] Descri ...

  9. POJ 3615 Cow Hurdles

    http://poj.org/problem?id=3615 floyd 最短路径的变形 dist[i][j]变化为 : i j之间的最大边 那么输入的时候可以直接把dist[i][j] 当作i j ...

  10. CodeForces - 743B Chloe and the sequence

    暴力肯定是无法做的 当时做的时候 当成一道递推来做的 用到分治的思想 想象一串长度为2n+1的列 那么前n个为前一串数 后n个是前一串数的reverse 第n+1个数 为第几串的编号 例如 第几串 中 ...