再回顾const int* p, int const* p,int* const p 的区别

目录

一、const int* p 和 int const* p (常量指针)

const int* p int const* p 两者都是一样,表示的都是p 指向的是内容不能通过指针p 去修改。 注意:这里不表示p 指向的区域不能被修改,如果一个 int * p2 指针也指向同一个区域,可以通过p2 指针修改这个区域的内容。
在这里插入图片描述

1.1 p 指向的内存不能通过指针p 修改

void test_1_func( void )
{
    int buf_1[5] = {1, 2, 3, 4, 5};
    const int *p = buf_1;
    int *p1 = buf_1;

    p[0] = 8;

}

编译上述代码,编译器提示:

main.c: In function ‘test_1_func’:
main.c:10:10: error: assignment of read-only location ‘*p’
   10 |     p[0] = 8;
      |   

1.2 其他指针可以修改p 指向的内存

void test_1_func( void )
{
    int buf_1[5] = {1, 2, 3, 4, 5};
    const int *p = buf_1;
    int *p1 = buf_1;
    int i = 0;

    p1[0] = 8;
    printf( "print buf_1:\n" );
    for ( i = 0; i < sizeof( buf_1 ) / sizeof( buf_1[0] ); i++ )
        printf( "%d,", p[i] );
    printf( "\n" );

}

代码执行结果如下:

第一个元素已经被修改成8。

print buf_1:
8,2,3,4,5,

1.3 指针p 可以重新指向其他地址

void test_2_func( void )
{
    int buf_1[5] = {1, 2, 3, 4, 5};
    int buf_2[5] = {11, 12, 13, 14, 15};
    int i = 0;
    const int *p = buf_1;

    printf( "p pointer to buf_1:\n" );
    for ( i = 0; i < sizeof( buf_1 ) / sizeof( buf_1[0] ); i++ )
        printf( "%d,", p[i] );
    printf( "\n" );

    p = buf_2;
    printf( "p pointer to buf_2:\n" );
    for ( i = 0; i < sizeof( buf_2 ) / sizeof( buf_2[0] ); i++ )
        printf( "%d,", p[i] );
    printf( "\n" );

}

代码执行结果如下:

p pointer to buf_1:
1,2,3,4,5,
p pointer to buf_2:
11,12,13,14,15,

二、int* const p (指针常量)

int* const p const 修饰的是指针p,表示p 只能指向一个地址,并且是在定义p 的时候指向该地址,中途不能指向其他地址。

2.1 p 定义的时候初始化

void test_3_func( void )
{
    int buf_1[5] = {1, 2, 3, 4, 5};
    int *const p = buf_1 ;
    printf( "p pointer to buf_1:\n" );
    for ( int i = 0; i < sizeof( buf_1 ) / sizeof( buf_1[0] ); i++ )
        printf( "%d,", p[i] );
    printf( "\n" );
}

代码编译,运行结果如下:

p pointer to buf_1:
1,2,3,4,5,

2.2 p 定义的时候未初始化

void test_3_func( void )
{
    int buf_1[5] = {1, 2, 3, 4, 5};
    int *const p = NULL;
    p = buf_1;
}

编译结果如下:

main.c: In function ‘test_3_func’:
main.c:43:7: error: assignment of read-only variable ‘p’
   43 |     p = buf_1;
      |    

2.3 可以通过 p 修改指向内存存放的值

void test_3_func( void )
{
    int buf_1[5] = {1, 2, 3, 4, 5};
    int *const p = buf_1;

    p[0] = 6;
    p[1] = 7;

    printf( "p pointer to buf_1:\n" );
    for (int i = 0; i < sizeof( buf_1 ) / sizeof( buf_1[0] ); i++ )
        printf( "%d,", p[i] );
    printf( "\n" );
}

程序运行结果如下:

p pointer to buf_1:
6,7,3,4,5,

三、const int * const p

结合前面的介绍,可以知道:

  • p 指向的内容不能通过p 进行修改
  • p 指针也只能指向一个地址,不能修改
void test_4_func(void)
{
    int buf_1[5] = {1, 2, 3, 4, 5};
    int buf_2[5] = {11, 12, 13, 14, 15};
    const int * const p = buf_1;
    p[0] = 6; //error
    p = buf_2; //error

}

代码编译结果如下:

main.c: In function ‘test_4_func’:
main.c:58:10: error: assignment of read-only location ‘*p’
   58 |     p[0] = 6;
      |          ^
main.c:59:7: error: assignment of read-only variable ‘p’
   59 |     p = buf_2;
      |   
  • 6
    点赞
  • 8
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值