出现段错误的情况汇总

2023-11-12

1. 访问数组时超过数组边界

int data[20];
int n;

for (n = 0; n <= 20; n++) {
    ...
    //operate on data[n]
    ...
}

上面声明的数组长度为20,但是却会访问data[20], 已经超过了数组边界,导致段错误出现。

2. 数组的长度是负值

int imgWidth, imgHeight;
long long len = imgWidth * imgHeight;
char imgSize[len];

其中imgWidth, imgHeight 很大,导致len算出来为负数,比如

imgHeight=1997306112
imgWidth=2147483647
imgSize=-1997306112

buf分配失败,导致Segmentation fault

我这个程序在在嵌入式系统上运行,int, long , long long int类型数据的长度是一样的。

3. 使用strcpy函数时不小心将dest buffer后面的空间覆盖掉了。

​​​​​​​char *strcpy(char *dest, char *src);   通常用于字符串拷贝,会把src中的字符复制到dest所指空间,直到遇到‘\0’为止。如果src字符串长度大于dest数组长度,那就很危险了。
char *strncpy(char *dest, char *src, size_t num);  会将src中的前num个字符拷贝到dest中, 可以用num限制拷贝长度,防止dest空间被意外覆盖,较为安全。

注:还可以使用strdup()函数来代替上面的方法,但是使用完了之后一定要记得使用free释放申请的空间。

#include <string.h> 
char *strdup(const char *s);

//strdup函数实现
char * __strdup(const char *s)
{
   size_t  len = strlen(s) + 1;
   void *new = malloc(len);
   if (new == NULL)
      return NULL;
   return (char *)memecpy(new,s,len);
}

例子:

char *src = "abcd";

char *new = strdup(src);

本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系:hwhale#tublm.com(使用前将#替换为@)

出现段错误的情况汇总 的相关文章

  • 详谈概率图模型(PGM)

    概率图 引言 1 概述 2 基本问题 2 1 模型表示 2 1 1 有向图模型 2 1 2 无向图模型 2 1 3 有向图和无向图之间的转化 2 2 学习问题 2 3 推断 引言 quad quad 机器学习是根据一些已观察到的证据 如训练
  • VMware vCenter 7.0U2A升级攻略VMware vCenter 7.0U3C攻略

    一 概述 写这篇文章是因为VMware 7 0U2A之前版本有个bug 用户可根据漏洞 CVE 2021 22005 进行提权443端口 直接访问vCenter 443管理界面 然后想着将VMware 7 0U2A升级至最新版VMware
  • 应急响应思路

    应急响应过程 目的 分析攻击时间 攻击操作 攻击结果 安全修复等并给出合理的解决方案 保护阶段 直接断网 保护现场 看是否能够恢复数据 分析阶段 对入侵过程进行分析 常见方法为指纹库搜索 日志时间分析 后门追查分析 漏洞检查分析等 复现阶段
  • AttributeError: module ‘seaborn‘ has no attribute ‘scatterplot‘

    我找到很多博客 说这是因为seaborn的版本不对 我就去升级seaborn了 发现仍然是报这个错误 经过排查 pip list发现里面有个叫做sns的包 版本是0 1 我是import seaborn as sns了 并不清楚这个sns包

随机推荐