数组的指针特性

从一道小题下手(该考点曾被腾讯等大公司作为基础笔试题考过),

#include <stdio.h>

int size(char a[10])
{
    return sizeof(a);
}

int main(void)
{
    char a[] = {'C','h','i','n','a','\0'};
    char *p = "China";
    char *q = a;

    printf("sizeof(a)=%d\n", sizeof(a));
    printf("sizeof(p)=%d\n", sizeof(p));
    printf("sizeof(q)=%d\n", sizeof(q));
    printf("size(a)=%d\n", size(a));

    return 0;
}

在32位机的编译环境下,对C语言很熟悉的人一眼就能看出结果为:

sizeof(a)=6
sizeof(p)=4
sizeof(q)=4
size(a)=4

基于本小题,主要考究以下几点:

数组名退化成指针

仅在以下3种情况中,数组不会退化成指针,

  1. 使用sizeof(a)的时候,所以上面sizeof(a)的结果为6字节

  2. 对数组名取地址操作:&a。&a的类型为pointer to array of 6 chars,而对字符串指针取地址结果为pointer to pointer to char.

  3. 使用字符串初始化数组的时候也不会退化。

其它情况都会退化成“指向数组首元素的指针”,比如:

  1. 数组名做函数参数时,a都会退化成&a[0]指针。如上面的size函数和printf函数中的a[]都是这种情况

  2. 二维数组,char s[10][8]数组的首元素(得理解这个首元素,从一维数组的角度看的)是一维数组s[0],因此退化成&s[0]指针

数组定义字符串和指针定义字符串的区别

  1. 使用数字定义的字符串只分配字符串所需的空间(上例中为6个字节),数字名没有单独的存储空间;使用指针定义字符串,除了字符串占用的空间,还要为指针变量分配对应的空间。

  2. 数组退化成指针为“常量指针”,不可更改,而直接指向字符串的指针可修改,如

    char a[10] = "China";
    char *p = "China";
    a++;   // 错误的
    p++;   // 正确的
  • 1
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值