1. 获取数组的地址无须 &, 因为数组名本身就是个地址
#include <stdio.h>
int main(void)
{
char c = 'A';
char cs[] = "ABC";
printf("%c, %s\n", c, cs); /* 获取字符及字符数组的内容 */
printf("%p, %p, %p\n", &c, cs, &cs); /* 获取字符及字符数组的地址, cs 与 &cs 没有区别*/
getchar();
return 0;
}
2. 数组元素的地址是连续的:
#include <stdio.h>
int main(void)
{
char cs[] = "ABC";
printf("%p\n%p\n%p\n%p\n", cs, &cs[0], &cs[1], &cs[2]);
getchar();
return 0;
}
3. 数组名所代表的地址就是第一个元素的地址:
#include <stdio.h>
int main(void)
{
char str[] = "ABC";
char *p1 = str;
char *p2 = &str[0];
printf("%p, %p\n", p1, p2);
getchar();
return 0;
}
4. 通过指针访问数组元素:
#include <stdio.h>
int main(void)
{
char str[] = "ABC";
char *p = str;
printf("%c\n", *p);
printf("%c\n", *p+1);
printf("%c\n", *p+2);
printf("\n");
printf("%c\n", *p);
printf("%c\n", *++p);
printf("%c\n", *++p);
getchar();
return 0;
}
5. 通过指针遍历数组:
#include <stdio.h>
int main(void)
{
char str[] = "123456789";
char *p = str;
int i;
for (i = 0; i < sizeof str/sizeof str[0]; i++) {
printf("%c\n", *p);
p++;
}
getchar();
return 0;
}
#include <stdio.h>
int main(void)
{
char str[] = "123456789";
char *p = str;
while (*p != '\0') {
printf("%c\n", *p);
p++;
}
getchar();
return 0;
}
#include <stdio.h>
#include <string.h>
int main(void)
{
char str[] = "123456789";
char *p = str;
int i;
for (i = 0; i < strlen(str); i++) {
printf("%c\n", *(p+i));
}
getchar();
return 0;
}
#include <stdio.h>
int main(void)
{
int nums[] = {111,222,333,444};
int *p = nums;
int i;
for (i = 0; i < sizeof nums / sizeof nums[0]; i++) {
printf("%d\n", *p++);
}
getchar();
return 0;
}
6. 注意: 指针+1 是根据元素大小移动一个位置
#include <stdio.h>
int main(void)
{
int nums[] = {111,222,333,444};
int *p = nums;
int i;
printf("%d\n", *p);
printf("%d\n", *(p+1));
printf("%d\n", *p+1); /* 不是这样; 这是代表取值后再 + 1 */
getchar();
return 0;
}
7. 上面的指针其实都是数组元素的指针, 如何声明真正的数组指针呢?
#include <stdio.h>
int main(void)
{
int nums[4] = {111,222,333,444};
int (*p)[4] = &nums; /* 注意其中的小括号 */
printf("%d\n", (*p)[1]); /* 用起来并不方便 */
printf("%d\n", (*p)[2]);
getchar();
return 0;
}