【问题标题】:LeetCode ERROR: AddressSanitizer: heap-buffer-overflowLeetCode 错误:AddressSanitizer:堆缓冲区溢出
【发布时间】:2023-01-25 22:14:49
【问题描述】:

我的代码可以正确打印答案,但是当我尝试返回 ans 变量时,它显示堆缓冲区溢出。

char * longestPalindrome(char * s){
    int le = strlen(s);
    int t = 0, it = 0;
    int start = 0, end = 0;
    int max = 0; 
    for (int i = 0; i < le; i++){
        it = i;
        for (int j = le-1; j > i; j--){
            t = 0;
            while (s[it] == s[j]){
                t++;
                j--;
                it++;
                if (j < i){
                    break;
                }
            }
            if (max < t){
                max = t;
                start = i;
                end = it-1;
            }
            it = i;
        }
    }
    char *ans;
    ans = (char *)malloc(sizeof(char)*(max));
    for(int i = 0; i < max; i++){
        ans[i] = s[start+i];
    }
    return ans;
}

错误描述是这样的: ==34==错误:AddressSanitizer:地址 0x602000000033 上的堆缓冲区溢出,位于 pc 0x557f4a2709ab bp 0x7fff8135edd0 sp 0x7fff8135edc0 在 0x602000000033 线程 T0 读取大小 1 #2 __libc_start_main 中的 0x7f4879d2e0b2 (/lib/x86_64-linux-gnu/libc.so.6+0x270b2) 0x602000000033 位于 3 字节区域右侧的 0 个字节 [0x602000000030,0x602000000033) 在这里由线程 T0 分配: #0 0x7f487a973bc8 在 malloc (/lib/x86_64-linux-gnu/libasan.so.5+0x10dbc8) #3 __libc_start_main 中的 0x7f4879d2e0b2 (/lib/x86_64-linux-gnu/libc.so.6+0x270b2)

【问题讨论】:

  • 不要忘记再分配一个额外的字节来标记字符串的结尾
  • @embedded4ever 两个想法 :-) 这正是我在回答中写的 + OP 也需要实际终止字符串。

标签: c memory-leaks address-sanitizer


【解决方案1】:

您需要为ans再分配一个字节,以便为腾出空间

猜你喜欢
  • 2022-11-14
  • 2019-01-05
  • 1970-01-01
  • 2021-09-20
  • 1970-01-01
  • 1970-01-01
  • 2017-01-04
  • 1970-01-01
  • 1970-01-01
相关资源
最近更新 更多