在 Windows 开发中,入口点函数和嵌入可执行文件的启动函数是两个相关但不同的概念:
Windows 应用程序入口函数
- GUI(Graphical User Interface)应用,链接器选项:
/SUBSYSTEM:WINDOWS
- CUI(Console User Interface)应用,链接器选项:
/SUBSYSTEM:CONSOLE
_tWinMain 与 _tmain 函数声明
Int WINAPI _tWinMain(
HINSTANCE hInstanceExe,
HINSTANCE,
PTSTR pszCmdLine,
int nCmdShow);
int _tmain(
int argc,
TCHAR *argv[],
TCHAR *envp[]);
应用程序类型 | 入口点函数 | 嵌入可执行文件的启动函数 |
---|---|---|
处理ANSI字符(串)的GUI应用程序 | _tWinMain(WinMain) | WinMainCRTSartup |
处理Unicode字符(串)的GUI应用程序 | _tWinMain(wWinMain) | wWinMainCRTSartup |
处理ANSI字符(串)的CUI应用程序 | _tmain(Main) | mainCRTSartup |
处理Unicode字符(串)的CUI应用程序 | _tmain(wMain) | wmainCRTSartup |
动态链接库(Dynamic-Link Library) | DllMain | _DllMainCRTStartup |
入口点函数(Entry Point Function)
-
定义:入口点函数是程序加载到内存后开始执行的第一个函数。在 Windows 应用程序中,这个函数通常被称为 WinMain(对于图形用户界面应用程序)或 main(对于控制台应用程序)。
-
作用:入口点函数是程序执行的起点。它负责初始化应用程序,处理命令行参数,创建窗口(对于 GUI 应用程序),并进入消息循环(对于 GUI 应用程序)或执行主要的程序逻辑(对于控制台应用程序)。
-
位置:在 Visual Studio 项目中,入口点函数通常在项目的源文件中定义,并且在链接时被指定为程序的入口点。
嵌入可执行文件的启动函数(Startup Function for Embedded EXE)
-
定义:在某些情况下,一个可执行文件可能被嵌入到另一个程序中,而不是作为独立的应用程序运行。在这种情况下,嵌入的可执行文件需要一个特定的函数来处理它的启动和执行,这个函数就是所谓的启动函数。
-
作用:启动函数负责加载嵌入的可执行文件,设置它的运行环境,调用它的入口点函数,并在适当的时候处理它的退出。
-
位置:启动函数通常由宿主应用程序(即嵌入可执行文件的程序)提供,并在宿主应用程序的源代码中定义。
区别和联系
-
区别:入口点函数是独立应用程序的起始点,而启动函数是嵌入可执行文件的运行管理函数。入口点函数直接开始程序的执行,而启动函数负责在宿主环境中启动和管理嵌入的程序。
-
联系:无论是独立运行的应用程序还是嵌入的可执行文件,它们的执行最终都会通过某个形式的入口点函数开始。在嵌入的情况下,启动函数充当了与宿主应用程序交互的桥梁,它在适当的时候调用嵌入可执行文件的入口点函数。
在实际开发中,如果你正在开发一个需要嵌入到其他应用程序中的组件或库,你需要定义一个启动函数来管理这个组件的生命周期。如果你正在开发一个独立的应用程序,你只需要定义一个入口点函数,如 WinMain 或 main。在某些复杂的部署场景中,如 DLL 注入或其他高级技术,启动函数的概念可能会变得更加重要。