[转]MFC下关于“建立空文档失败”问题的分析

这类问题的出现主要在bool CWinApp::ProcessShellCommand(CCommandLineInfo& rCmdInfo);

函数的关键内容: 
BOOL bResult = TRUE; 
switch (rCmdInfo.m_nShellCommand) 

case CCommandLineInfo::FileNew:  // 新建 
 if (!AfxGetApp()->OnCmdMsg(ID_FILE_NEW, 0, NULL, NULL)) 
  OnFileNew(); 
 if (m_pMainWnd == NULL)



3&-‘  
  bResult = FALSE; 
 break; 
case CCommandLineInfo::FileOpen: 
 if (!OpenDocumentFile(rCmdInfo.m_strFileName)) 
  bResult = FALSE; 
 break; 
通过上面的内容我们可以看出:如果没有对ID_FILE_NEW做映射的话出现问题就在OnFileNew(); 
CWinApp对OnFileNew的默认实现是调用m_pDocManager->OnFileNew();

我们继续解析cdocmanager,它究竟干了些什么? 
(首先说明一下CDocManager它主要的功能是帮助CWinApp是管理文档模板链表和注册文件类型.)

//如果模板列表为空的话 
if (m_templateList.IsEmpty()) 
{



q  
 TRACE0("Error: no document templates registered with CWinApp. 
"); 
 AfxMessageBox(AFX_IDP_FAILED_TO_CREATE_DOC);  //报错并返回.这里不会报建立新文档出错。 
 return; 
}

cdoctemplate* pTemplate = (CDocTemplate*)m_templateList.GetHead(); 
if (m_templateList.GetCount() > 1) 

 // more than one document template to choose from 
 // bring up dialog prompting user 
 CNewTypeDlg dlg(&m_templateList); 
 int nID = dlg.DoModal(); 
 if (nID == IDOK) 
  pTemplate = dlg.m_pSelectedTemplate;Mj8F  
 else 
  return;     // none - cancel operation



w  
}

assert(ptemplate != NULL);



]kW  
ASSERT_KINDOF(CDocTemplate, pTemplate);

ptemplate->opendocumentfile(null);

通过上面的代码我们可以看出,cwinapp的onfilenew和onfileopen分别调用cdocmanager的虚拟函数onfilenew和onfileopen。而在cdocmanager里面。通过模板链表选择不同的模板来调用文档模板的opendocumentfile(); 
如果传入参数NULL表示新建文件。

下面我们来看看cdoctemplate::opendocumentfile()它是一个最关键的函数。因为他是虚拟函数,我们考虑CSingleDocTemplate::OpenDocumentFile的情况。



4RqL=  
这个函数里面有一段代码: 
其中:AFX_IDP_FAILED_TO_CREATE_DOC 就是字符“建立空文档失败”的资源id 
// create a new document 
pDocument = CreateNewDocument(); 
ASSERT(pFrame == NULL);     // will be created below 
bCreated = TRUE; 
if (pDocument == NULL)N+  

AfxMessageBox(AFX_IDP_FAILED_TO_CREATE_DOC); 
return NULL; 

ASSERT(pDocument == m_pOnlyDoc);?#Z  
if (pFrame == NULL) 

ASSERT(bCreated);

// create frame - set as main document frame



