inta[10];
数组名是常量不能为左值(如:a=5;)
不要认为数组元素a[i]代表数组元素的值,它代表数组元素本身,可作为左值使用。
为指针进行初始化的字符串是只读的
(如:char*p=“hello”;strcpy(p,“world”);这样写是错的)
为数组进行初始化的字符串是可写的
(如:charstr[10]=“hello”;strcpy(str,“world”);这样写是对的)
注意:
一直以为a代表数组的首地址,可以像指针一样进行a++等操作,但是,数组名代表数组首地址,一定是个常量!
所以不能对数组名进行a++或者是a--的操作,因为常量不能被修改。
但如果定义指向数组的指针*p=a;
那么这个指向该数组的指针是可以进行p++或者是p--操作的,指针可以通过这种方式来获取元素。
数组名a除了代表数组的首地址外,它还代表特定的类型,在此例中a代表了int[10]这个类型。
在编译环境内运行prinrf(“%d%d)”,sizeof(a),sizeof(p));得到了404。
得到这个结果的原因就是数组名a代表了它所定义的数组类型int[10],此类型占了10个int型大小的内存,因此是长度是40。
而指针存放的就是某个地址值,不论它指向的是什么类型的地址,都占有固定的4个字节大小。
直接访问——用变量名访问。
间接访问——用地址、指针访问。
间接访问:*(首地址+偏移)偏移=下标值*sizeof(数组元素类型)
?通过数组下标访问数组元素也是间接访问。
a[i]<==>*(a+i*sizeof(数组元素类型))(每次偏移一个数组元素类型大小的字节数)
查看动态数组的大小:
(注意头文件:#include)
int*p=(int*)malloc(sizeof(int)*10);
printf(“%d”,_msize(p));
输出结果是40。
访问静态数组元素最灵活的方法:
inta[]={0,1,2,3,4,5};
inti;
for(i=0;i
{
……
……
}
注意:sizeof(a)/sizeof(a[0])在编译阶段就已经由编译器以常量形式给出,不必担心每次循环都需要计算。
相关推荐: