初识命令行参数(以my_chmod为例)

本文通过一个具体的C语言程序实例——my_chmod.c,详细解析了如何利用命令行参数实现文件权限更改的功能。文章介绍了如何使用argc和argv来接收并处理命令行参数,包括参数个数的校验、权限数值的转换等。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

<span style="font-family: Arial, Helvetica, sans-serif; font-size: 18px; background-color: rgb(255, 255, 255);"></span><pre name="code" class="cpp">#include<stdio.h>
#include<stdlib.h>
#include<sys/types.h>
#include<sys/stat.h>

int main(int argc,char ** argv)
{
    int mode;   //权限
    int mode_u;     //所有者的权限
    int mode_g;     //所属组的权限
    int mode_o;     //其他用户的权限
    char *path;

    /*检查参数个数合法性*/
    if(argc < 3){
        printf("%s <mode num> <target file>\n",argv[0]);
        exit(0);
    }
    
    /*获取命令行参数*/
    mode = atoi(argv[1]);
    if(mode > 777 || mode < 0){
        printf("mode num error!\n");
        exit(0);
    }
    mode_u = mode / 100;
    mode_g = (mode - (mode_u * 100)) / 10;
    mode_o = mode - (mode_u * 100) - (mode_g * 10);
    mode = (mode_u * 8 * 8) + (mode_g * 8) + mode_o;    //八进制转换
    path = argv[2];

    if(chmod(path,mode) == -1){
        perror("chmod error");
        exit(1);
    }

    return 0;
}
<span style="font-family: Arial, Helvetica, sans-serif; font-size: 18px; background-color: rgb(255, 255, 255);">
</span>
<span style="font-family: Arial, Helvetica, sans-serif; font-size: 18px; background-color: rgb(255, 255, 255);">以这个my_chmod.c为例,之前我所接触到的程序都是在函数中计算的,而这个程序直接在命令行里就可以用,而能在终端直接运行的关键就在于命令行参数。</span><span style="font-family: Arial, Helvetica, sans-serif; background-color: rgb(255, 255, 255);">也就是这里的main(int argc, int ** argv),而括号里面的两个参数是固定的写法。现在来看argc,假如只输入程序名(例如ls),由操作系统传来的参数为argc = 1,表示只有一个程序名称。argc只有一个元素,argv[0]指向输入的程序路径及名称(: ./ls)。如果输入程序名和一个参数(例如ls -a),有一个参数,由操作系统传来的参数为argc = 2,表示除程序名称外还有一个参数。argv[0]指向程序路径及名称,argv[1]指向参数 (-a)字符串。如果输入程序名和两个参数(例如 chmod mode file),由操作系统传来的参数为argc = 1,表示有一个程序名称和两个参数。argv[0]指向程序路径及名称,argv[1]指向第一个参数字符串(mode),argv[2]指向第二个参数字符串(file)。</span>

下面来看my_chmod.c中命令行参数的应用。

    if(argc < 3){    //检查参数个数的合法性

这一行中根据操作系统传来的参数argc来检查参数个数的合法性。

        printf("%s <mode num> <target file>\n",argv[0]);
这一行中的argv[0]显示程序的路径。

    /*获取命令行参数*/
    mode = atoi(argv[1]);
这里把第一个参数转换成整型数。

  path = argv[2];
这里指针指向第二个参数,在接下来调用chmod()时传入第二个参数。

完)

### 回答1: 要将文件 `f_xuehao.txt` 的权限设置为 `rwx-w---x`,可以使用以下命令: ``` chmod 731 f_xuehao.txt ``` 其中,`chmod` 是用于修改文件或目录权限的命令,`7` 表示拥有者的权限为 `rwx`,`3` 表示组用户的权限为 `w--`,`1` 表示其他用户的权限为 `--x`,`f_xuehao.txt` 则是要修改权限的文件名。 解释一下 `rwx-w---x` 代表的权限: - `rwx`:表示拥有者(owner)对文件拥有读、写和执行权限。 - `-w-`:表示组用户(group)对文件只拥有写权限,没有读取和执行权限。 - `--x`:表示其他用户(others)对文件只拥有执行权限,没有读取和写入权限。 因此,当将 `f_xuehao.txt` 的权限设置为 `rwx-w---x` 后,只有文件的拥有者可以读、写和执行此文件,组用户只能写此文件,其他用户只能执行此文件。 ### 回答2: 要将文件f_xuehao.txt的权限设置为rwx-w---x,在Linux命令行界面中,可以使用chmod命令来完成。 要设置文件的权限,需要使用数字表示权限。每种权限用一个数字表示,分别为读(r)=4,写(w)=2,执行(x)=1,若要同时赋予某个用户组的多个权限,可以将这些数字相加。 根据给定的权限rwx-w---x,可以分为三个用户组来解释: 1. 所有者(Owner):rwx,即读、写和执行的权限。Owner是指该文件的创建者,对文件拥有全部的权限,可以读取、写入和执行该文件。 2. 所有者所在的组(Group):w--,即只有写入权限。Group是指该文件所属的用户组,对于该用户组的成员来说,只有写入该文件的权限,不能读取和执行。 3. 其他用户(Others):--x,即只有执行权限。Others是指除了Owner和Group之外的其他用户,他们只有执行该文件的权限,不能读取和写入。 所以,将f_xuehao.txt的权限设置为rwx-w---x的含义是,Owner对该文件拥有读、写和执行的所有权限,Group只有写入该文件的权限,其他用户只有执行该文件的权限。 ### 回答3: 要将f_xuehao.txt的权限设置为rwx-w---x,可以使用chmod命令。在命令行中输入如下命令: chmod 731 f_xuehao.txt 这个权限设置代表以下含义: - rwx:所有者(Owner)有读(Read)、写(Write)和执行(Execute)的权限; - -w-:组(Group)只有写的权限; - --x:其他用户(Others)只有执行的权限。 对应数字权限为731: - 7:所有者的权限为4(读)+2(写)+1(执行),即rwx; - 3:组的权限为2(写),即-w-; - 1:其他用户的权限为1(执行),即--x。 所以,以设置权限为rwx-w---x,表示文件的所有者可以读、写和执行,组成员只能写入,其他用户可以执行。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值