CDemoDoc::CDemoDoc() { // Initialize private member variables. m_pList = NULL; m_pCurRgn = NULL; m_wAvaileableId = 1000; m_nMode = IDNOP; autoRepaint = TRUE; TRY { m_pList = new CObList; } CATCH(CMemoryException, memEx) { AfxMessageBox("Out of Memory"); } END_CATCH }
时间: 2024-04-18 17:24:38 浏览: 55
这段代码是CDemoDoc类的构造函数。在构造函数中,它初始化了一些私有成员变量。
1. `m_pList`是一个指向CObList对象的指针,用于存储区域对象的列表。在构造函数中,将其初始化为NULL。
2. `m_pCurRgn`是一个指向CPanCtRgn对象的指针,表示当前区域。在构造函数中,将其初始化为NULL。
3. `m_wAvaileableId`是一个整型变量,表示可用的ID。在构造函数中,将其初始化为1000。
4. `m_nMode`是一个整型变量,表示当前模式。在构造函数中,将其初始化为IDNOP。
5. `autoRepaint`是一个BOOL类型变量,表示自动重绘标志。在构造函数中,将其初始化为TRUE。
接下来,在TRY-CATCH块中,它尝试为`m_pList`分配内存并创建一个CObList对象。如果内存分配失败(内存异常),则会捕获该异常并显示一个消息框提示"Out of Memory"。
总结起来,这段代码初始化了CDemoDoc类的一些私有成员变量,并尝试为m_pList创建一个CObList对象。如果内存分配失败,则会显示一个错误消息框。
相关问题
CDemoDoc::~CDemoDoc() { if (m_pList != NULL) { for (POSITION pos = m_pList->GetHeadPosition(); pos != NULL; ) { CPanCtRgn* pRgn = (CPanCtRgn*) m_pList->GetNext(pos); if (pRgn != NULL) { delete pRgn; } } m_pList->RemoveAll(); delete m_pList; } }
这段代码是在 `CDemoDoc` 类的析构函数 `CDemoDoc::~CDemoDoc()` 中执行的。让我逐行解释:
- `if (m_pList != NULL)`:检查成员变量 `m_pList` 是否为空指针。
- `for (POSITION pos = m_pList->GetHeadPosition(); pos != NULL; )`:使用 `GetHeadPosition()` 函数获取链表的头部位置,并在每次迭代结束后更新 `pos`。
- `CPanCtRgn* pRgn = (CPanCtRgn*) m_pList->GetNext(pos);`:使用 `GetNext()` 函数获取链表中的下一个元素,并将其转换为 `CPanCtRgn*` 类型。
- `if (pRgn != NULL) { delete pRgn; }`:如果获取到有效的区域对象,则调用 `delete` 运算符释放该对象所占用的内存。
- `m_pList->RemoveAll();`:调用链表对象的 `RemoveAll()` 函数,移除所有的元素。
- `delete m_pList;`:最后,使用 `delete` 运算符释放链表对象所占用的内存。
这段代码的作用是在销毁 `CDemoDoc` 类的对象时,释放动态分配的资源。它首先遍历链表中的每个元素,将每个区域对象删除并释放内存。然后,它调用链表对象的 `RemoveAll()` 函数来移除所有元素,最后使用 `delete` 运算符释放链表对象的内存。这样做可以确保在销毁对象时,释放了与之关联的资源,避免内存泄漏。
BOOL CDemoApp::InitInstance() { // Standard initialization // If you are not using these features and wish to reduce the size // of your final executable, you should remove from the following // the specific initialization routines you do not need. m_pszProfileName = strdup("PCTLDEMO.INI"); m_pszHelpFilePath = strdup("..\\docs\\vcet.hlp"); SetDialogBkColor(); // set dialog background color to gray LoadStdProfileSettings(); // Load standard INI file options (including MRU) // Register the application's document templates. Document templates // serve as the connection between documents, frame windows and views. AddDocTemplate(new CMultiDocTemplate(IDR_DEMOTYPE, RUNTIME_CLASS(CDemoDoc), RUNTIME_CLASS(CMyMDIChildWnd), // standard MDI child frame RUNTIME_CLASS(CDemoView))); // create main MDI Frame window CMainFrame* pMainFrame = new CMainFrame; if (!pMainFrame->LoadFrame(IDR_MAINFRAME)) return FALSE; // Initialise the controls PAN_LoadControls(NULL, NULL); pMainFrame->ShowWindow(m_nCmdShow); pMainFrame->UpdateWindow(); m_pMainWnd = pMainFrame; // create a new (empty) document OnFileNew(); // instanciate notification procedure *((FARPROC * ) &lpfnNotifyProc) = MakeProcInstance((FARPROC) NotifyWndProc, AfxGetInstanceHandle()); if (lpfnNotifyProc == NULL) { ::MessageBox((HWND) 0, "Cannot make procedure instance!", "INFO", MB_ICONINFORMATION); return FALSE; } if (m_lpCmdLine[0] != '\0') { // TODO: add command line processing here } return TRUE; }
这段代码是一个 MFC 应用程序的初始化函数 `BOOL CDemoApp::InitInstance()`,它包含了一些标准的初始化步骤和自定义的初始化操作。让我逐一解释一下:
1. `m_pszProfileName` 和 `m_pszHelpFilePath` 的赋值:
- `m_pszProfileName` 是应用程序的配置文件名,这里将其设置为 "PCTLDEMO.INI"。
- `m_pszHelpFilePath` 是应用程序的帮助文件路径,这里将其设置为 "..\\docs\\vcet.hlp"。
2. `SetDialogBkColor()`:设置对话框的背景颜色为灰色。
3. `LoadStdProfileSettings()`:加载标准的 INI 文件选项,包括最近使用的文件列表(MRU)等。
4. 注册应用程序的文档模板:
- `IDR_DEMOTYPE` 是资源 ID,表示该文档模板对应的资源。
- `CDemoDoc` 是文档类。
- `CMyMDIChildWnd` 是标准的 MDI 子窗口类。
- `CDemoView` 是视图类。
5. 创建主 MDI 框架窗口 `CMainFrame`,并加载框架窗口的资源。如果加载失败,则返回 FALSE。
6. `PAN_LoadControls(NULL, NULL)`:初始化控件。
7. 显示和更新主框架窗口。
8. `m_pMainWnd` 指向主框架窗口。
9. `OnFileNew()`:创建一个新的空文档。
10. `MakeProcInstance((FARPROC) NotifyWndProc, AfxGetInstanceHandle())`:创建一个用于处理通知的过程实例。
11. 检查 `lpfnNotifyProc` 是否为空,如果为空,则显示一个消息框,并返回 FALSE。
12. 如果命令行参数 `m_lpCmdLine` 不为空,则可以在这里添加命令行处理的代码。
最后,函数返回 TRUE,表示初始化成功。
阅读全文