@(m`w  
BOOL bAutoDelete = pDocument->m_bAutoDelete; 
pDocument->m_bAutoDelete = FALSE; 
// don’t destroy if something goes wrong 
pFrame = CreateNewFrame(pDocument, NULL); 
pDocument->m_bAutoDelete = bAutoDelete;1nD{WwQ  
if (pFrame == NULL) 

 AfxMessageBox(AFX_IDP_FAILED_TO_CREATE_DOC); 
 delete pDocument;       // explicit delete on error 
 return NULL; 
}

通过观察上面的代码我们很容易的看出有两个可能出错的原因:1 CreateNewDocument返回为NULL 2 createnewframe 返回为空。

先看 CreateNewDocument() 一般来说这个函数很少失败。不过在调试时也不能掉以轻心。



6GYC
>‘@  
再看看CreateNewFrame()  里面有一个函数LoadFrame是造成这种“建立新文档失败”错误的源泉所在。 
只要它返回False就会弹出这样的提示。 
我们在来看看LoadFrame() 里面调用CFrameWnd::Create()来创建窗口,创建窗口失败返回Fasle。 
这样问题就变的比较简单了。

看看create和createex函数的动作就知道怎么回事了。



[V:!R  
****************************************************************S_zS  
1如果找不到菜单资源返回False 同时也弹出“建立空文档失败” 
HINSTANCE hInst = AfxFindResourceHandle(lpszMenuName, RT_MENU); 
if ((hMenu = ::LoadMenu(hInst, lpszMenuName)) == NULL) 

 TRACE0("Warning: failed to load menu for CFrameWnd. 
"); 
 PostNcDestroy();            // perhaps delete the C++ object 
 return FALSE; 

2重载了PreCreateWindow而且返回False也会导致弹出“建立空文档失败” 
3在OnCreate 里面返回-1 也会导致弹出“建立空文档失败”。 
******************************************************************

以上就是我分析的出现这样“建立空文档失败”问题的大致原因。也许还有其他的原因。我这里就不一一列举了。

原文地址:https://www.cnblogs.com/rainbow70626/p/8979563.html

时间: 2024-10-31 04:29:32

[转]MFC下关于“建立空文档失败”问题的分析的相关文章

win8下hosts保存文档失败,提示:请检查文件是否被另一个应用程序打开

选择文件,然后右键点击属性,然后进入"安全"选项卡下点击当前用户对用的用户名然后编辑权限,给予完全控制的权限. 如图: 图一: 点击“编辑”, 图二. 赋予“完全控制”的权限然后点击保存即可.

MFC下对串口的操作以及定时器的调用

最近研究了一下MFC下对串口的操作,测试了一下对设备的读写. 1.打开串口 1 GetDlgItem(IDC_BUTTON_OPEN)->EnableWindow(FALSE); 2 m_hComm = CreateFile("COM1", 3 GENERIC_READ | GENERIC_WRITE, 4 0, 5 NULL, 6 OPEN_EXISTING, 7 0, 8 NULL); 9 if (m_hComm == INVALID_HANDLE_VALUE) 10 { 1

MFC下AfxSocketInit()正确初始化套接字

初始化Socket,这是mfc封装的类调用之前必须进行套接字动态链接库的装载,但是如果你错过了向导中的选项,而是自己手动添加,如果不了解情况,导致程序运行失败. //Socket功能初始化  if (!AfxSocketInit())  {   AfxMessageBox(IDP_SOCKETS_INIT_FAILED);   return FALSE BOOL CMyApp::InitInstance() { ............. ..................;  } 正确的初始

MFC下的各种字符串类型和相互转换

MFC下的常用字符串数据类型表示的含义: L:Long  长 P:Point  指针 C:Const  常量 W:Wchar_t  宽字符 T:TCHAR  STR:String  字符串 在看看MFC下各种数据类型的定义: 1 typedef char *LPSTR; 2 typedef const char *LPCSTR; 3 4 typedef wchar_t *LPWSTR; 5 typedef const wchar_t *LPCWSTR; 6 typedef wchar_t WCH

Ubuntu下sudo apt-get install vim 失败的解决办法

Ubuntu下 执行命令:sudo apt-get install vim 失败 解决办法: 更新一下,命令:sudo apt-get update 再安装即可成功:sudo apt-get install vim Ubuntu下sudo apt-get install vim 失败的解决办法,布布扣,bubuko.com

MFC框架类、文档类、视图类相互访问的方法

1.获取应用程序指针 CMyApp* pApp=(CMyApp*)AfxGetApp(); 2.获取主框架指针 CWinApp 中的公有成员变量 m_pMainWnd 就是主框架的指针 CMainFrame* pMainFrame = (CMainFrame*)(AfxGetApp()->m_pMainWnd); 或者 CMainFrame* pMainFrame = (CMainFrame*)AfxGetMainWnd(); 3.获取菜单指针 CMenu* pMenu = AfxGetMain

MiinCMP SAE版修正windows平台下无法获取文档问题

原因:在本地测试时,出现文件路径错误,windows下路径为\ROOT\WEB-INF\,统一转换为/ROOT/WEB-INF/ @Override     public String readFile(File file,String encode){                 String pathweb=parentWebDir;// +"/"+  path;       File f=new File(pathweb);              String path=

MongoDB在MFC下使用C++驱动编译错误的解决

.post p{text-indent: 2em;} 今天使用MongoDB的C++驱动,在编译连接的时候一直出现错误,显示的string_data.h下93行max宏的问题,可视其本身并不是调用max宏,而是调用 std::numeric_limits<size_t>::max 这样就是产生错误,通过搜索发现解决方法(参考网址:http://blog.chinaunix.net/uid-17102734-id-2830143.html),将该函数用括号括起来,避免windows定义的混淆,具

linux下使用crontab实现定时PHP计划任务失败的原因分析

这篇文章主要介绍了linux下使用crontab实现定时PHP计划任务失败的原因分析,需要的朋友可以参考下 很多人在linux下使用crontab实现PHP执行定时任务却未能成功,不能生成缓存.本文就linux下使用crontab实现定时PHP计划任务失败的原因做一分析. 一般我们linux定时执行php代码例如: 1 */5 * * * * /usr/local/php/bin/php /home/wwwroot/1.php 其实这样是可以执行php代码的. 但是为什么很多朋友在1.php写的