C语言 如何从调用方分配的内存空间中捕获由被调用方组织的字符串数组



我想将内存空间传递给被调用者以收集从文件中过滤掉的字符串数组(即/tmp/saveconfig,它列在问题末尾(。通常,它应该具有以下输出,

/dev/disk/by-id/scsi-2001b4d2039784462
/dev/disk/by-id/scsi-2001b4d2049798685
/dev/disk/by-id/scsi-2001b4d2032048753

更具体地说,我假设调用者,即 main((,只需通过 char *ptr = malloc(4096( 分配一个空间并将其传递给 get_devs((,然后由调用者释放空间。在 get_devs(( 中组织字符串数组后,调用方可以使用 char *dev[] 从分配的空间迭代字符串。换句话说,如何将 *ptr 与 *dev[] 相关联?但是根据下面的代码片段,我得到了分段错误。我哪里做错了?请给我一个提示。

int get_devs(char *pdev[])
{
    FILE *fp;
    char str[64];
    int len = 0, count = 0;
    char *cp, *ptr;
    /* opening file for reading */
    fp = fopen("/tmp/saveconfig", "r");
    if(fp == NULL) {
        perror("Error opening file");
        return(-1);
    }
    while(fgets(str, 64, fp) != NULL) {
        if (ptr = strstr(str, "/dev/")) {
            for (len = 1, cp = ptr; *cp != 'n'; len++, cp++) {
                if (*cp == '"') {
                    *cp = '';
                    break;
                }
            }
            strncpy(*pdev, ptr, len);
            printf("%sn", pdev);
            pdev++;
            count++;
        }
    }
    fclose(fp);
    return count;   
}
int main()
{
    int i = 0, count = 0;
    char *pdev[64];
    count = get_devs(pdev);
    for (; i < sizeof(pdev) / sizeof(*pdev); i++) {
        printf("%sn", pdev[i]);
    }
}

保存配置文件如下,

{
  "fabric_modules": [], 
  "storage_objects": [
    {
      "attributes": {
        "block_size": 512, 
      }, 
      "dev": "/dev/disk/by-id/scsi-2001b4d2039784462", 
      "name": "scsi-2001b4d2039784462", 
      "plugin": "block", 
      "readonly": false, 
      "write_back": false
    }, 
    {
      "attributes": {
        "block_size": 4096
      }, 
      "dev": "/dev/disk/by-id/scsi-2001b4d2049798685", 
      "name": "scsi-2001b4d2049798685", 
      "plugin": "block", 
      "readonly": false, 
      "write_back": false
    }, 
    {
      "attributes": {
        "block_size": 512, 
      }, 
      "dev": "/dev/disk/by-id/scsi-2001b4d2032048753", 
      "name": "scsi-2001b4d2032048753", 
      "plugin": "block", 
      "readonly": false, 
      "write_back": false
    }
  ]
}

许多错误,但最重要的是:

char *pdev[64];

为 64 个指向字符的指针分配空间。但是您没有为字符本身分配任何空间,因此当您稍后strncpy(*pdev, ...)时,您将复制到随机内存中。此外,您只使用第一个指针。 您可能打算这样做:

char *pdev[1000];  // How many lines in file?
int i = 0;
while (fgets(str... {
    pdev[i] = malloc(strlen(str) + 1);
    memmove(pdev[i], str, strlen(str) + 1);
    . . .
    i += 1;
    . . .

试试这个:

   ptr = strstr(str, "/dev/");
   if (!ptr) {
        .....
   }

strstr(( 返回 NULL 是没有匹配项的。
否则,它将返回第一个匹配项的字符串的第一个字符的地址。

最新更新