48.C语言 指针声明和定义

最后更新于:2020-08-28 22:36:57

一.指针简介

指针和数组是C语言的灵魂,关于数组,前面我们已经介绍完了,在讲解指针之前,需要明白三个概念:内存/内存地址/指针;

1.内存

C语言所有变量都存放在内存中,就好比杯子里的水,水就是变量,杯子就是内存,内存作为容器用来存放变量

2.内存地址

内存地址就好比一个人除了有名字之后外还有身份证,每个人的身份证都是唯一的,内存地址也是唯一的,如何查看内存地址,下面的文章也有有讲解;

3.指针声明

指针也是C语言中变量的一种,其值为一个变量的地址,即内存位置的直接地址。指针变量声明的一般形式为:

/*
type:指针类型,它必须是一个有效的 C 数据类型,例如:int / float / double / char .....
var-name : 指针变量的名称
*/
type *var-name;

注意:不要忘记在指针类型和变量名中间还有一个 * 号,没有这个 * 号,只是定义了一个普通变量,这也是普通变量声明和指针声明的区别之一;

int    *p;    /* 一个整型的指针 */
int     p;    /* 一个整型的变量 */

二.指针类型

指针很灵活,它可以指向任意类型的数据。指针的类型说明了它所指向地址空间的内存,以下是有效的指针声明:

int    *p;    /* 一个整型的指针 */
double *p;    /* 一个 double 型的指针 */
float  *p;    /* 一个浮点型的指针 */
char   *p;    /* 一个字符型的指针 */

注意:不要忘记在指针类型和变量名中间还有一个 * 号,没有这个 * 号,只是定义了一个普通变量,这也是普通变量声明和指针声明的区别之一;

三.声明并初始化一个指针

1.声明指针并直接初始化 – 推荐

int     *p = 10; //声明一个int类型的指针指向变量为10的内存地址
double  *p = 10.55;    //声明一个double类型的指针指向变量为10.55的内存地址
float   *p = 10.0;    //声明一个float类型的指针指向变量为10.0的内存地址
char    *p = "123456";    //声明一个char类型的指针指向变量为"123456"的内存地址

2.先声明指针在初始化 – 不推荐

C语言中,定义局部变量时如果未初始化,则值是随机的;全局变量 、静态变量初始值为0

四.查看指针地址和指针的值

在文章 格式控制符/占位符 中已经介绍了不少占位符,而对于指针的占位符则是用%p或者%x表示,具体使用参考下面例子:

/************************************************************************/
/*@文件名      : 查看指针地址和指针的值.cpp
/*@日  期      : 2020/07/25 21:52
/*@作  者      : 猿说编程
/*@公众号      : 猿说编程
/*@博客        : www.shuopython.com
/*@描述        : C语言教程 - 数组快速法排序实战
/************************************************************************/

#include "stdafx.h"
#include "stdio.h"
#include "stdlib.h"


int main()
{
    int iValue = 10;
    int *pValue = &iValue;

    printf("整形变量iValue值:%d   整形变量iValue内存地址:%p\n", iValue,&iValue);
    printf("整形指针变量pValue值:%d   整形指针变量pValue内存地址:%p\n", *pValue, pValue);
    printf("-------------------------------------------------------\n");

    *pValue = 20;
    printf("整形变量iValue值:%d   整形变量iValue内存地址:%p\n", iValue, &iValue);
    printf("整形指针变量pValue值:%d   整形指针变量pValue内存地址:%p\n", *pValue, pValue);
    printf("-------------------------------------------------------\n");

    iValue = 30;
    printf("整形变量iValue值:%d   整形变量iValue内存地址:%p\n", iValue, &iValue);
    printf("整形指针变量pValue值:%d   整形指针变量pValue内存地址:%p\n", *pValue, pValue);

    system("pause");
    return 0;
}

/*
输出结果:

整形变量iValue值:10   整形变量iValue内存地址:004FF798
整形指针变量pValue值:10   整形指针变量pValue内存地址:004FF798
-------------------------------------------------------
整形变量iValue值:20   整形变量iValue内存地址:004FF798
整形指针变量pValue值:20   整形指针变量pValue内存地址:004FF798
-------------------------------------------------------
整形变量iValue值:30   整形变量iValue内存地址:004FF798
整形指针变量pValue值:30   整形指针变量pValue内存地址:004FF798
请按任意键继续. . .

*/

在上面例子中:声明了一个整形变量iValue,并使用指针pValue执行整形变量iValue,根据输出的信息可以得到结论:两者的内存地址都一样

由于整形变量iValue和指针变量pValue内存地址一样,整形变量iValue的值发生变化后指针pValue也会跟着一起变化,指针pValue的值发生变化后整形变量iValue的值也会跟着一起变化,两者本来就是同一个, 就好比既可以通过名字找到你,也可以通过身份证号码找到你;

五.NULL指针 – 空指针

在变量声明的时候,如果没有确切的地址可以赋值,为指针变量赋一个 NULL 值,赋为 NULL 值的指针被称为空指针

NULL 指针是一个定义在标准库中的值为零的常量。请看下面的程序:

#include <stdio.h>

int main ()
{
   int  *ptr = NULL;

   printf("ptr 的地址是 %p\n", ptr  );

   return 0;
}

//输出:ptr 的地址是 0x0

在大多数的操作系统上,程序不允许访问地址为 0 的内存,因为该内存是操作系统保留的。然而,内存地址 0 有特别重要的意义,它表明该指针不指向一个可访问的内存位置。但按照惯例,如果指针包含空值(零值),则假定它不指向任何东西。

如需检查一个空指针,您可以使用 if 语句,如下所示:

if(ptr)     /* 如果 p 非空,则完成 */
{
    //....
}
if(!ptr)    /* 如果 p 为空,则完成 */
{
    //....
}

六.重点总结

指针作为一个变量,肯定有自己的地址,占位符使用%p 或者%x

int *p = 10;
printf(" p : %p",p);// 输出地址:004FF798

指针作为一个变量,肯定有自己的值,占位符使用%d,取指针的值需要在指针变量前面加上*,否则是取指针的地址,例如:

int *p = 10;
printf(" p : %d",*p);// 输出值: 10
printf(" p : %p",p); // 输出地址:004FF798

指针很灵活,它可以指向任意类型的数据。指针的类型说明了它所指向地址空间的内存


猜你喜欢

1. 三目运算符

2. 逗号表达式

3. NaN(Not a Number)

4. memcpy/strcpy/strcpy_s 区别

5. unicode 和多字节区别

6. 数组定义和使用

7. sizeof和strlen函数区别

8. Debug和_DEBUG区别

9. _WIN32/WIN32/_WIN64/WIN64区别

10. 判断exe可执行程序是32位的还是64位

11. 数组下标越界

12. 数组内存溢出

13. 数组下标越界和内存溢出区别

14. 二维数组行数和列数计算



转载请注明: 猿说编程 » C/C++教程 » 指针声明和定义

赞赏

微信赞赏支付宝赞赏