当前位置: 首页 > news >正文

Windows编程----进程:命令行参数

什么是进程的命令行参数

每个进程在启动(双击exe启动、cmd命令行启动或者由其他程序通过CreateProcess启动)的时候,都会有一个命令行参数给它。命令行的参数以空格区分。这个命令行总是不为空,因为命令行参数的第第一参数是exe程序的启动路径。但是一般情况下,我们会忽略这个参数。一般情况下,我们忽略第一个参数,将后面的内容作为命令行参数对待。

如何获取命令参数一

方法一:通过Windows API GetCommandLine 获取命令参数。
#include <iostream>
#include <Windows.h>
int main()
{
    PTSTR cmdStr = GetCommandLine();
    std::wcout << cmdStr << std::endl;
}

在VS项目的属性页中,设置调试属性为 key1=value1 key2=value2 这个属性可以配置启动程序的命令行参数。

调试项目之后之后,会得到下面的输出结果"D:\project\ConsoleApp1\x64\Debug\ConsoleApp.exe" key1=value1 key2=value2,从输出结果可以看到GetCommandLine api获取到的结果 第一个参数为"D:\project\ConsoleApp1\x64\Debug\ConsoleApp.exe" ,第二个参数为key1=value1,一般参数都是key-value键值对。第三个参数为key2=value2.一般情况下,我们会忽略第一个参数。从程序的角度来讲,命令行参数本质上就是以0结尾的一个字符串。我们可以定义任何格式的字符串作为命令行参数。但是通常情况下,我们以空格作为分割命令行参数的分割符号。

一般我们用key=value的形式表示一个命令行参数。但这也不是绝对的。我们也还可以其他的参数格式key1=value1 --key2=value2 /key3=value3 --key4 value4 /key5 value5具体参数,可以在程序中,自行解析。

方法二:通过修改main函数的参数

main函数除了可以写成上面的格式之外,还可以写成带参数的格式,如下:

int main(int argc,char** argv)

第一个参数argc表示命令行参数的个数,第二个参数表示命令行参数的指针数组。这种写法的好处是不用自己手动解析参数,操作系统会帮助我们解析好参数之后,放在数组指针中,我们直接拿着用就可以。

#include <iostream>
#include <Windows.h>
int main(int argc,char** argv)
{
    for (int i = 0; i < argc; i++) {
        std::wcout << argv[i] << std::endl;
    }
}

上面代码,通过循环输出所有的参数,输出结果如下:

方法三:通过全局变量获取命令行参数

windows提供了__argc的全局变量表示命令行参数的个数,通过__argc或者__wargv表示命令行的参数,相当于方法二中 main函数的第二个参数char** argv__wargv表示unicode版本,__argc表示ANISC版本。

#include <iostream>
#include <Windows.h>
int main(int argc,char** argv)
{
    std::cout << __argc << std::endl;
    for (size_t i = 0; i < __argc; i++)
    {
        std::wcout << __argv[i] << std::endl;
    }
}

运行上面代码,可以得到如下结果:直接打印出命令行参数的个数和参数的具体内容。当然微软不建议使用这两个全局变量来访问命令行参数个数和参数内容。一般建议使用方法一和方法二访问命令行参数和参数内容。

解析命令行参数

微软提供一个CommandLineToArgvWAPI来对命令行参数进行解析,但是这个API目前貌似只提供了UNICODE版本的API。

#include <iostream>
#include <Windows.h>
int main(int argc,char** argv)
{
    PTSTR cmdStr = GetCommandLine();
    int numArgs;
    PWSTR* str = CommandLineToArgvW(cmdStr, &numArgs);
    for (size_t i = 0; i < numArgs; i++)
    {
        std::wcout << str[i] << std::endl;
    }
    HeapFree(GetProcessHeap(), 0, str);
}

执行上述代码会输出以下结果,可以看到三个命令行参数被正确打印出来。因为CommandLineToArgvWAPI在函数内部会分配内存,所以我们要记得释放内存。尤其是当我们频繁调用这个API的时候。

相关文章:

  • 如何根据应用需求选择光谱相机
  • OpenCV计算摄影学(18)平滑图像中的纹理区域同时保留边缘信息函数textureFlattening()
  • 第五章 起航16 申请一个外包资源
  • 【Linux 22.4 ubuntu 安装cuda12.1 完整方案】
  • OFA:通过简单的序列到序列学习框架统一架构、任务和模态
  • 数学建模:MATLAB强化学习
  • 通过 Docker openssl 容器生成生成Nginx证书文件
  • 2025-03-07 :详细介绍一下 Databricks 的 Lakehouse
  • 【华为OD机试真题29.9¥】(E卷,100分) - 运维日志排序(Java Python JS C++ C )
  • OpenHarmony子系统开发编译构建指导
  • dart中实现子isolate的管理类,特适用于针对数据库的处理
  • 【js逆向】iwencai国内某金融网站实战
  • 心智模式—系统思考
  • 小白学Agent技术[1]
  • 初阶数据结构(C语言实现)——3.4带头双向循环链表详解(定义、增、删、查、改)
  • Android AudioFlinger(四)—— 揭开PlaybackThread面纱
  • ollama 安装方式
  • 九章云极 Aladdin重塑 AI 开发范式的先锋力量
  • Mybatis-Plus 插件机制与自定义插件实现
  • 分布式锁—6.Redisson的同步器组件
  • 淘宝几百块钱做网站靠谱吗/西安关键词seo
  • 网站建设的市场容量/广州头条今日头条新闻
  • 网站访问过程/站长统计是什么意思
  • 企业线上培训平台有哪些/广州seo和网络推广
  • wordpress开发工作流/比较好的网络优化公司
  • 寻找郑州网站建设公司/今天全国疫情最新消息