signed 与 unsigned 关键字

#include <stdio.h> 
#include <string.h>

int main(void)
{
	signed char a[1000];
	int i;
	for(i=0;i<1000;i++)
		a[i]= -1 -i;
	
	printf("%d\n", strlen(a)); 

	return 0;
}

上面输出的结果为255;

        for循环内,当i的值为0时, a[0]的值为-1。关键就是-1在内存里面如何存储?

        我们知道在计算机系统中,数值一律用补码来表示(存储),主要原因是,使用补码可以将符号位和其他位统一处理;同时,减法也可按加法来处理。另外,两个用补码表示的数相加时,如果最高位(符号位)有进位,则进位被舍弃。正数的补码与其原码一致;负数的补码:符号位为1,其余位为该数绝对值的原码按位取反,然后整个数加1。

        按照负数补码的规则,可以知道-1的补码为Oxff,-2的补码为Oxfe...当i的值为127时,a[127]的值为-128,而-128是char类型数据能表示的最小的负数。当i继续增加, a[128]的值肯定不能是-129,因为这时候发生了溢出,-129需要9位才能存储下来,而char类型数据只有8位,所以最高位被丢弃。剩下的8位是原来9位补码的低8位的值,即Ox7f。当i继续增加到255的时候,-256的补码的低8位为0;然后当i增加到256时,-257的补码的低8位全为1,即低8位的补码为Oxff,如此又开始一轮新的循环....

       按照上面的分析, a[0]~ a[254]里面的值都不为0,而a[255]的值为0strlen函数是计算字符串长度的,并不包含字符串最后的'\0'。判断一个字符串是否结束的标志就是看是否遇到'\0';如果遇到'\0',则认为本字符串结束。

       分析到这里, strlen(a)的值为255应该完全能理解了。这个问题的关键就是要明白signed char类型表示的值的范围为[-128, 127],超出这个范围的值会产生溢出;另外还要清楚的就是负数的补码怎么表示。弄明白了这两点,这个问题其实就很简单了。
 

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章