zoukankan      html  css  js  c++  java
  • MFC程序中如何接受命令行参数

    在MFC程序中,可以用以下几种方法来获取命令行参数。 为方便说明,我们假设执行了命令:C: estapp.exe -1 -2  
    方法一 
    ::GetCommandLine(); 
    将获取到 "C: estapp.exe"  -1 -2  
    方法二 
    for (int i=0;i<__argc;i++) { 
    __argv[i]; 
    将依次得到C: estapp.exe  -1  -2 }  
    方法三 
    AfxGetApp()->m_lpCmdLine; 将获取到 -1 -2   
    获取命令行的方法: 
     
    1、GetCommandLine() 获取输入的所有信息,包括程序所在路径及参数  
    2、AfxGetApp()->m_lpCmdLine 只包含参数 
     
    一般情况下,获取到命令行后就可以针对命令行中的内容进行相应的处理了  
    CObject  
    └CCommandLineInfo  
    类CCommandLineInfo用于分析启动应用时的命令行参数。 
    MFC应用一般都会在它的应用对象中使用函数InitInstance创建这个类的一个本地实例。然后把该对象传给CWinApp::ParseCommandLine,ParseCommandLine又重复调用ParseParam填充CCommandLineInfo对象。最后,CCommandLineInfo对象被传给
    CWinApp::ProcessShellCommand来处理命令行参数和选项。  
    BOOL CExampleApp::InitInstance()  {  
        ...  
        // 分析标准外壳命令、DDE、打开文件操作的命令行      CCommandLineInfo cmdInfo;      ParseCommandLine(cmdInfo);    
        // 调度在命令行中指定的命令。如果  












        // 用 /RegServer、/Register、/Unregserver 或 /Unregister 启动应用程序,则返回 FALSE。      if (!ProcessShellCommand(cmdInfo))          return FALSE;      ...  }    
    void CWinApp::ParseCommandLine(CCommandLineInfo& rCmdInfo)  {  
        for (int i = 1; i < __argc; i++)  
        {  
            LPCTSTR pszParam = __targv[i];          BOOL bFlag = FALSE;  
            BOOL bLast = ((i + 1) == __argc);          if (pszParam[0] == '-' || pszParam[0] == '/')          {  
                // remove flag specifier              bFlag = TRUE;              ++pszParam;          }  
            rCmdInfo.ParseParam(pszParam, bFlag, bLast);      }  } 
    这里有个继承CCommandLineInfo类的例子  
    =====================  
    目标 
    让应用程序处理这里所见的命令行标志。 
    >XXX.exe /c /d 策略 
    一个MFC应用程序可以用CCommandLineInfo类的成员函数ParseParam()处理一些标准标 志。要添加我们自己的标志,而仍然能够支持另外一些标志,我们将从CCommandLineInfo派 
    生类,然后重载ParseParam()。 步骤 
    1.创建一个新的CCommandLineInfo类 
    1)用ClassWizard创建一个派生于CCommandLineInfo的新类。在新类中,为应用程序要 处理的每个新的标志添加一个Boolean或String成员变量。 classCWzdCommandLineInfo:publicCCommandLineInfo { 
    public: 
    BOOLm_bAFlag; BOOLm_bCFlag; 












    BOOLm_bDAFlag; 
    CStringm_sArg; 
    2)添加一个ParseParam()函数,以重载基类的ParseParam()函数。 //Operations public: 
    voidParseParam(constTCHAR*pszParam,BOOLbFlag,BOOLbLast); }; 
    3)如下实现ParseParam(): 
    voidCWzdCommandLineInfo::ParseParam(constTCHAR*pszParam, BOOLbFlag,BOOLbLast) { 
    CStringsArg(pszParam); if(bFlag) { 
    m_bAFlag=!sArg.CompareNoCase("a"); m_bCFlag=!sArg.CompareNoCase("c"); m_bDAFlag=!sArg.CompareNoCase("da"); } 
    //m_strFileNamegetsthefirstnonflagname elseif(m_strFileName.IsEmpty()) { 
    m_sArg=sArg; } 
    88第二部分用户界面实例 下载 
    CCommandLineInfo::ParseParam(pszParam,bFlag,bLast); } 
    注意到变量pszParam包括命令行中的下一项。如果pszParam的后面是一个—(连字符)或 /(正斜杠)字符,则bFlag变量为TRUE,这些字符将被删除;如果pszParam是一行中最后一个 
    变量,则bLast为TRUE。确信最后调用基类的ParseParam(),否则标准标志不被处理。 4)有关命令行消息类的详细清单,参见本节的“清单—命令行消息类”。 2.把新的命令行消息类插到应用程序类中 
    1)在应用程序类中找到ParseCommandLine(),并用该新类替换CCommandLineInfo类。 //Parsecommandlineforstandardshellcommands,DDE,fileopen CWzdCommandLineInfocmdInfo; 
    ParseCommandLine(cmdInfo); 
    2)现在,命令行选项不能作为cmdInfo变量的成员变量。 if(cmdInfo.m_bAFlag) { ::: 

    3)要使这些选项在整个应用程序中可得,则把cmdInfo嵌入应用程序中,并访问它的成员 变量。 












    (CXXXApp*)AfxGetApp()->m_cmdInfo.m_bAFlag; 注意:CXXXApp类是你自己创建的应用程序类 说明 
    ■标准MFC标志如下,真正处理这些标准命令行发生在ProcessShellCommand(cmdInfo) 中,它正好在应用程序类中ParseCommandLine()之后。 nothing使应用程序试图打开一个新文档 
    filename使应用程序试图以文档方式打开文件名 
    /pfilename使应用程序打开并打印给定的文件名到默认的打印机 /ptfilename与上面相同,但输入到指定的打印机 printerdriverport 
    /dde使应用程序开始运行,并等待DDE命令 /AutomationCOM标志 /Embedding /Unregister 
    /Unregserver 
    ■处理非标准标志(如名字)会有点复杂,我们认为出现的第一个非标准标志是文档文件名。 然而,一旦一个文件名被发现,可以根据目的攫取任何非标准标志,这就是说,除非 遇到/pt标志,在这种情况下,下面三个非标准标志变量用来初始化打印。为了简化起 见,也可通过不把/pt标志传递给基类中的ParseParam()来禁用/pt标志。 
    ■当然,如果不需继续支持前面所示的标准MFC标志,则可以更加自由地行动。只要不 用调用基类的ParseParam(),可以使用任何标志或非标准标志选项。但是,不要因为能 用非标准标志,而轻易放弃这些标准标志提供的功能。 
  • 相关阅读:
    [转]vs2010 快捷键大全
    oracle 分组排序
    jqGrid如何实现单选。
    WCF 服务调用RFC 出现异常
    c语言修饰符总结const、static、volatile、auto、extern、register
    BL和LDR——位置无关码和位置相关码
    原码,反码,补码(二)
    原码补码反码
    C语言内存分布
    ARM总线架构(S3C2440)
  • 原文地址:https://www.cnblogs.com/hzcya1995/p/13318544.html
Copyright © 2011-2022 走看看