x264.c中取后缀名,方法好诡异,求解释

本文探讨了x264.c中文件名后缀解析的具体实现方式,通过指针操作高效地获取文件扩展名。

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

x264.c中:

static int  Parse( int argc, char **argv,
                   x264_param_t *param, cli_opt_t *opt )
{
    char *psz_filename = NULL;   /* 用来存解析到的文件名 */

    char *psz;

 

    psz_filename = argv[optind++]; /* 文件名 */

 

    psz = psz_filename + strlen(psz_filename) - 1; 

 

    while( psz > psz_filename && *psz != '.' )
   {
        psz--; /* psz是什么类型啊,怎么--了 */
   }

这儿很乱啊

psz_filename 是char *

psz 是char *

 psz = psz_filename + strlen(psz_filename) - 1; //这句和unsigned int  相加, 和1相减

那psz是char * , 右边是 char * + unsigned int - int

这个结果就算不出错,也没什么用啊,奇怪,从后续代码看来,这个while循环是取文件名的后缀,即点及点后面的部分。

 

psz_filename = argv[optind++]; - 加菲 -  .
 
 

 但是要取后缀,完全不用这样麻烦啊,

 

psz_filename = argv[optind++]; - 加菲 -  .
 
psz_filename = argv[optind++]; - 加菲 -  .
 
 
 

 #include "stdafx.h"

int main(int argc, char* argv[])
{
 char * str;
 str = "a";
 unsigned int i;
 i = 2;
 //str + i;
 printf("%s\n",str);
 printf("str + i = %d !\n", str + i);
 printf("str + i = %d !\n", 'abc' + 2);

 

 printf("Hello World!\n");
 return 0;
}

   
 
经过如下测试,确认是取后缀名,测试代码如下:

 
#include "stdafx.h"
#include <string.h>

int main(int argc, char* argv[])
{
 char *psz_filename = NULL;
 char *psz;

 psz_filename = "abc.avi";
 psz = psz_filename + strlen(psz_filename) - 1;

    while( psz > psz_filename && *psz != '.' )
 {
  psz--;
 }


 printf("psz = %s\n",psz);


 printf("Hello World!\n");
 return 0;
}

 运行效果如图:
psz_filename = argv[optind++]; - 加菲 -  .
 
   
把如上代码加了点输出打印,如下:

 #include "stdafx.h"
#include <string.h>

int main(int argc, char* argv[])
{
 char *psz_filename = NULL;
 char *psz;

 psz_filename = "abc.avi";
 psz = psz_filename + strlen(psz_filename) - 1;

 printf("psz_filename = %s\n",psz_filename);
 printf("psz = %s\n",psz);

 printf("-------------------------\n");

    while( psz > psz_filename && *psz != '.' )
 {
  printf("psz = %s\n",psz);
  psz--;
  printf("psz = %s\n",psz); 
 }

 printf("-------------------------\n");
 printf("psz = %s\n",psz);


 printf("Hello World!\n");
 return 0;
}

 
x264.c中取后缀名,方法好诡异,求解释 - 加菲 -  .
 
去掉while与psz--之间的print:
x264.c中取后缀名,方法好诡异,求解释 - 加菲 -  .
 
 
   
 看着应该是移动内存地址了
请大侠帮着解释一下
资源下载链接为: https://pan.quark.cn/s/22ca96b7bd39 在当今的软件开发领域,自动化构建与发布是提升开发效率和项目质量的关键环节。Jenkins Pipeline作为一种强大的自动化工具,能够有效助力Java项目的快速构建、测试及部署。本文将详细介绍如何利用Jenkins Pipeline实现Java项目的自动化构建与发布。 Jenkins Pipeline简介 Jenkins Pipeline是运行在Jenkins上的一套工作流框架,它将原本分散在单个或多个节点上独立运行的任务串联起来,实现复杂流程的编排与可视化。它是Jenkins 2.X的核心特性之一,推动了Jenkins从持续集成(CI)向持续交付(CD)及DevOps的转变。 创建Pipeline项目 要使用Jenkins Pipeline自动化构建发布Java项目,首先需要创建Pipeline项目。具体步骤如下: 登录Jenkins,点击“新建项”,选择“Pipeline”。 输入项目名称和描述,点击“确定”。 在Pipeline脚本中定义项目字典、发版脚本和预发布脚本。 编写Pipeline脚本 Pipeline脚本是Jenkins Pipeline的核心,用于定义自动化构建和发布的流程。以下是一个简单的Pipeline脚本示例: 在上述脚本中,定义了四个阶段:Checkout、Build、Push package和Deploy/Rollback。每个阶段都可以根据实际需求进行配置和调整。 通过Jenkins Pipeline自动化构建发布Java项目,可以显著提升开发效率和项目质量。借助Pipeline,我们能够轻松实现自动化构建、测试和部署,从而提高项目的整体质量和可靠性。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值