MFC程序中如何接受命令行参数

MFC程序中如何接受命令行参数


2024年5月19日发(作者:)

在MFC程序中,可以用以下几种方法来获取命令行参数。

为方便说明,我们假设执行了命令:C: -1 -2

方法一

::GetCommandLine();

将获取到 "C:" -1 -2

方法二

for (int i=0;i<__argc;i++)

{

__argv[i];

将依次得到C: -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;

}

aram(pszParam, bFlag, bLast);

}

}

这里有个继承CCommandLineInfo类的例子

=====================

目标

让应用程序处理这里所见的命令行标志。

> /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=!eNoCase("a");

m_bCFlag=!eNoCase("c");

m_bDAFlag=!eNoCase("da");

}

//m_strFileNamegetsthefirstnonflagname

elseif(m_y())

{

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(),可以使用任何标志或非标准标志选项。但是,不要因为能

用非标准标志,而轻易放弃这些标准标志提供的功能。


发布者:admin,转转请注明出处:http://www.yc00.com/news/1716131123a2724415.html

相关推荐

发表回复

评论列表(0条)

  • 暂无评论

联系我们

400-800-8888

在线咨询: QQ交谈

邮件:admin@example.com

工作时间:周一至周五,9:30-18:30,节假日休息

关注微信