
找到工程生成的cpp文件,里面含有OnInitDialog()函数,把自己的函数调用方法放入到里面
例如:
BOOL CTestDlg::OnInitDialog()
{
CMenu pSysMenu = GetSystemMenu(FALSE);
if (pSysMenu != NULL)
{
CString strAboutMenu;
strAboutMenuLoadString(IDS_ABOUTBOX);
if (!strAboutMenuIsEmpty())
{
pSysMenu->AppendMenu(MF_SEPARATOR);
pSysMenu->AppendMenu(MF_STRING, IDM_ABOUTBOX, strAboutMenu);
}
}
// 设置此对话框的图标。当应用程序主窗口不是对话框时,框架将自动
// 执行此 *** 作
SetIcon(m_hIcon, TRUE); // 设置大图标
SetIcon(m_hIcon, FALSE); // 设置小图标
//在下面加入你需要的代码即可
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
return TRUE;
}
1 预处理
预处理相当于根据预处理指令组装新的C/C++程序。经过预处理,会产生一个没有宏定义,没有条件编译指令,没有特殊符号的输出文件,这个文件的含义同原本的文件无异,只是内容上有所不同。
读取C/C++源程序,对其中的伪指令(以#开头的指令)进行处理
①将所有的“#define”删除,并且展开所有的宏定义
②处理所有的条件编译指令,如:“#if”、“#ifdef”、“#elif”、“#else”、“endif”等。这些伪指令的引入使得程序员可以通过定义不同的宏来决定编译程序对哪些代码进行处理。预编译程序将根据有关的文件,将那些不必要的代码过滤掉。
③处理“#include”预编译指令,将被包含的文件插入到该预编译指令的位置。
(注意:这个过程可能是递归进行的,也就是说被包含的文件可能还包含其他文件)
删除所有的注释
添加行号和文件名标识。
以便于编译时编译器产生调试用的行号信息及用于编译时产生的编译错误或警告时能够显示行号
保留所有的#pragma编译器指令
2 编译
将预处理完的文件进行一系列词法分析、语法分析、语义分析及优化后,产生相应的汇编代码文件。
3 汇编
将编译完的汇编代码文件翻译成机器指令,并生成可重定位目标程序的o文件,该文件为二进制文件,字节编码是机器指令。
汇编器是将汇编代码转变成机器可以执行的指令,每一个汇编语句几乎都对应一条机器指令。所以汇编器的汇编过程相对于编译器来讲比较简单,它没有复杂的语法,也没有语义,也不需要做指令优化,只是根据汇编指令和机器指令的对照表一一翻译即可。
4 链接
通过链接器将一个个目标文件(或许还会有库文件)链接在一起生成一个完整的可执行程序。
由汇编程序生成的目标文件并不能立即就被执行,其中可能还有许多没有解决的问题。
例如,某个源文件中的函数可能引用了另一个源文件中定义的某个符号(如变量或者函数调用等);在程序中可能调用了某个库文件中的函数,等等。所有的这些问题,都需要经链接程序的处理方能得以解决。
链接程序的主要工作就是将有关的目标文件彼此相连接,也就是将在一个文件中引用的符号同该符号在另外一个文件中的定义连接起来,使得所有的这些目标文件成为一个能够被 *** 作系统装入执行的统一整体。
至此,大致经过这几个步骤,一个完整的可执行程序产生了。
我写的是一些简单的程序,流程图是这么写的,以供你参考
1写出每个按键
2 (按键A)-->单击-->是否符合单击条件-->符合-->记录参数值-->判断条件-->执行不同的功能-->记录参数值-->对其他功能的使能-->返回
这个只是其中一条线,完整的应该是个网。
大的程序我就不知道了,你再看看吧。
标准
c
库函数
不知道行不行,如果在win32环境下,调用win32
API绝对是可以的,用shellexecute
函数
启动
程序
,
命令行参数
在程序
名称
后按
空格
隔开,在调用程序
main函数
中使用string
strLine=::AfxGetApp()->m_lpCmdLine;就可以获取命令行参数了,在开发多进程项目的时候用的比较多,常用于进程间启动
参数传递
。
获取系统进程要使用CreateToolhelp32Snapshot()函数得到快照,然后进行遍历,取出自己想要的信息就可以了。下面是我自己写的一个由进程名称得到进程ID的函数,要得到所有的进程,你只要把循环进行完就行。上代码:
DWORD CXXXDlg::GetProeccIDByName(CString& csProName){
//AddOutPut()是我自己封装的调试函数,可以不用理会
//使用CreateToolhelp32Snapshot()等函数要包含头文件
//#include <TlHelp32h>
AddOutPut(_T("->由进程名字得到进程ID开始"));
if (csProNameIsEmpty())
{
AddOutPut(_T("!!由进程名字得到进程ID失败,进程ID名字为空!"));
return 0;
}
HANDLE hSnapShot = NULL;
hSnapShot = CreateToolhelp32Snapshot(TH32CS_SNAPPROCESS, 0);
if (INVALID_HANDLE_VALUE == hSnapShot)
{
AddOutPut(_T("!!由进程名字得到进程ID失败,创建快照失败!"));
return 0;
}
int nPos = csProNameReverseFind('\\');
csProName = csProNameRight(csProNameGetLength() - nPos);
PROCESSENTRY32 proEntry32 = {0};
bool bRetval = false;
bool bFind = false;
proEntry32dwSize = sizeof(PROCESSENTRY32);
bRetval = Process32First(hSnapShot, &proEntry32) true : false;
while (bRetval)
{
if (0 == StrCmpI(proEntry32szExeFile, csProName))
{
bFind = true;
break;
}
bRetval = Process32Next(hSnapShot, &proEntry32) true : false;
proEntry32dwSize = sizeof(PROCESSENTRY32);
}
if (!bFind)
{
AddOutPut(_T("!!由进程名字得到进程ID失败,未找到该进程!"));
return 0;
}
if (hSnapShot != NULL)
{
CloseHandle(hSnapShot);
}
AddOutPut(_T("->由进程名字得到进程ID成功"));
return proEntry32th32ProcessID;
}
以上就是关于MFC里怎么让程序一运行就自己执行指定的某一段代码 而不用按按钮之类的 *** 作全部的内容,包括:MFC里怎么让程序一运行就自己执行指定的某一段代码 而不用按按钮之类的 *** 作、MFC源代码是如何链接到程序中的、MFC开发的程序该如何写程序流程图 对话框的等相关内容解答,如果想了解更多相关内容,可以关注我们,你们的支持是我们更新的动力!
欢迎分享,转载请注明来源:内存溢出
微信扫一扫
支付宝扫一扫
评论列表(0条)