C语言 SIGSEGV (Segmentation fault)

出错代码

typedef struct {
    char *ch;//按串长分配存储区,ch指向串的基地址
    int length;//串的长度
}HString;
//定位操作,若主串S中存在与串T值相同的子串,则返回它在主串S中第一次出现的位置,否则,返回-1
int Index(HString S,HString T){
    if (S.length < T.length)
        return -1;
    for (int i = 0; i < S.length; ++i) {;
        HString Sub;
        SubString(Sub,S,i,T.length);
        bool  flag = false;
        if (Sub.length == T.length) {
            for (int j = 0; j < T.length; ++j) {
                if (Sub.ch[j] != T.ch[j]){
                    flag = true;
                    continue;
                }
            }
            if (flag)
                continue;
            else
                return i;
        }
    }
    return -1;
}

错误:SIGSEGV (Segmentation fault)

经过调试,发现 那一行代码返回值结果和预期是相同的,但是就是在那一行出现 Segmentation fault,因此可能是那一行代码里面的指针有问题,经查找,是 HString 的char*指针未初始化,使用了未初始化的指针

解决方法:
调用初始化方法对指针初始化

HString InitStr(HString &S){
    S.ch = (char *) malloc(sizeof(char ));
    if (S.ch == NULL) {
        cout<<"内存分配失败"<<endl;

    }
    S.length = 0;
    return S;
}
HString Sub = InitStr(Sub);

### 解决 C/C++ 中 `memcpy` 导致的段错误 当遇到 `memcpy` 使用后出现的 segmentation fault 错误时,通常是因为目标缓冲区未被正确初始化或分配足够的空间。对于给定的情况,可以观察到几个潜在的原因。 在提供的代码片段中,变量 `data` 被声明为指向字符数组的指针,但是并没有为其分配实际的存储空间就尝试执行复制操作[^2]: ```c char Data[] = "qwertyuiop"; char *data; memcpy(data, Data, sizeof(Data)); ``` 为了防止此类错误的发生,应该确保目标指针已经指向了一块有效的内存区域。以下是修正后的版本: ```c #include <stdio.h> #include <stdlib.h> #include <string.h> int main() { char source[] = "qwertyuiop"; // 动态分配足够大小的空间用于保存副本 char *destination = (char *)malloc(sizeof(source)); if (!destination) { fprintf(stderr, "Memory allocation failed\n"); return EXIT_FAILURE; } // 执行安全的数据拷贝 memcpy(destination, source, sizeof(source)-1); destination[sizeof(source)-1]='\0';// 确保字符串以null结尾 printf("Copied string is \"%s\".\n", destination); free(destination); // 不要忘记释放动态分配的资源 } ``` 上述代码通过调用 `malloc()` 函数来显式地请求操作系统提供一块适当尺寸的新内存块,并检查返回值是否为空(即是否有足够的可用内存)。只有在这一步骤完成后才会继续进行数据传输过程。此外,在完成工作之后记得释放之前申请过的堆内存在程序结束前。 另一个重要的注意事项是在使用像 `sizeof()` 运算符获取源对象长度的时候减去最后一个位置留给终止符 `\0` 的空间,从而避免越界写入的风险。 最后需要注意的是,如果打算处理更复杂的数据结构而非简单的字节数组,则可能还需要考虑深浅拷贝的区别以及相应的实现方式。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值