C语言指针基础详解

目录
  • 1.1:概述
    • 1.1.1:内存
    • 1.1.2:内存
    • 1.1.3:指针和指针变量
  • 1.2:指针基础知识
    • 1.2.1:指针变量的定义和使用
    • 1.2.2:通过指针间接修改变量的值
    • 1.2.3:指针的大小
    • 1.2.4:空指针与野指针
    • 1.2.4:万能指针
  • 1.3:指针与数组
    • 1.3.1:数组名
    • 1.3.2:指针操作数组
    • 1.3.3:指针的加减运算
  • 1.4:指针基础小结
  • 1.5:总结

1.1:概述

1.1.1:内存

内存含义:

  • 储存器:用来存储程序和数据,辅助CPU进行运算处理的重要组成部分。
  • 内存:内部存储器,暂时存放程序/数据。
  • 外存:外部储存器,长时间保存程序/数据。

1.1.2:内存

内存地址:

  • 可以理解为将内存抽象成一个很大的一维数组。
  • 编码就是将内存的每一个字节分配一个32位或者64位的编号。这个内存编号我们就称为地址

1.1.3:指针和指针变量

  • 内存中每一个字节都有一个编号,我们称之为”地址“。
  • 指针的实质就是内存的”地址“。地址就是指针,指针也就是地址。
  • 指针是地址,而定义的指针变量是存放地址的变量。

1.2:指针基础知识

1.2.1:指针变量的定义和使用

- 指针是一种数据类型,指针变量是一种存放地址编号的变量。

-‘*' 解引用操作符,表示指针所指的内存空间的具体内容。

打印变量的地址:(用%p)

解引用操作符的运用:

int * 代表了指针类型,p是定义的指针类型的变量,将a的地址赋给变量P,这是p中存的是a的地址编号,p就指向了a的空间,*P就表示a空间里的内容,也就是a的值。

1.2.2:通过指针间接修改变量的值

前面我们提到了关于由const修饰的局部变量的修改,不可以通过赋值直接修改,这里我们介绍通过指针间接的修改变量的值。

当直接修改由const修饰的常量时,我们可以看出会发生错误。

这时我们定义一个指针变量间接的修改局部变量的值是可以的!我们用个图来辅助理解:

1.2.3:指针的大小

  • sizeof() 测得是指针变量指向的储存地址的大小。
  • 在32位平台,所有指针地址都是32位(4字节)。
  • 在64位平台,所有指针地址都是64位(8字节)。

1.2.4:空指针与野指针

  • 空指针(NULL):主要用于给指针变量初始化,空指针是指向内存地址编号为0的空间。int * P = NULL;
  • 野指针:对我个人理解而言,对于野指针我理解为指向一个未知的空间,(通俗来讲,就是我虽然知道这块内存的地址编号,但是我并不知道这块内存具体存放的是什么内容)。下面我介绍两野指针常见错误。

①:任意数值赋值给野指针。

②:操作野指针指向的内存区域。

1.2.4:万能指针

这里我们不做详细的介绍,void * 指针可以指向任意变量的内存空间:

特别注意:我们在对万能指针进行操作时,因为系统需要知道具体需要对几个字节的内容进行操作,所以我们需要强转成具体的指针类型。

1.2.5:const修饰的指针变量

const修饰指针变量时,因const的位置不同,修饰的意义也有所不同,如下代码:

对于p1 ,const可以理解为修饰的*p1,也就是修饰的空间的内容,这时这块空间的地址是可以重新赋值的,而内容不可以!

对于p2,const修饰的是指针变量p2,也就是修饰的空间地址,所以这时可以对内容进行辅助,而不可以改变变量的地址!

注:在编写程序时,指针作为函数参数传递,如果对应的内存空间的值不会被修改,可以使用const修饰指针数据类型。

1.3:指针与数组

1.3.1:数组名

敲重点:对一维数组来说,数组名是首元素地址,是一个常量!!,不可以修改,切记切记,对二维数组来说,此时数组名也是首元素地址,只不过此时的首元素不再只是一个元素,而是一个一维数组。

1.3.2:指针操作数组

其实博主觉得,用指针操作数组可读性还是比较差,而且后续面对多维数组,用指针来操作数组比较麻烦,可读性差。无奈博主学艺不精呀。

这里*(arr + i) 与arr[i]的效果一摸一样,这里的知识点涉及到指针的加减运算,见下一小节。

1.3.3:指针的加减运算

(1) 加法运算

指针计算绝对不是简单的整数相加,这里与指针类型有关:

  • 如果是一个整型指针,那么+1的效果就是变化一个int的大小。
  • 如果是一个字符型指针,那么+1的效果就是变化一个char的大小。

此时数组名是首元素1的地址,属于整型指针,+2表示变化2个int的大小,也就是第三个元素的地址。

(2) 减法运算

这里对于指针减一个整数的作用与加法如出一辙,也是与指针类型有关。

