unsigned无符号数减法问题

今天一个QQ群里有人扔出一段代码:

#include <stdio.h>

float sum_elem(float a[],unsigned length){
  int i;
  float result = 0;

  for(i=0;i<=length-1;i++){
     //printf("test\n");   
     result+=a[i];
}
   return result;
}

int main(){
	float a[1]={0.0};
	printf("%f",sum_elem(a,0));
	return 0;
}

看代码的时候,也觉着应该输出a[0],但是编译通过,运行时发生段错误:Segmentation fault (core dumped)

仔细观察觉着问题应该出现在unsigned length身上,将其修改为int类型,就可以输出期望的a[0]了。

然后去检索了下无符号数的减法问题

参考以下链接:

http://blog.chinaunix.net/uid-23629988-id-2984353.html

http://bbs.csdn.net/topics/300036795

得出结论:无符号数相减的结果仍然是无符号数!

其过程是:先将无符号数转换成有符号数相减,结果再转为无符号数。

所以上面的代码中传递给unsigned length的值为0,减1后,得到一个很大的无符号数。

在for循环中添加一个打印语句,发现打印语句被执行多次后才出现段错误,也说明了上面的结论。