当前位置: 首页 > 编程笔记 >

C语言安全编码之数组索引位的合法范围

缑永年
2023-03-14
本文向大家介绍C语言安全编码之数组索引位的合法范围,包括了C语言安全编码之数组索引位的合法范围的使用技巧和注意事项,需要的朋友参考一下

C语言中的数组索引必须保证位于合法的范围内!

示例代码如下:

enum {TABLESIZE = 100};
int *table = NULL;
int insert_in_table(int pos, int value) {
  if(!table) {
    table = (int *)malloc(sizeof(int) *TABLESIZE);
  }
  if(pos >= TABLESIZE) {
    return -1;
  }
  table[pos] = value;
  return 0;
}

其中:pos为int类型,可能为负数,这会导致在数组所引用的内存边界之外进行写入

解决方案如下:

enum {TABLESIZE = 100};
int *table = NULL;
int insert_in_table(size_t pos, int value) {
  if(!table) {
    table = (int *)malloc(sizeof(int) *TABLESIZE);
  }
  if(pos >= TABLESIZE) {
    return -1;
  }
  table[pos] = value;
  return 0;
}
 类似资料:
  • 本文向大家介绍C语言安全编码数组记法的一致性,包括了C语言安全编码数组记法的一致性的使用技巧和注意事项,需要的朋友参考一下 对C语言程序来说,在同一文件中时,void func(char *a);  和  void func(char a[]); 完全等价 但在函数原型之外,如果一个数组在一个文件中声明为指针,在另一个不同的文件中声明为数组,那么它们是不等价的 示例代码如下: 解决方案如下:

  • 本文向大家介绍C语言安全编码之数值中的sizeof操作符,包括了C语言安全编码之数值中的sizeof操作符的使用技巧和注意事项,需要的朋友参考一下 通常来说获取数组的长度时不要对指针应用sizeof操作符。 现来看看下面这段代码: clear()使用sizeof(array) / sizeof(array[0])这种用法确定这个数组的元素数量,但由于array是一个形参,因此它是指针类型,size

  • 本文向大家介绍C语言安全之数组长度与指针实例解析,包括了C语言安全之数组长度与指针实例解析的使用技巧和注意事项,需要的朋友参考一下 1.C语言编码需要保证变长数组的长度参数位于合法范围之内 例如以下代码: 解决方案如下: 2.需要保证复制的目标具有足够的存储空间 参考代码如下所示: 3.不要把一个指向非数组对象的指针加上或减去一个整数 错误代码如下所示: 上面的代码试图用指针运算访问结构的元素,这

  • 数组是一种内存分配的形式,数组是定义了一个连续的空间,与指针类似。 数组定义方式 类型 数组名[数组大小];//类型为每个空间的大小,我们通过数组名和下标访问数据,数组名指向存储数据的首地址,但是我们不可以改变数组名指向的地址。数组大小只有在定义的时候生效,定义之后不可以被改变。 int a[100]; //申请了一个名叫a的数组,它包含了100个整型。 数组的访问 我们可以通过数组的下标访问数

  • 本文向大家介绍Mysql之组合索引方法详解,包括了Mysql之组合索引方法详解的使用技巧和注意事项,需要的朋友参考一下 对于任何DBMS,索引都是进行优化的最主要的因素。对于少量的数据,没有合适的索引影响不是很大,但是,当随着数据量的增加,性能会急剧下降。  如果对多列进行索引(组合索引),列的顺序非常重要,MySQL仅能对索引最左边的前缀进行有效的查找。例如:  假设存在组合索引(c1,c2),

  • 老师们好 下面的代码,我怎么想也没有想明白会返回-1 0|0 = 0, 0|1 =1, 1|1 =1, 1|0 = 1, 怎么会出现-1呢,