标签:数组使用 取值 原来 3.2 register 局部变量 gis printf 补码
数组是指某种数据类型,在内存上按照顺序存储。中括号([ ])是数组的标识,中括号内的数值标识该种数据类型变量的个数,中括号也有取值的作用。
int a[10]={1,2,3,4,5,6,7,8,9,0}; --数组的定义
int *p=&a[1]; --a[1],是取数组a在内存1位置的值,&a[1],是取a[1]的地址
则p[6]等于8 --p[6],是以&a[1]为起始位置,向上取第六位置的值。
只能清零。
可以设定为指定的值。但是,只会置每个字节的低位为指定值。例如:
int a[5] = {1,2,3,4,5};
memset(a,2,sizeof(a));
for(int i=0; i<5; i++){
printf("%d", a[i]); --打印的值为:10000000100000001000000010
}
只用于具有代码块作用域的变量声明中,修饰局部变量。
只能是局部变量,并且是CPU可以接受的类型,不能取址。可以大大提高运算效率。
(1)static修饰全局变量,只初始化一次,防止在其它文件也被使用。
(2)static修饰局部变量,函数执行完,static变量不会释放。
(3)static修饰函数,该函数只能在本文件使用。
声明某变量或者函数可外部调用。
int main(void)
{
unsigned int a = 6;
int b = -20;
char c;
(a+b>6)?(c=1):(c=0);
return 0;
}则c=1,但a+b=-14;如果a为int类型则c=0。
原来有符号数和无符号数进行比较运算时(==,<,>,<=,>=),有符号数隐式转换成了无符号数(即底层的补码不变,但是此数从有符号数变成了无符号数),
比如上面 (a+b)>6这个比较运算,a+b=-14,-14的补码为1111111111110010。此数进行比较运算时,被当成了无符号数,它远远大于6,所以得到上述结果。
因为有符号的原码的真实值不准确,所以出现反码;因为-0这个特殊的值,所以出现的补码。所以,处理器计算的是补码。
标签:数组使用 取值 原来 3.2 register 局部变量 gis printf 补码
原文地址:https://www.cnblogs.com/campus16/p/9425184.html