有关数组的运算:
首先我们分析一下sizeof()和strlen();
sizeof()功能:计算数据空间的字节数
当数组名单独放进sizeof()里表示整个数组。
strlen()计算字符数组的字符数,以"\0"为结束判断,不计算为'\0'的数组元素。
1.一位数组的计算
#define _CRT_SECURE_NO_WARNINGS 1
#include<stdio.h>
int main()
{
int a[] = {1,2,3,4}; //一位数组
printf("%d\n",sizeof(a)); // 16 a表示整个数组
printf("%d\n",sizeof(a+0)); // 4 a+0 表示数组首元素地址,int型占4个字节
printf("%d\n",sizeof(*a)); // 4 *a 表示数组首元素, 1 int型
printf("%d\n",sizeof(a+1)); // 4 a+1 表示数组第二个元素的地址
printf("%d\n",sizeof(a[1])); // 4 a[1]表示数组的第二个元素
printf("%d\n",sizeof(&a)); // 4 a表示整个数组,&a表示数组的地址(与数组首元素地址相同,但含义不同)
printf("%d\n",sizeof(&a+1)); // 4 同上 &a+1表示数组后的的地址
printf("%d\n",sizeof(&a[0])); // 4 &a[0]表示首元素地址
printf("%d\n",sizeof(&a[0]+1));// 4 &a[0]+1表示第二个元素地址
return 0;
}
2.字符数组的计算:
注释:strlen()会默认()内为一个地址,从此地址开始找字符,直到找到’\0‘,就停止
#define _CRT_SECURE_NO_WARNINGS 1
#include<stdio.h>
#include <string.h>
int main()
{
char arr[] = {'a', 'b', 'c', 'd', 'e', 'f',};
printf("%d\n",sizeof(arr)); // 6 arr 表示整个数组,char型一个字节,6个元素
printf("%d\n",sizeof(arr+0)); // 4 arr+1 表示数组第二个元素的地址
printf("%d\n",sizeof(*arr)); // 1 *arr 表示第一个元素,char型
printf("%d\n",sizeof(arr[1])); // 1 arr[1] 表示第一个元素,char型
printf("%d\n",sizeof(&arr)); // 4 数组地址的地址(与数组首元素地址相同,但含义不同)
printf("%d\n",sizeof(&arr+1)); // 4 数组地址的下一个地址
printf("%d\n",sizeof(&arr[0]+1)); // 4 数组第二个元素的地址
printf("%d\n",strlen(arr)); // X arr表示素组,但strlen需要有'\0'才能停下来
printf("%d\n",strlen(arr+0)); // X arr+1表示数组首地址,同上
// printf("%d\n",strlen(*arr)); // strlen 是从地址开始的地方查找字符,知道找到'\0'
//printf("%d\n",strlen(arr[1]));
printf("%d\n",strlen(&arr)); // X &arr表示数组的地址
printf("%d\n",strlen(&arr+1)); // X &arr表示数组后的地址
printf("%d\n",strlen(&arr[0]+1)); // X &arr[0]+1 数组的第二个元素
return 0;
}
3. 指针型数组:
#define _CRT_SECURE_NO_WARNINGS 1
#include<stdio.h>
#include <string.h>
int main()
{
char *p = "abcdef";
printf("%d\n",sizeof(p)); // 4 p表示数组首元素的地址
printf("%d\n",sizeof(p+1)); // 4 p+1表示数组第二个元素的地址
printf("%d\n",sizeof(*p)); // 1 *p表示数组首元素
printf("%d\n",sizeof(p[0])); // 1 p[0]表示数组首元素
printf("%d\n",sizeof(&p)); // 4 &p表示数组首元素地址的地址
printf("%d\n",sizeof(&p+1)); // 4 &p表示数组首元素地址的下一个地址
printf("%d\n",sizeof(&p[0]+1)); // 4 &p[0]+1表示数组第二个元素地址
printf("%d\n",strlen(p)); // 6 p表示数组首元素地址,从此开始查找到第七个元素碰到了'\0'结束减1
printf("%d\n",strlen(p+1)); // 5 p+1表示数组第二个元素地址,从此处开始查找
//printf("%d\n",strlen(*p)); // *p表示第一个元素。
//printf("%d\n",strlen(p[0])); // p[0]表示第一个元素
//printf("%d\n",strlen(&p)); // &p表示数组首元素地址的地址
// printf("%d\n",strlen(&p+1)); // X &p表示数组首元素地址的下一个地址
printf("%d\n",strlen(&p[0]+1)); // 5 &p[0]+1表示数组第二个元素地址
return 0;
}
4. 二维数组:
#define _CRT_SECURE_NO_WARNINGS 1
#include<stdio.h>
int main()
{
int a[3][4] = {0};
printf("%d\n",sizeof(a)); // 48 a 表示整个数组
printf("%d\n",sizeof(a[0][0])); // 4 a[0][0]表示数组第一个元素
printf("%d\n",sizeof(a[0])); // 16 a[0]表示二维数组的第一行
printf("%d\n",sizeof(a[0]+1)); // 4 a[0]+1表示二维数组的第一行第二个元素的地址
printf("%d\n",sizeof(a+1)); // 4 a+1表示数组第二个元素的地址
printf("%d\n",sizeof(&a[0]+1)); // 4 &a[0]+1表示二维数组的第一行地址第二个元素的地址(&a[0]表示第一行地址)
printf("%d\n",sizeof(*a)); // 16 *a 表示数组的第一行元素
printf("%d\n",sizeof(a[3])); // 16 a[3]表示数组的第三行元素
return 0;
}
结论:数组名代表整个数组只有两种情况:
1. 数组名单独放在sizeof()中.
2. &数组名,这里数组名表示整个数组,而”&数组名“表示整个数组的地址与数组首元素地址值相同但含义不同
例: int arr[10] = {0};
其中:假设:&arr和&arr[0]值上都等于0x00000000
但: &arr+1 = 0x00000028
而&arr[0]+1 = 0x00000004