当前位置:  编程技术>c/c++/嵌入式

C语言安全之数组长度与指针实例解析

    来源: 互联网  发布时间:2014-10-25

    本文导语:  1.C语言编码需要保证变长数组的长度参数位于合法范围之内 例如以下代码: void func(size_t s) { int vla[s]; /*...*/ } /*...*/ func(size); /*...*/ 解决方案如下: enum {MAX_ARRAY = 1024}; void func(size_t s) { if(s < MAX_ARRAY && s != 0) { i...

1.C语言编码需要保证变长数组的长度参数位于合法范围之内

例如以下代码:

void func(size_t s) {
 int vla[s];
 /*...*/
}
/*...*/
func(size);
/*...*/

解决方案如下:

enum {MAX_ARRAY = 1024};
void func(size_t s) {
 if(s < MAX_ARRAY && s != 0) {
  int vla[s];
  /*...*/
 } else {
  //错误处理
 }
}
/*...*/
func(size);
/*...*/

2.需要保证复制的目标具有足够的存储空间

参考代码如下所示:

enum {WORKSPACE_SIZE = 256};
void func(const int src[], size_t len) {
 int dest[WORKSPACE_SIZE];
 if(len > WORKSPACE_SIZE) {
  //错误处理
 }
 memcpy(dest, src, sizeof(int) * len);
 /*...*/
}

3.不要把一个指向非数组对象的指针加上或减去一个整数

错误代码如下所示:

struct numbers {
 short num1;
 short num2;
 /*...*/
 short num9;
};
int sum_numbers(const struct numbers *numb) {
 int total = 0;
 const int *numb_ptr;
 for(numb_ptr = &numb->num1; numb_ptr num9; numb_ptr++) {
  total += *(numb_ptr);
 }
 return total;
}
int main(void) {
 struct numbers my_numbers = {1,2,3,4,5,6,7,8,9};
 sum_numbers(&my_numbers);
 return 0;
}

上面的代码试图用指针运算访问结构的元素,这是危险的,因为结构中的字段并不保证在内存中是连续的

解决方案(使用数组)如下:

struct numbers {
 short num1;
 short num2;
 /*...*/
 short num9;
};
int sum_numbers(const short *numb, size_t dim) {
 int total = 0;
 const int *numb_ptr;
 for(numb_ptr = numb; numb_ptr < numb + dim; numb_ptr++) {
  total += *(numb_ptr);
 }
 return total;
}
int main(void) {
 short my_numbers[9] = {1,2,3,4,5,6,7,8,9};
 sum_numbers(my_numbers, sizeof(my_numbers) / sizeof(my_numbers[0]));
 return 0;
}

    
 
 

您可能感兴趣的文章:

  • c语言合并两个已排序数组的示例(c语言数组排序)
  • 如何在VIM中使汇编语言和C语言自动缩进? iis7站长之家
  • C语言构建动态数组完整实例
  • c语言动态数组示例
  • C语言安全编码之数组索引位的合法范围
  • C语言求连续最大子数组和的方法
  • C语言中全局数组和局部数组的问题
  • c语言中用字符串数组显示菜单的解决方法
  • C语言二维数组的处理实例
  • C语言安全编码数组记法的一致性
  • C语言 结构体动态数组内存释放问题
  • C语言数组指针的小例子
  • Linux下C语言怎样从键盘读入一个十六进制字符数组
  • C语言中多维数组的内存分配和释放(malloc与free)的方法
  • 约瑟夫环问题(数组法)c语言实现
  • c语言中数组名a和&a详细介绍
  • 深入理解c语言数组
  • C语言小程序 数组操作示例代码
  • C语言柔性数组实例详解
  • c语言字符数组与字符串的使用详解
  • C语言中有指针,因此C语言可以创建链表,那么Java语言没有指针,那Java是否可以创建链表呢?
  • C语言指针问题?
  • C语言中常量指针与指针常量区别浅析
  • C语言:指针问题求救~
  • C语言的指针类型详细解析
  • 一个c语言指针问题
  • C语言指针学习经验总结浅谈
  • 关于c语言指针的两处小tip分享
  • C语言入门之指针用法教程
  • C语言创建链表错误之通过指针参数申请动态内存实例分析
  • 基于C语言中野指针的深入解析
  •  
    本站(WWW.)旨在分享和传播互联网科技相关的资讯和技术,将尽最大努力为读者提供更好的信息聚合和浏览方式。
    本站(WWW.)站内文章除注明原创外,均为转载、整理或搜集自网络。欢迎任何形式的转载,转载请注明出处。












  • 相关文章推荐
  • 请教如何用c语言在linux下实现检查某一用户密码长度?
  • 各位大虾:请问UNIX环境下C语言函数memcpy拷贝的字符的长度有没有限制,若有,能不能修改,怎么修改?
  • 关于几种 c语言内部数据类型的 字节长度
  • c语言输出字符串中最大对称子串长度的3种解决方案
  • 2013年7月和2013年8月编程语言排行榜
  • 如何在GTK2.0下实现国际化(语言选择根据自己设置的语言,不用系统的语言)
  • 2017 年热门编程语言排行榜出炉,你的语言上榜没?
  • 求助,在linux下,c语言和汇编语言的接口是什么?
  • 苹果OS X和IOS下最新编程语言swift介绍
  • C语言中间语言 CIL
  • c语言判断某一年是否为闰年的各种实现程序代码
  • 最近学JSP,苦于HTML语言和JAVA语言太差,请教推荐几本书,thanks.
  • PHP编程语言介绍及安装测试方法
  • 动态编程语言 LIME编程语言
  • Linux下C语言strstr()查找子字符串位置函数详细介绍(strstr原型、实现及用法)
  • C语言如何改变当前语言环境
  • c语言实现MD5算法完整代码示例
  • 如何在VIM中使汇编语言和C语言自动缩进?
  • 以NetBeans IDE为例介绍如何使用XML中Schema语言
  • 我安装的linux时默认语言选择的是中文,又乱码,怎么可以解决?怎么更改默认语言成英文?
  • c语言基于libpcap实现一个抓包程序过程
  • Redhat9安装时语言只选择了中文,现在还能再增加其它语言的支持吗?如英文
  • HTML超文本标记语言教程及实例
  • 请问哪里有ubuntu 9.0版本的中文语言包和KDE的中文语言包下载,我用Google搜索了很多地方都没有!
  • MD5算法的C语言实现
  • 可不可以这样认为!c语言是一道唯一指向操作系统的语言,精通了它,就了解了操作系统?


  • 站内导航:


    特别声明:169IT网站部分信息来自互联网,如果侵犯您的权利,请及时告知,本站将立即删除!

    ©2012-2021,,E-mail:www_#163.com(请将#改为@)

    浙ICP备11055608号-3