c - 释放 C 中为 char* 分配的内存

标签 c memory-management

有人可以向我解释一下我下面的代码有什么问题吗? 据我了解,我需要释放为 char* 分配的内存 - 否则它会泄漏。但是,如果我使用(在程序的最后 free()),我会得到: malloc:* 对象 0x7ff7274027a4 的错误:未分配正在释放的指针 *在malloc_error_break中设置断点进行调试 中止陷阱:6

没有“free()”,这段代码运行得很好,并给了我我需要的东西。 预先感谢您!

  #include <stdio.h>
  #include <string.h>
  #include<stdlib.h>

  int main ()
 {
    char *src="start=3.6307436653491267,2.2931731236906048,0";
    char *psrc;
    psrc=calloc((strlen(src)+1),sizeof(char));
    strcpy(psrc,src);
    size_t len= strlen(src);
    len +=1;
    char str[len];
    int count=0;
    char *wt=calloc(3,sizeof(char));
    char *ft=calloc(17, sizeof(char));
    char *finalstr=calloc((strlen(wt) + strlen(ft) + 1), sizeof(char));
    while (psrc != NULL && *psrc != '\0' && count <= len)
    {
        if(psrc[0] == '=')
        {
            psrc +=1;
            strcpy(str, psrc);
            wt=strtok(str, ".");
            ft=strtok(NULL, ".");
            ft=strtok(ft, ",");
            strcpy(finalstr, wt);
            strcat(finalstr, ".");
            strncat(finalstr, ft, 2);
        }
        ++psrc;
        ++count;
   }
   printf("finalstr: %s\n", finalstr);
   //free(psrc);
   exit(EXIT_SUCCESS);
}

最佳答案

该错误是因为您只能将 malloc()/calloc()/返回的指针传递给 free() realloc() 并且您正在传递递增的 psrc

例如,

char *string = malloc(SIZE);
free(string + 1);

是未定义的行为,调用free()的唯一可接受且正确的方法是

free(string);

你有

psrc += 1;

这会更改 psrc 的值,并且它不再指向 calloc() 最初返回的地址。

尽管如果您担心内存泄漏,您需要了解它们。

在您的代码中,您有

char *wt = calloc(3, sizeof(char));

然后,

wt = strtok(str, ".");

这正是内存泄漏:因为您现在无法 free() 之前由 calloc() 返回的内存。

在继续之前,您需要研究指针,当您的代码中存在显式内存泄漏而您又不知道时,担心内存泄漏没有多大意义.

我还认为你应该重新考虑以下陈述

without "free()" this code runs just fine and gives me what I need.

代码并不总是给你你需要的,因为它有严重的错误,会导致未定义的行为,所以它不可能无论如何预测结果。

如果您仔细阅读以下示例中使用的函数的文档,您就会正确地执行以下代码

#include <stdio.h>
#include <string.h>
#include <stdlib.h>

int main(void)
{
    const char *src = "start=3.6307436653491267,2.2931731236906048,0";
    const char *equal;
    char *endptr;
    float value;
    int length;
    char *result;

    // Find the equal sign, if not found the function
    // returns and no output is shown
    equal = strchr(src, '=');
    if (equal == NULL)
        return -1;
    // Convert the string to a `float' starting
    // at the `=' sign and up to the `,'
    value = strtof(equal + 1, &endptr);
    // If the first non numeric character wasn't a `,'
    // then this input string is not as we expected it to
    // be so we abort the program.
    if (*endptr != ',')
        return -1;
    // Create a string from the number, with just 2
    // decimal places.

    // Compute the length of the resulting string
    length = snprintf(NULL, 0, "%.2f", value);
    if (length == -1)
        return -1;
    // Allocate space for it
    result = malloc(length + 1);
    if (result == NULL)
        return -1;
    // Finally "print" the number into the string
    snprintf(result, length, "%.2f", value);
    // Now we have the string we wanted
    fprintf(stdout, "%s\n", result);
    // After we've done our work with `result' then we
    // have to `free()' it
    free(result);
    return 0;
}

关于c - 释放 C 中为 char* 分配的内存,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/47148660/

相关文章:

c - libxml2:使用 xmlNodeDump() 转储节点时缺少子节点

c - 打印 AVL 树中的元素

c - 基于内存对齐将字节数组转换为 int 是否安全?

C - 检查当前可用的空闲 RAM?

c - malloc 返回类型 void * 的意图/好处是什么?

c - 具有自动内存分配的 sprintf()?

c - 收到 parent 的信号后如何向 child 的 child 发送信号

cocoa - Coredata、EXC_BAD_ACCESS 或相关对象上的奇怪行为

c - 如何检查一个值代表一个地址

iPhone开发——防止泄密