strok and strok_r parse parameters

本文介绍了一个用于解析字符串参数的C语言函数parseargs。该函数接受一个字符串和一个指向整数的指针作为输入,返回一个指向字符串数组的指针。通过对输入字符串进行分隔,可以得到一系列参数并存储为字符串数组。
char ** parseargs(char *s, int * argc)
{
    char *token = 0;
    char **array = 0;
    char * temp = NULL;
    int index = 0;
    int length = (int) strlen(s);
    if (0 == argc || length < 1)
    {
        return NULL;
    }

    char *params = malloc(length + 1);
    memcpy(params, s, strlen(s) + 1);

    temp = strtok(s, " ");
    *argc = 0;
    while (temp != 0)
    {
        temp = strtok(NULL, " ");
        (*argc)++;
    }
    array = malloc((*argc) * sizeof(char*));

    token = strtok_r(params, " ", &temp);
    while (token != NULL)
    {
        length = strlen(token) + 1;
        array[index] = (char *) malloc(length);
        memcpy(array[index], token, length);
        index++;
        token = strtok_r(NULL, " ", &temp);
    }
    free(params);
    return array;

}// end makeArgs
### 解决 `stroke_registry_app` 编译失败问题 #### 问题分析 根据用户提供的日志信息,`pages.json` 文件在第 5 行存在多个 JSON 格式错误。具体表现为: - 预期字符串但发现 `<<`。 - 预期冒号 (`:`) 但发现 `<<`。 - 预期 JSON 值但发现 `<<`。 - 预期右大括号 (`}`) 但发现 `<<`。 - 预期右中括号 (`]`) 但发现 `<`。 - 预期右大括号 (`}`) 但发现 `Updated`。 这些错误表明 `pages.json` 文件的第 5 行可能存在以下问题: 1. 键或值未正确使用双引号包裹。 2. 使用了非法字符(如 `<<` 或 `Updated`)。 3. JSON 结构不完整或格式错误。 --- #### 修复方案 以下是针对 `pages.json` 文件可能存在的问题及修复方法: ##### 1. 确保键和值使用双引号包裹 JSON 格式要求所有键和字符串值必须用双引号包裹。例如: ```json { "pages": [ "pages/index/index" ], "window": { "navigationBarTitleText": "示例标题" } } ``` 如果缺少双引号,会导致解析失败[^2]。 ##### 2. 检查非法字符 根据错误信息,`<<` 和 `Updated` 可能是误输入的非法字符。需要删除这些内容并确保 JSON 文件中只包含合法的 JSON 数据结构。 例如,假设原始文件如下: ```json { "pages": [ "pages/index/index", << Updated >> ] } ``` 修复后应为: ```json { "pages": [ "pages/index/index" ] } ``` ##### 3. 验证 JSON 文件格式 可以使用在线工具(如 JSONLint)或 IDE 内置功能验证 `pages.json` 文件是否符合 JSON 标准。如果文件不符合规范,工具会指出具体位置和错误类型。 --- #### 示例修复 假设原始 `pages.json` 文件如下: ```json { "pages": [ "pages/index/index", << Updated >> ], "window": { navigationBarTitleText: "示例标题" } } ``` 修复后的文件应为: ```json { "pages": [ "pages/index/index" ], "window": { "navigationBarTitleText": "示例标题" } } ``` --- #### 注意事项 1. **多余逗号**:JSON 不允许在最后一个元素后添加逗号。 2. **缺失引号**:所有键和字符串值都必须用双引号括起来。 3. **非法字符**:避免使用全角字符或特殊符号。 --- ###
评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值