C语言安全编码之数组索引位的合法范围
C语言中的数组索引必须保证位于合法的范围内!
示例代码如下:
enum{TABLESIZE=100};
int*table=NULL;
intinsert_in_table(intpos,intvalue){
if(!table){
table=(int*)malloc(sizeof(int)*TABLESIZE);
}
if(pos>=TABLESIZE){
return-1;
}
table[pos]=value;
return0;
}
其中:pos为int类型,可能为负数,这会导致在数组所引用的内存边界之外进行写入
解决方案如下:
enum{TABLESIZE=100};
int*table=NULL;
intinsert_in_table(size_tpos,intvalue){
if(!table){
table=(int*)malloc(sizeof(int)*TABLESIZE);
}
if(pos>=TABLESIZE){
return-1;
}
table[pos]=value;
return0;
}
热门推荐
10 大寿爸爸祝福语简短英文
11 老爸生日暴富祝福语简短
12 喜事作文结尾祝福语简短
13 亲戚红包生日祝福语简短
14 考生大学后祝福语简短
15 老板茶楼开业祝福语简短
16 儿媳买车妈妈祝福语简短
17 送个姐妹生日祝福语简短
18 朋友搞笑蛋糕祝福语简短