关于命令行中 < 的代码说明

linux shell中,<符号表示输入,比如cat < 1.txt,表示1.txt为cat命令的输入。默认情况下,若没有<,则默认输入为键盘。

为此,本人写了一个程序:

#include <stdio.h>


int main(int argc, char **argv)
{
int i = 0;
for(i = 0; i < argc; i++)
{
printf("%s\n", argv[i]);
}
char szBuffer[1024] = {0};
while (fgets (szBuffer, sizeof(szBuffer), stdin) != NULL) {
printf(szBuffer);
szBuffer[0] = 0;
}

return 0;
}

该程序是打印所有的命令行,并打印输入文件的内容,测试结果如下所示:
在这里插入图片描述
可以看到<以及后面的字符串123.txt并不属于命令行参数, < 123.txt由shell处理,其将lessthanTest进程产生的fd为0的描述符指向123.txt。

当然,读者可以在程序的最后面添加while(1)防止退出,然后,到/proc目录下看:

在这里插入图片描述
可以看到,fd=0,即stdin表示的就是文件123.txt。

  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
ICLI 是一个基于 Python 的命令行交互框架,用于快速开发交互式命令行应用程序。下面是 ICLI 命令行配置代码的书写要求及格式: 1. 导入必要的模块和库: 在编写 ICLI 命令行配置代码之前,需要先导入 ICLI 模块和其他必要的 Python 库,如下所示: ``` import click import icli ``` 2. 定义命令行程序: 在 ICLI ,可以通过 `icli.App` 类定义命令行程序。例如: ``` app = icli.App( name='myapp', description='This is my app', version='1.0.0' ) ``` 这里定义了一个名为 `myapp` 的命令行程序,描述为 `This is my app`,版本为 `1.0.0`。 3. 定义命令: 在 ICLI ,可以通过 `@app.command` 装饰器定义命令。例如: ``` @app.command() @click.option('--name', '-n', default='World', help='The name to greet.') def hello(name): """Say hello to someone.""" print(f'Hello, {name}!') ``` 这里定义了一个名为 `hello` 的命令,使用 `--name` 或 `-n` 参数指定要打招呼的人的名字,默认为 `World`。 4. 运行命令行程序: 在 ICLI ,可以通过 `app.run()` 方法运行命令行程序。例如: ``` if __name__ == '__main__': app.run() ``` 这里在程序最后添加了上述代码,表示如果这个 Python 文件作为主程序运行时,会运行 `app.run()` 方法,启动命令行程序。 以上就是 ICLI 命令行配置代码的基本要求和格式。在实际开发,可以根据需要添加更多的命令和参数。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值