这里我们利用一个逆序打印数组来说明指针减法,特别注意 arr与&arr分别+1的区别,arr表示的是首元素地址,&arr表示的是整个数组的地址,arr + 1变化4字节,而&arr + 1 变化的是整个数组大小的字节数(36)。如图:

我们可以看出,打印&arr与arr的地址编号是一样的,但是意义是不一样的。 1.3.4:指针数组

指针数组还是一个数组,数组元素都是指针类型,拿一级指针数组举例:

这里博主提一点自己对一级指针数组的理解,希望对大家有一丢丢帮助,一级指针数组我把它与二级指针、二维数组相对应,这里不做详细解释,后续指针强化我会解释我的理解,这种理解可能按官方说法来说不严谨,但是能帮助我们理解就好。

1.4:指针基础小结

  • int i:定义整型变量
  • int * p:定义一个指向int的指针变量
  • int **p:定义一个二级指针,指向一级指针。
  • int arr[10]:定义一个有10个整型元素的数组。
  • int *arr[10]:定义一个有10个一级指针元素的数组。

1.5:总结

本篇文章就到这里了,希望能够给你带来帮助,也希望您能够多多关注我们的更多内容!

(0)

相关推荐

  • 对C语言中指针的理解与其基础使用实例

    C语言的指针,关键意思在于"指". "指"是什么意思? 其实完全可以理解为指示的意思.比如,有一个物体,我们称之为A.正是这个物体,有了这么个称谓,我们才能够进行脱离这个物体的实体而进行一系列的交流.将一个物体的指示,是对这个物体的抽象.有了这种抽象能力,才有所谓的智慧和文明.所以这就是"指示"这种抽象方法的威力. 退化到C语言的指针,指针是一段数据/指令(在冯诺易曼体系中,二者是相通,在同一空间中的)的指示.这是指示,也就是这段数据/指令的起始

  • C语言中的函数指针基础学习教程

    顾名思义,函数指针就是函数的指针.它是一个指针,指向一个函数.看例子: A) char * (*fun1)(char * p1,char * p2); B) char * *fun2(char * p1,char * p2); C) char * fun3(char * p1,char * p2); 看看上面三个表达式分别是什么意思? C)这很容易,fun3是函数名,p1,p2是参数,其类型为char *型,函数的返回值为char *类型. B) 也很简单,与C)表达式相比,唯一不同的就是函数的

  • C语言指针之必须要掌握的指针基础知识

    目录 一.指针概述 指针的创建 指针的大小 如何使用指针 二级指针 二.野指针 形成野指针的原因 如何规避野指针 三.指针的基本运算 指针± 整数 指针-指针 四.指针和数组 五.指针数组 总结 一.指针概述 指针是个变量,存放内存单元的地址(编号). 指针的创建 在定义指针变量的时候,在变量前面加上' * ',代表这个变量是一个指针,再往前面加上一个类型名,就代表指针的类型,称为XX指针. 指针的初始化: 使用&(取地址操作符)可以获得变量的地址,将其赋值给已经定义好的指针变量,需要它们的类型

  • C语言指针基础知识实例讲解

    对程序进行编译的时候,系统会把变量分配在内存单位中,根据不同的变量类型,分配不同的字节大小.比如int整型变量分配4个字节,char字符型变量分配1个字节等等.被分配在内存的变量,可以通过地址去找到,内存区每一个字节都有一个编号,地址也可以形象的理解成我们生活中的住址,通过住址找到每一个人所在的地方.指针作为一个变量用来存放地址,可以通过指针来改动变量. 上图就是一个简单的定义一个一级指针变量和利用指针改变变量数值的过程.int*表示整型指针,*p表示解引用操作,就是利用指针找到a的地址然后再改

  • C语言指针基础详解

    目录 1.1:概述 1.1.1:内存 1.1.2:内存 1.1.3:指针和指针变量 1.2:指针基础知识 1.2.1:指针变量的定义和使用 1.2.2:通过指针间接修改变量的值 1.2.3:指针的大小 1.2.4:空指针与野指针 1.2.4:万能指针 1.3:指针与数组 1.3.1:数组名 1.3.2:指针操作数组 1.3.3:指针的加减运算 1.4:指针基础小结 1.5:总结 1.1:概述 1.1.1:内存 内存含义: 储存器:用来存储程序和数据,辅助CPU进行运算处理的重要组成部分. 内存:

  • c++ 智能指针基础详解

    简介 在现代 C++ 编程中,标准库包含了智能指针(Smart pointers). 智能指针用来确保程序不会出现内存和资源的泄漏,并且是"异常安全"(exception-safe)的. 智能指针的使用 智能指针定义在头文件 memory 里的命名空间 std 中.它对于资源获取即初始化(RAII, Resource Acquisition Is Initialization) 编程理念至关重要.该理念的目的是保证对象初始化的时候也是资源获取的时候,从而使对象的所有资源在单行代码中创建

  • Go语言指针用法详解

    结合这个例子分析一下 结果: 结合以往C语言的基础,画了一张图来解释为什么会有上面这些值的出现.先查看下Go中的这两个运算符是啥吧. ①对于所有带a的结果 var a int = 1 定义了一个变量a值为1,如下图所示: &a就是这个存放a变量值的地址 *&a 就是指向&a的一个指针,*&a = a = 1 ②所有带b结果 var b *int = &a 类似C语言的 int *b = &a 定一个指向整形变量的指针b,b指向了a的地址 所以: b = &a

  • C语言 指针数组详解及示例代码

    如果一个数组中的所有元素保存的都是指针,那么我们就称它为指针数组.指针数组的定义形式一般为: dataType *arrayName[length]; [ ]的优先级高于*,该定义形式应该理解为: dataType *(arrayName[length]); 括号里面说明arrayName是一个数组,包含了length个元素,括号外面说明每个元素的类型为dataType *. 除了每个元素的数据类型不同,指针数组和普通数组在其他方面都是一样的,下面是一个简单的例子: #include <stdi

  • C++基础教程之指针拷贝详解

    C++基础教程之指针拷贝详解 指针是编程人员的梦魇,对C语言的开发者是如此,对C++的开发者也是如此.特别是在C++中,如果不注意处理类中的指针,非常容易出问题.如果朋友们不相信可以看看下面的代码: class data { int* value; public: data(int num){ if(num > 0) value = (int*)malloc(sizeof(int)* num); } ~data(){ if(value) free(value); } }; void proces

  • C语言编程数据结构基础详解小白篇

    目录 数据结构的基本信息 数据结构 逻辑结构 1,集合结构 2,线性结构 3,树结构 4,图结构或网结构 存储结构 顺序储存结构 链式储存结构 抽象数据类型 介绍 数据结构的基本信息 数据:是客观事物的符号表示,是所有能输入到计算机中并被计算机程序处理的符号的总称.如:字符串,实数整数.... 数据元素:是数据的基本单位,在计算机中通常被作为一个整体进行考虑与处理.如组成通讯录的每一个人的信息,数据元素可以完整的描述一个对象. 数据项:是组成数据元素的,具有独立意义的,不可分割的最小单位(也就是

  • C语言中的指针以及二级指针代码详解

    很多初学者都对C中的指针很迷糊,希望这篇blog能帮助到大家: 1.什么是"指针": 在执行C程序的时候,由于我们的数据是存储在内存中的.所以对于C程序本身来说,如果想找到相应被调用的数据,就要知道存储该数据的内存地址是多少,换言之,C程序通过已知的内存地址到相应的内存位置存储数据. 这里简单说一下内存管理(对于初学者来说.为了避免专业术语引发的理解问题,下面的叙述尽量避免专业定义:),对于现代计算机系统来说,内存空间分为两个区域,一个是"数据区",一个是"

  • C 语言基础----详解C中的运算符

    C语言中又有哪些运算符呢? 如下所示: ※ 算术运算符 ※ 赋值运算符 ※ 关系运算符 ※ 逻辑运算符 ※ 三目运算符 C语言基本算术运算符如下表: 除法运算中注意: 如果相除的两个数都是整数的话,则结果也为整数,小数部分省略,如果两数中有一个为小数,结果则为小数. 取余运算中注意: 该运算只适合用两个整数进行取余运算 运算后的符号取决于被模数的符号,如(-10)%3 = -1;而10%(-3) = 1. 注:C语言中没有乘方这个运算符,也不能用×,÷等算术符号. 赋值运算符 下表列出了 C 语

  • C语言结构体指针引用详解

    目录 指向结构体变量的指针 指向结构体数组的指针 结构体指针,可细分为指向结构体变量的指针和指向结构体数组的指针. 指向结构体变量的指针 前面我们通过"结构体变量名.成员名"的方式引用结构体变量中的成员,除了这种方法之外还可以使用指针. 前面讲过,&student1 表示结构体变量 student1 的首地址,即 student1 第一个项的地址.如果定义一个指针变量 p 指向这个地址的话,p 就可以指向结构体变量 student1 中的任意一个成员. 那么,这个指针变量定义成

  • C++中文件操作基础详解

    目录 文件操作 文件分类 文本文件 写文件 读文件 二进制文件 写文件 读文件 文件操作 意义:利用文件操作可以保存我们程序运行的信息,是持久化技术的体现 文件分类 按文件类型分为: 1.文本文件    -  文件以文本的ASCII码形式存储在计算机中 2.二进制文件 - 文件以文本的二进制形式存储在计算机中 按类分为: ofstream类:写操作 ifstream类: 读操作 fstream类: 读写操作 文本文件 写文件 五个步骤: 1.引入头文件 #include <fstream> 2

随机推荐