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