深入理解C语言指针的奥秘

合集下载

单片机c语言的指针

单片机c语言的指针

单片机c语言的指针
单片机C语言中的指针是一种非常重要的概念,它可以帮助我们更灵活地操作内存和访问硬件资源。

在单片机C语言中,指针和在其他C语言环境中的使用方式基本相同,但是由于单片机资源有限,对指针的使用需要更加小心和精确。

首先,指针在单片机C语言中可以用来访问和操作内存中的数据。

通过指针,我们可以直接操作内存地址,这对于一些对内存要求严格的单片机应用非常重要。

例如,我们可以使用指针来访问外设的寄存器,或者直接操作缓冲区中的数据。

其次,指针还可以用来动态分配内存。

在单片机应用中,内存通常是非常宝贵的资源,因此动态分配内存时需要格外小心。

我们可以使用指针和相关的内存分配函数来动态地分配和释放内存,以满足特定的需求。

此外,指针还可以用来传递参数。

在单片机C语言中,函数的参数传递通常是通过传值或传引用来实现的。

通过传递指针作为参数,我们可以在函数内部直接修改传入参数所指向的内存位置的数值,从而避免在函数返回值时产生额外的开销。

需要注意的是,在单片机C语言中,指针的使用需要格外小心,因为指针操作涉及到对内存的直接访问和修改,一旦出现错误可能
会导致系统崩溃甚至损坏硬件。

因此,在使用指针时,需要格外小
心地检查指针的合法性,避免出现空指针或者越界访问等问题。

总之,单片机C语言中的指针是一种非常重要且灵活的工具,
它可以帮助我们更好地操作内存和访问硬件资源,但是在使用时需
要格外小心,以避免出现意外的错误。

希望以上回答能够帮助你更
好地理解单片机C语言中指针的概念和用法。

c语言指针不能直接赋值的原因

c语言指针不能直接赋值的原因

C语言是一种广泛应用的计算机编程语言,它具有高效的性能和灵活的特性。

在C语言中,指针是一种非常重要的概念,它允许程序员直接访问内存位置区域,可以对变量进行直接的操作和管理。

然而,尽管指针在C语言中具有重要的地位,但是指针本身却不能直接赋值,这一点引发了许多程序员的疑惑和困惑。

本文将探讨C语言指针不能直接赋值的原因,以帮助读者更好地理解和掌握C语言中指针的特性和用法。

一、指针的概念和作用1. 指针是什么?指针是一个存储变量位置区域的变量。

简单来说,指针就是一个存储内存位置区域的变量,它指向内存中的某个位置。

2. 指针的作用指针的主要作用是允许程序直接访问内存位置区域,可以通过指针来操作和管理内存中的数据,从而实现对变量的灵活控制。

二、指针不能直接赋值的原因1. 指针的类型在C语言中,指针是一种特殊的数据类型,它与普通的变量类型不同。

指针的类型表示了它所指向的变量的类型。

由于指针是一个位置区域变量,它只能指向具有相同数据类型的变量。

这就意味着,指针本身是不能直接赋值的,因为指针必须要指向一个特定类型的变量。

2. 内存管理在C语言中,指针的主要作用是用来管理内存。

指针可以指向内存中的某个位置,并通过指针来对该位置的数据进行操作。

然而,如果允许指针直接赋值,就会导致内存管理的混乱和错误。

因为指针的赋值会改变指针所指向的内存位置,这样就会造成内存中数据的混乱,甚至会导致程序崩溃。

3. 安全性考虑C语言是一种强大但危险的语言,它允许程序员对内存进行直接的操作。

指针的赋值是一种直接的内存操作,如果允许指针直接赋值,就会给程序带来潜在的安全隐患。

为了保证程序的稳定性和安全性,C语言设计者禁止了指针的直接赋值。

三、指针赋值的替代方案尽管指针不能直接赋值,但是程序员仍然可以通过其他方式来实现对指针的赋值操作。

下面是一些常用的指针赋值的替代方案:1. 位置区域操作符在C语言中,位置区域操作符可以获取一个变量的位置区域。

c语言指针详细讲解

c语言指针详细讲解

c语言指针详细讲解
C 语言中指针是非常强大的概念,它允许程序直接访问内存中的数据。

指针在 C 语言中最初是被用于解决内存分配问题而提出的,随着 C 语言的发展,指针也变得愈发重要。

指针的本质是一个存储变量地址的变量。

在 C 语言中,指针通常用符号&来表示,例如&x 表示的是 x 变量的地址。

指针变量存储的是一个内存地址,当程序读取指针变量时,它会读取该地址中存储的数据。

C 语言中可以使用指针进行高效的内存操作。

例如,当程序需要对一个数组元素进行修改时,可以直接用指针修改该元素的值,而不必修改数组名本身。

另外,指针还可以用于动态分配内存,这是 C 语言中一个重要的特性。

指针的使用方法比较灵活,但也需要小心使用。

如果不小心处理指针,可能会导致未知的错误。

例如,当指针指向的内存空间被释放后,程序试图访问该内存空间时可能会导致未定义的行为。

因此,在C 语言中,指针的使用需要更加谨慎。

C 语言中指针是一个非常重要和强大的概念,掌握指针的使用方法可以让程序员写出更加高效和安全的代码。

全的C语言指针详解PPT课件

全的C语言指针详解PPT课件

在函数中使用指针参数
03
使用指针参数来访问和修改指针所指向的内容,需要使用“-
>”或“*”运算符。
05
指针的高级应用
指向指针的指针(二级指针)
定义与声明
二级指针是用来存储另一个指 针的地址的指针。在声明时, 需要使用`*`操作符来声明二级
指针。
初始化与使用
通过使用`&`操作符获取一个指 针的地址,并将该地址存储在 二级指针中。然后,可以通过 二级指针来访问和操作原始指
当使用malloc或calloc等函 数动态分配内存后,如果 不再需要该内存,必须使 用free函数释放它。否则, 指针将指向一个无效的内 存地址。
当一个指针在函数中定义 ,但该函数返回后仍然存 在并继续指向无效的内存 地址时,就会产生野指针 。
避免指针越界访问
总结词:指针越界访问是指试图访问数 组之外的内存,这是不安全的,可能会 导致程序崩溃或产生不可预测的结果。
指针与内存分配
通过指针来访问和操作动态分配的内存空间。指针可以 存储动态分配的内存地址,并用于读取和写入该地址中 的数据。
指向结构体的指针
01
定义与声明
指向结构体的指针是指向结构体类型的指针。在声明时,需要使用结
构体类型的名称来声明指向结构体的指针。
02 03
初始化与使用
通过使用`&`操作符获取结构体的地址,并将该地址存储在指向结构 体的指针中。然后,可以通过该指针来访问和操作结构体中的成员变 量。
```
பைடு நூலகம்
指向数组元素的指针
• 指向数组元素的指针是指向数组中某个具体元素的指针。通过将指针指向数组中的某个元素,可以访问该 元素的值。
• 指向数组元素的指针可以通过定义一个指向具体元素的指针来实现。例如,定义一个指向数组中第三个元 素的指针,可以使用以下代码

c语言 指针的指针 用法详解

c语言 指针的指针 用法详解

c语言指针的指针用法详解在C语言中,指针是非常重要的一种数据类型。

而指针的指针是指指向指针变量的指针。

它在C语言中也是非常重要的一种数据类型,经常用于动态内存分配和函数传递参数等方面。

下面,我们来详细介绍一下指针的指针在C语言中的用法。

一、指针的基本概念在C语言中,指针是一个变量,用来表示另一个变量的内存地址。

指针变量可以存储任何数据类型的地址,包括整型、字符型、浮点型等。

使用指针可以实现动态内存分配、函数传递参数等功能。

二、指针的指针的概念指针的指针是指指向指针变量的指针。

它的定义方式如下:```int **p;```其中,p是一个指向指针的指针变量,它可以指向一个指针变量的地址。

三、指针的指针的用法指针的指针在C语言中有很多用途,下面列举几个比较常见的用法。

1.动态内存分配在C语言中,可以使用malloc函数动态分配内存,该函数返回的是一个指向分配内存的首地址的指针。

而在一些情况下,需要动态分配二维数组或者指针数组,这时就需要使用指针的指针了。

例如:```int **p;int i,j;p=(int **)malloc(sizeof(int*)*3);//分配3个指向int类型指针的指针变量for(i=0;i<3;i++){p[i]=(int*)malloc(sizeof(int)*4);//分配4个int类型的变量}for(i=0;i<3;i++){for(j=0;j<4;j++){p[i][j]=i*j;//为p[i][j]赋值}}```上述代码中,先使用malloc函数分配3个指向int类型指针的变量,然后再用循环分别为这3个变量分配4个int类型的变量。

最后,再使用嵌套循环为二维数组赋值。

2.函数传递参数在C语言中,函数可以通过指针传递参数。

指针的指针也可以用于函数传递参数,可以使函数返回多个值。

例如:```void fun(int **p){*p=(int*)malloc(sizeof(int)*4);//为指针p分配4个int类型的变量(*p)[0]=10;(*p)[1]=20;(*p)[2]=30;(*p)[3]=40;}int main(){int *p;fun(&p);//传递p的地址printf("%d %d %d %d\n",p[0],p[1],p[2],p[3]);free(p);//释放内存return 0;}```上述代码中,定义了一个指针类型的函数fun,在函数中通过指针的指针为指针p分配4个int类型的变量,并为这4个变量赋值。

C指针详解(经典,非常详细)

C指针详解(经典,非常详细)

总结课:让你不再害怕指针指针所具有的四个要素:指针的类型,指针所指向的类型,指针指向的内存区,指针自身占据的内存。

0前言:复杂类型说明要了解指针,多多少少会出现一些比较复杂的类型,所以我先介绍一下如何完全理解一个复杂类型,要理解复杂类型其实很简单,一个类型里会出现很多运算符,他们也像普通的表达式一样,有优先级,其优先级和运算优先级一样,所以我总结了一下其原则:从变量名处起,根据运算符优先级结合,一步一步分析.下面让我们先从简单的类型开始慢慢分析吧:int p;//这是一个普通的整型变量int*p;//首先从P处开始,先与*结合,所以说明P是一//个指针,然后再与int结合,说明指针所指向//的内容的类型为int型.所以P是一个返回整//型数据的指针int p[3];//首先从P处开始,先与[]结合,说明P是一个数//组,然后与int结合,说明数组里的元素是整//型的,所以P是一个由整型数据组成的数组int*p[3];//首先从P处开始,先与[]结合,因为其优先级//比*高,所以P是一个数组,然后再与*结合,说明//数组里的元素是指针类型,然后再与int结合,//说明指针所指向的内容的类型是整型的,所以//P是一个由返回整型数据的指针所组成的数组int(*p)[3];//首先从P处开始,先与*结合,说明P是一个指针//然后再与[]结合(与"()"这步可以忽略,只是为//了改变优先级),说明指针所指向的内容是一个//数组,然后再与int 结合,说明数组里的元素是//整型的.所以P 是一个指向由整型数据组成的数//组的指针int**p;//首先从P开始,先与*结合,说是P是一个指针,然//后再与*结合,说明指针所指向的元素是指针,然//后再与int 结合,说明该指针所指向的元素是整//型数据.由于二级指针以及更高级的指针极少用//在复杂的类型中,所以后面更复杂的类型我们就//不考虑多级指针了,最多只考虑一级指针.int p(int);//从P处起,先与()结合,说明P是一个函数,然后进入//()里分析,说明该函数有一个整型变量的参数//然后再与外面的int结合,说明函数的返回值是//一个整型数据int(*p)(int);//从P处开始,先与指针结合,说明P是一个指针,然后与//()结合,说明指针指向的是一个函数,然后再与()里的//int结合,说明函数有一个int型的参数,再与最外层的//int结合,说明函数的返回类型是整型,所以P是一个指//向有一个整型参数且返回类型为整型的函数的指针int*(*p(int))[3];//可以先跳过,不看这个类型,过于复杂//从P开始,先与()结合,说明P是一个函数,然后进//入()里面,与int结合,说明函数有一个整型变量//参数,然后再与外面的*结合,说明函数返回的是//一个指针,,然后到最外面一层,先与[]结合,说明//返回的指针指向的是一个数组,然后再与*结合,说//明数组里的元素是指针,然后再与int结合,说明指//针指向的内容是整型数据.所以P是一个参数为一个//整数据且返回一个指向由整型指针变量组成的数组//的指针变量的函数.说到这里也就差不多了,我们的任务也就这么多,理解了这几个类型,其它的类型对我们来说也是小菜了,不过我们一般不会用太复杂的类型,那样会大大减小程序的可读性,请慎用,这上面的几种类型已经足够我们用了.1、细说指针指针是一个特殊的变量,它里面存储的数值被解释成为内存里的一个地址。

c语言指针教学中的知识点分析与总结

c语言指针教学中的知识点分析与总结

c语言指针教学中的知识点分析与总结c语言指针教学中的知识点分析与总结本文对c语言指针的教学进行了探讨和总结。

要想真正的掌握c 语言的指针,首先必须要对它有全面深刻的认识。

因为它是c语言的基础,只有将指针的知识学好,才能够更好地学习后续的课程。

下面小编给大家介绍一下关于c语言指针的知识。

一、 c语言中指针的定义指针是一种特殊的数据类型,也称为引用类型。

所谓指针就是指向一个地址的变量,例如: int a[10];二、变量指针及指针变量1.1 c语言中的变量。

变量是存储在计算机中的二进制数值,当我们需要使用时,必须创建一个变量并赋予它相应的值,然后将变量的地址传递给外部的一个或多个对象,这样外部对象通过访问内部变量来使用其中存储的信息,而且可以保证外部对象不会越界。

1.2指针变量是变量的一种特殊形式,指针变量在内存中占有一块区域,可以指向一个地址,这个地址的值是这个变量所代表的值,这样方便变量间的传递。

例如: char *a[10];2.1指针操作符2.2指针数组,它的作用和一维数组相同,即具有一维数组的特点,也具有二维数组的特点,三者最明显的区别就是二维数组中元素个数是固定的,而一维数组中元素个数是可变的。

2.3指针的运算规则。

在指针变量的操作中,要遵循以下运算规则:原地址→指针地址。

例如: char * a[10]; 2.4 c语言中的const指针常量是一种特殊的指针常量, const不是一种变量的标准类型,它专门用于指向一个const指针。

2.3指针的运算规则。

在指针变量的操作中,要遵循以下运算规则:原地址→指针地址。

例如: char *a[10];2.4指针的定义与使用:所谓指针就是指向一个地址的变量,例如: int a[10]; 2.4指针的定义与使用: pointer, pointer-pointer,and-and-and。

所以,当我们在一个字符串中出现pointer,pointer-pointer, and-and-and的时候,就表示它指向一个地址。

c语言指针实验总结

c语言指针实验总结

c语言指针实验总结《c语言指针实验总结》在学习C语言的过程中,指针是一个非常重要的概念。

为了更好地掌握指针的用法和理解其工作原理,我进行了一系列的实验。

在这篇总结中,我将分享我在实验中所学到的知识和经验。

首先,我进行了一个基本的指针实验,用于了解指针的定义和初始化。

我定义了一个整型变量,并通过指针将其地址赋给另一个指针变量。

然后,我通过对指针变量进行修改,来改变原始变量的值。

这个实验帮助我深入理解了指针是如何通过引用和修改地址来操作变量的。

接下来,我进行了一个指针数组的实验。

我创建了一个包含多个整型变量的数组,并定义了一个指向数组的指针。

通过对指针进行加减操作,我可以访问数组中的不同元素。

这个实验展示了指针和数组之间的密切关系,并帮助我更好地理解了C语言中数组的原理。

我还进行了一个指针和函数的实验。

我定义了一个带有指针参数的函数,并在主函数中调用了这个函数。

通过传递指针作为参数,我可以实现对变量的直接修改,而不需要通过返回值来传递结果。

这个实验使我意识到使用指针参数可以提高程序的效率和灵活性。

最后,我进行了一个动态内存分配的实验。

我使用malloc函数动态地分配了一块内存,并通过指针进行访问和操作。

通过释放内存,我可以避免内存泄漏问题。

这个实验教会了我如何使用指针来管理内存,确保程序的健壮性和效率。

通过这些实验,我对C语言中的指针有了更深入的理解。

指针在C语言中扮演着重要的角色,掌握了指针的使用技巧和原理,能够提高程序的效率和功能。

我相信通过不断实践和学习,我的指针技能将得到进一步的提升。

c语言中的指针详解

c语言中的指针详解

c语言中的指针详解在C语言中,指针是一种特殊的变量类型,它存储了一个变量的内存地址。

通过指针,我们可以间接访问和修改内存中的数据,这对于一些需要动态分配内存的操作非常有用。

以下是关于C语言指针的一些详细解释:1. 定义指针:使用"*"符号来定义指针变量。

例如,int* ptr; 定义了一个指向整型变量的指针 ptr。

2. 取址操作符(&):取地址操作符(&)用于获取变量的内存地址。

例如,&a 返回变量 a 的地址。

3. 解引用操作符(*):解引用操作符(*)用于访问指针所指向的变量的值。

例如,*ptr 返回指针 ptr 所指向的整型变量的值。

4. 动态内存分配:可以使用相关的库函数(如malloc和calloc)在运行时动态分配内存。

分配的内存可以通过指针来访问和使用,并且在使用完后应该使用free函数将其释放。

5. 空指针:空指针是一个特殊的指针值,表示指针不指向任何有效的内存地址。

可以将指针初始化为NULL来表示空指针。

6. 指针和数组:指针和数组在C语言中有密切的关系。

可以通过指针来访问数组元素,并且可以使用指针进行指针算术运算来遍历数组。

7. 传递指针给函数:可以将指针作为函数参数传递,以便在函数内部修改实际参数的值。

这种传递方式可以避免拷贝大量的数据,提高程序的效率。

8. 指针和字符串:字符串在C语言中实际上是以字符数组的形式表示的。

可以使用指针来访问和操作字符串。

需要注意的是,指针在使用时需要小心,因为不正确的操作可能导致程序崩溃或产生不可预料的结果。

对于初学者来说,理解指针的概念和使用方法可能需要一些时间和练习。

C语言指针详解

C语言指针详解

C语言指针详解1 程序如何运行当我们打开电脑中的任何一个程序运行时,我们的操作系统会将该程序存在硬盘的所有数据装载到内存中,然后有CPU 进行读取内存中的数据并进行计算,并将计算的结果返回给我们的操作系统,然后操作系统将相应的动作交付给相应的硬件来完成。

如:将声音数据交给声卡,最后有音响输出来,将图像交给显卡最后有显示器输出……但是还会有一部分数据会返回给内存,以供程序下面的语句继续使用。

我们都知道内存的容量有很大,如:4G,8G, 16G,有时候我们会打开很多的程序,所有的程序的数据都存放到我们的内存中,那么CPU是如何正确的读取我们的不同程序的数据并加以计算的哪?2 内存的假设设计为了让我们的CPU 可以很好的读取内存中的数据,内存必须做优化设计,于是给内存设定了集合设计,将我们的内存分成很多大小相同的方格(盒子),所有的数据将放入这些小盒子中,将不同的程序的数据放入到不同的小盒子中,这样就出现的模块化的内存,当我执行程序的一个命令时,CPU就会从相应的盒子读数据然后计算,由于我们硬件所能访问或计算的最小单位是字节,所以内存中的这样的一个小盒子的大小就给他规定一个字节。

3 地址和指针一般我们声明一块内存空间的时候,会给他取一个名字,为的是我们在编写程序的时候方便使用空间中存放的值,但是CPU 读数据的时候会忽视这个名字,因为CPU无法理解这样的数据,CPU 只能执行0,1代码,那么CPU是如何知道从什么地方读取数据,又到什么地方地址数据的读取的那,所以必须对内存做2次设计,就是将内存中分成的很多小盒子下面标注一些顺序的序号,例如:从第一个盒子开始,标注1,2,3,4,5,6,7,……每一个数字对应一个盒子,但是真正的内存如中不是使用这些十进制数字的,而是使用16进制整数表示的,如0x16ffee。

这些我们标记的数字就叫做内存中的地址。

由于这些地址和盒子是对应的关系,所以只要知道了地址,就可以得到对应盒子中存放的数据了,形象的说,我们说这个地址指向对应的盒子,在C语言中可以通过地址得到对应盒子的数据是*地址。

如何透彻理解C语言中指针的概念

如何透彻理解C语言中指针的概念

如何透彻理解C语言中指针的概念强大的指针功能是C语言区别于众多高级语言的一个重要特征。

C语言指针的功能强大,使用灵活多变,可以有效地表示复杂的数据结构、动态分配内存、高效地使用数组和字符串、使得调用函数时得到多个返回值。

而它的应用远不限于此。

初学者对于指针的概念总是感到无所适从,有时觉得“自己懂了,为什么编译器就是不懂呢”,常有茫然和无助的感觉。

学好指针的关键在于深入了解内存地址的空间可以理解为一个一维线性空间,内存的编址和寻址方法,以及指针在使用上的一些规定。

事实上,指针就是方便我们对内存地址直接进行操作的,是为程序员服务的,我们只要抓住指针想要帮助我们解决什么问题这个核心,就可以轻松地理解它的工作原理。

什么是指针,指针有什么作用指针就是指向一个特定内存地址的一个变量。

简化了的内存空间模型是按照从0到某一个数(比如1048575=1M-1)的一维线性空间,其中的每一个数对应一个存储单元,即1个字节。

指针有两个属性:指向性和偏移性。

指向性指的是指针一定要有一个确定的指向,偏移性则是体现指针重要应用的方面,即指针可以按程序员的要求向前或向后偏移。

指针的应用往往与数组联系在一起,为了方便说明问题,不妨从数组开始解释指针的偏移。

数组就是许多的变量,它的一个重要特征就是在内存空间中连续地存放,而且是按下标顺序存放。

比如我们定义一个有100个变量的一维整型数组,它一定从内存的某一个存储单元开始按数组下标顺序存放,连续占用100*4=400字节。

当我们定义一个数组时,系统就会自动为它分配一个指针,这个指针指向数组的首地址。

(在本文剩余部分的论述中,不加区分地使用“指向数组的首地址”与“指向数组的第一个元素”这两种说法,事实上这两种说法也是一致的。

)为了让系统了解每一次指针偏移的单位,也为了方便程序员进行指针偏移(让程序员记住一个整形变量占用4字节,一个字符型变量占用1字节……等等是很麻烦的),不用每次去计算要偏移多少个字节,C语言引入了指针的基类型的概念。

C语言指针用法详解

C语言指针用法详解

C语言指针用法详解C语言指针用法详解指针可以说是集C语言精华之所在,一个C语言达人怎么可以不会指针呢。

下面店铺给大家介绍C语言指针用法,欢迎阅读!C语言指针用法详解(1)关于指针与数组的存储a、指针和数组在内存中的存储形式数组p[N]创建时,对应着内存中一个数组空间的分配,其地址和容量在数组生命周期内一般不可改变。

数组名p本身是一个常量,即分配数组空间的地址值,这个值在编译时会替换成一个常数,在运行时没有任何内存空间来存储这个值,它和数组长度一起存在于代码中(应该是符号表中),在链接时已经制定好了;而指针*p创建时,对应内存中这个指针变量的空间分配,至于这个空间内填什么值即这个指针变量的值是多少,要看它在程序中被如何初始化,这也决定了指针指向哪一块内存地址。

b、指针和数组的赋值与初始化根据上文,一般情况下,数组的地址不能修改,内容可以修改;而指针的内容可以修改,指针指向的内容也可以修改,但这之前要为指针初始化。

如:int p[5];p=p+1; 是不允许的而p[0]=1; 是可以的;//int *p;p=p+1; 是允许的p[0]=1; 是不允许的,因为指针没有初始化;//int i;int *p=&i;p[0]=1; 是允许的;对于字符指针还有比较特殊的情况。

如:char * p="abc";p[0]='d'; 是不允许的为什么初始化了的字符指针不能改变其指向的内容呢?这是因为p 指向的是“常量”字符串,字符串"abc"实际是存储在程序的静态存储区的,因此内容不能改变。

这里常量字符串的地址确定在先,将指针指向其在后。

而char p[]="abc";p[0]='d'; 是允许的这是因为,这个初始化实际上是把常量直接赋值给数组,即写到为数组分配的内存空间。

这里数组内存分配在先,赋值在后。

(2)关于一些表达式的含义char *p, **p, ***p;char p[],p[][],p[][][];char *p[],*p[][],**p[],**p[][],*(*p)[],(**p)[],(**p)[][];能清晰地知道以上表达式的含义吗?(知道的去死!)第一组:char *p, **p, ***p;分别为char指针;char*指针,即指向char*类型数据地址的指针;char**指针,即指向char**类型数据的指针;他们都是占4字节空间的指针。

c语言指针的用法和好处

c语言指针的用法和好处

c语言指针的用法和好处C语言是一种面向过程的编程语言,也被广泛应用于系统编程和嵌入式系统开发中。

在C语言中,指针是一种非常重要的数据类型,也是C语言所独有的特性之一。

指针的用法和好处如下所述:1. 内存管理: C语言中没有自动垃圾回收机制,因此必须手动管理内存。

指针可以帮助我们直接访问和操作内存中的数据,包括动态分配和释放内存。

通过动态内存分配,可以在程序运行时根据需要分配内存空间,有效地管理内存资源,提高内存利用率。

2. 实现数据结构和算法: 指针在实现数据结构和算法时发挥了重要作用。

例如,可以使用指针来构建链表、树等复杂的数据结构。

指针的灵活性和高效性使得C语言成为算法和数据结构的理想选择。

3. 函数传递参数: 在C语言中,函数参数的传递是通过值传递方式,即函数的参数是被复制到函数中的局部变量中进行操作。

而使用指针作为函数的参数,则可以实现传引用的效果,能够直接修改指针所指向的数据。

这样可以节省空间和提高效率,同时也方便实现函数的返回多个值的需求。

4. 字符串处理: 字符串在C语言中是以字符数组的形式存储的,而指针可以方便地对字符数组进行处理。

通过指针可以对字符串进行遍历、查找、修改等操作,简化了字符串处理的过程。

指针还可以用于字符串的动态分配和释放,避免了空间浪费和内存泄漏问题。

5. 高效的数组访问: C语言中,数组的名称表示的是首元素的地址,通过指针可以实现对数组元素的高效访问。

通过指针可以直接计算数组元素的地址,避免了通过数组下标访问的开销。

指针还可以与整数进行运算,实现数组的遍历和操作。

6. 数据结构的动态修改: 动态数据结构常常需要在运行时进行修改,而指针的灵活性能够很好地支持这种需求。

例如,可以使用指针在运行时插入、删除和修改链表的节点。

指针还可以实现数据结构的动态扩容和缩容,提高代码的灵活性和可维护性。

7. 提高性能: 指针能够直接访问和操作内存,因此可以提高程序的执行效率。

通过指针可以避免不必要的数据复制和空间的开销,减少函数调用的传参时间。

C语言指针知识点总结

C语言指针知识点总结

C语⾔指针知识点总结1.指针的使⽤和本质分析(1)初学指针使⽤注意事项1)指针⼀定要初始化,否则容易产⽣野指针(后⾯会详细说明);2)指针只保存同类型变量的地址,不同类型指针也不要相互赋值;3)只有当两个指针指向同⼀个数组中的元素时,才能进⾏指针间的运算和⽐较操作;4)指针只能进⾏减法运算,结果为同⼀个数组中所指元素的下表差值。

(2)指针的本质分析①指针是变量,指针*的意义:1)在声明时,*号表⽰所声明的变量为指针。

例如:int n = 1; int* p = &n;这⾥,变量p保存着n的地址,即p<—>&n,*p<—>n2)在使⽤时,*号表⽰取指针所指向变量的地址值。

例如:int m = *p;②如果⼀个函数需要改变实参的值,则需要使⽤指针作为函数参数(传址调⽤),如果函数的参数数据类型很复杂,可使⽤指针代替。

最常见的就是交换变量函数void swap(int* a, int* b)③指针运算符*和操作运算符的优先级相同例如:int m = *p++;等价于:int m= *p; p++;2.指针和数组(1)指针、数组、数组名如果存在⼀个数组 int m[3] = {1,2,3};定义指针变量p,int *p = m(这⾥m的类型为int*,&a[0]==>int*)这⾥,其中,&m为数组的地址,m为数组0元素的地址,两者相等,但意义不同,例如:m+1 = (unsigned int)m + sizeof(*m)&m+1= (unsigned int)(&m) + sizeof(*&m)= (unsigned int)(&m) + sizeof(m)m+1表⽰数组的第1号元素,&m+1指向数组a的下⼀个地址,即数组元素“3”之后的地址。

等价操作:m[i]←→*(m+i)←→*(i+m)←→i[m]←→*(p+i)←→p[i]实例测试如下:1 #include<stdio.h>23int main()4 {5int m[3] = { 1,2,3 };6int *p = m;78 printf(" &m = %p\n", &m);9 printf(" m = %p\n", m);10 printf("\n");1112 printf(" m+1 = %p\n", m + 1);13 printf(" &m[2] = %p\n", &m[2]);14 printf(" &m+1 = %p\n", &m + 1);15 printf("\n");1617 printf(" m[1] = %d\n", m[1]);18 printf(" *(m+1) = %d\n", *(m + 1));19 printf(" *(1+m) = %d\n", *(1 + m));20 printf(" 1[m] = %d\n", 1[m]);21 printf(" *(p+1) = %d\n", *(p + 1));22 printf(" p[1] = %d\n", p[1]);2324return0;25 }输出结果为:(2)数组名注意事项1)数组名跟数组长度⽆关;2)数组名可以看作⼀个常量指针;所以表达式中数组名只能作为右值使⽤;3)在以下情况数组名不能看作常量指针:- 数组名作为sizeof操作符的参数- 数组名作为&运算符的参数(3)指针和⼆维数组⼀维数组的指针类型是 Type*,⼆维数组的类型的指针类型是Type*[n](4)数组指针和指针数组①数组指针1)数组指针是⼀个指针,⽤于指向⼀个对应类型的数组;2)数组指针的定义⽅式如下所⽰:int (*p)[3] = &m;②指针数组1)指针数组是⼀个数组,该数组⾥每⼀个元素为⼀个指针;2)指针数组的定义⽅式如下所⽰:int* p[5];3.指针和函数(1)函数指针函数的本质是⼀段内存中的代码,函数的类型有返回类型和参数列表,函数名就是函数代码的起始地址(函数⼊⼝地址),通过函数名调⽤函数,本质为指定具体地址的跳转执⾏,因此,可定义指针,保存函数⼊⼝地址,如下所⽰:int funcname(int a, int b);int(*p)(int a, int b) = funcname;上式中,函数指针p只能指向类型为int(int,int)的函数(2)函数指针参数对于函数int funcname(int a, int b);普通函数调⽤ int funcname(int, int),只能调⽤函数int func(int, int)函数指针调⽤ intname(*func)(int,int),可以调⽤任意int(int,int)类型的函数,从⽽利⽤相同代码实现不同功能,实例测试如下,假设有两个相同类型的函数func1和func2:1int func1(int a, int b, int c)2 {3return a + b + c;4 }56int func2(int a, int b, int c)7 {8return a - b - c;9 }普通函数调⽤和函数指针调⽤⽅式及结果如下所⽰1 printf("普通函数调⽤\n");2 printf("func1 = %d\n", func1(100, 10, 1));3 printf("func2 = %d\n", func2(100, 10, 1));4 printf("\n");56 printf("函数指针调⽤\n");7int(*p)(int, int, int) = NULL;8 p = func1;9 printf("p = %d\n", p(100, 10, 1));10 p = func2;11 printf("p = %d\n", p(100, 10, 1));12 printf("\n");需要注意的是,数组作为函数参数的时候,会变为函数指针参数,即:int funcname( int m[] )<——>int funcname ( int* m );调⽤函数时,传递的是数组名,即funcname(m);(3)回调函数利⽤函数指针,可以实现⼀种特殊的调⽤机制——回调函数。

指针的详细讲解

指针的详细讲解

指针的详细讲解
指针是C语言中重要的概念,也是很多初学者比较困惑的一部分。

在C语言中,指针是一个特殊的数据类型,它直接或者间接地指向了另一个变量或者数据的地址。

指针的基本定义:指针是一个变量,其值是扮演着另一个变量名也就是地址的变量的地址。

指针与变量之间的区别在于,变量存储的是实际的值,而指针存储的是值的内存地址。

指针的类型:在C语言中,指针有不同的类型,这些类型标识了指针指向的变量的数据类型。

例如,int*是一个整数指针,而char*是一个字符指针。

指针的运算:指针可以进行加、减、前后移动等操作。

例如,指针加上一个整数就会指向另一个地址,指针减去一个整数就会回到前一个地址。

指针的使用:指针的主要作用是通过引用来访问变量或者数据。

通过指针,我们可以传递变量的地址而不是变量本身,这样可以减少内存的使用量并提高程序的效率。

指针的注意事项:在使用指针时,需要特别注意指针的安全性。

不正确的使用指针可能会导致内存泄漏、程序崩溃、数据丢失等问题。

总的来说,指针是C语言中一个非常重要的概念,理解它的基本概念和使用方法,对于C语言的学习和开发都有非常重要的意义。

C语言指针讲解

C语言指针讲解

float a;
int * pointer_1;
pointer_1=&a;
编辑课件
9
在对指针变量赋值时需要注意两点:
⑴ 指针变量中只能存放地址(指针),不要将一个 整数赋给一个指针变量。
例: * pointer_1=100; /* pointer_1是指针 变量,100是整数,不合法 */
(2) 赋给指针变量的变是量地址不能是任意的类型, 而只能是与指针变量的基类型具有相同类型的变 量的
编辑课件
22
可以用一个指针变量指向一个数组元素。
例如:int a[10]; (定义a为包含10个整型数据的数组)
int *p; (定义p为指向整型变量的指针变量)
p=&a[0]; (把a[0]元素的地址赋给指针变量p) 也就是使p指向a数组的第0号元素 。
编辑课件
23
编辑课件
24
10.3.2 指针的运算
编辑课件
29
(3) 用指针变量指向数组元素。
#include <stdio.h> void main() { int a[10];
int *p,i; for(i=0;i<10;i++)
scanf(″%d″,&a[i]); printf(″\n″); for(p=a;p<(a+10);p++)
printf(″%d ″,*p); }
{ void exchange(int *q1, int *q2, int *q3);
int a,b,c,*p1,*p2,*p3;
scanf(″%d,%d,%d″,&a, &b, &c);
p1=&a;p2=&b;p3=&c;
exchange (p1,p2,p3);

C语言结构体中定义函数指针详解

C语言结构体中定义函数指针详解

C语言结构体中定义函数指针详解C语言中的结构体是用户自定义的数据类型,可以用来封装不同类型的数据。

结构体中可以包含各种类型的成员变量,例如整型、浮点型、字符型等,还可以包含指针类型的成员变量。

函数指针是指向函数的指针变量,它存储了函数的地址,可以通过函数指针来调用相应的函数。

函数指针可以作为结构体的成员变量,从而实现对不同函数的调用。

下面将详细介绍C语言结构体中定义函数指针的相关内容。

首先,我们先定义一个结构体类型,并在其中添加一个函数指针类型的成员变量:```typedef structint (*func)(int, int);} FuncStruct;```在上面的代码中,我们使用typedef关键字定义了一个结构体类型FuncStruct,并在其中添加了一个名为func的函数指针类型的成员变量。

接下来,我们可以定义几个函数,并将这些函数赋值给结构体中的成员变量。

例如,我们可以定义两个函数add和subtract,分别实现两个整数的加法和减法操作:```int add(int a, int b)return a + b;int subtract(int a, int b)return a - b;```然后,我们可以创建结构体变量,并将add函数和subtract函数分别赋值给结构体中的成员变量func:```FuncStruct funcStruct;funcStruct.func = add;```现在,我们可以通过结构体中的函数指针来调用add函数,并将结果存储在一个变量中:```int result = funcStruct.func(3, 4);printf("result: %d\n", result); // 输出结果:result: 7```上述代码中,我们通过结构体变量funcStruct中的函数指针func来调用add函数,并传递参数3和4给add函数。

深入解析C语言中函数指针的定义与使用

深入解析C语言中函数指针的定义与使用

深⼊解析C语⾔中函数指针的定义与使⽤1.函数指针的定义函数是由执⾏语句组成的指令序列或者代码,这些代码的有序集合根据其⼤⼩被分配到⼀定的内存空间中,这⼀⽚内存空间的起始地址就成为函数的地址,不同的函数有不同的函数地址,编译器通过函数名来索引函数的⼊⼝地址,为了⽅便操作类型属性相同的函数,c/c++引⼊了函数指针,函数指针就是指向代码⼊⼝地址的指针,是指向函数的指针变量。

因⽽“函数指针”本⾝⾸先应该是指针变量,只不过该指针变量指向函数。

这正如⽤指针变量可指向整形变量、字符型、数组⼀样,这⾥是指向函数。

C在编译时,每⼀个函数都有⼀个⼊⼝地址,该⼊⼝地址就是函数指针所指向的地址。

有了指向函数的指针变量后,可⽤该指针变量调⽤函数,就如同⽤指针变量可引⽤其他类型变量⼀样,在这些概念上是⼀致的。

函数指针有两个⽤途:调⽤函数和做函数的参数。

函数指针的声明⽅法为:数据类型标志符 (指针变量名) (形参列表);“函数类型”说明函数的返回类型,由于“()”的优先级⾼于“*”,所以指针变量名外的括号必不可少,后⾯的“形参列表”表⽰指针变量指向的函数所带的参数列表。

例如: int function(int x,int y); /* 声明⼀个函数 */ int (*f) (int x,int y); /* 声明⼀个函数指针 */ f=function; /* 将function函数的⾸地址赋给指针f */ 赋值时函数function不带括号,也不带参数,由于function代表函数的⾸地址,因此经过赋值以后,指针f就指向函数function(int x,int y);的代码的⾸地址。

2.函数指针使⽤的例⼦ 知道了如何定义⼀个函数指针,但如何来使⽤它呢?先看如下例⼦:#include <stdio.h>#include <string.h>char * fun(char * p1,char * p2){ int i = 0; i = strcmp(p1,p2); if (0 == i) { return p1; } else { return p2; }}int main(){ char * (*pf)(char * p1,char * p2); pf = &fun; (*pf) ("aa","bb"); return 0;} 我们使⽤指针的时候,需要通过钥匙(“*”)来取其指向的内存⾥⾯的值,函数指针使⽤也如此。

C语言指针函数和函数指针详解

C语言指针函数和函数指针详解

C语言指针函数和函数指针详解C语言指针函数和函数指针详解往往,我们一提到指针函数和函数指针的时候,就有很多人弄不懂。

以下是店铺为大家带来的C语言指针函数和函数指针详解,希望能帮助到大家!一、指针函数当一个函数声明其返回值为一个指针时,实际上就是返回一个地址给调用函数,以用于需要指针或地址的表达式中。

格式:类型说明符 * 函数名(参数)当然了,由于返回的是一个地址,所以类型说明符一般都是int。

例如:int *GetDate();int * aaa(int,int);函数返回的是一个地址值,经常使用在返回数组的某一元素地址上。

int * GetDate(int wk,int dy);main(){int wk,dy;do{printf("Enter week(1-5)day(1-7) ");scanf("%d%d",&wk,&dy);}while(wk<1||wk>5||dy<1||dy>7);printf("%d ",*GetDate(wk,dy));}int * GetDate(int wk,int dy){static int calendar[5][7]={{1,2,3,4,5,6,7},{8,9,10,11,12,13,14},{15,16,17,18,19,20,21},{22,23,24,25,26,27,28},{29,30,31,-1}};return &calendar[wk-1][dy-1];}程序应该是很好理解的,子函数返回的是数组某元素的地址。

输出的是这个地址里的值。

二、函数指针指向函数的指针包含了函数的地址,可以通过它来调用函数。

声明格式如下:类型说明符 (*函数名)(参数)其实这里不能称为函数名,应该叫做指针的变量名。

这个特殊的指针指向一个返回整型值的函数。

指针的声明笔削和它指向函数的声明保持一致。

c语言观后感

c语言观后感

c语言观后感《C语言观后感》在接触C语言相关的知识学习和实例观看后,我感触颇多。

最初观看C语言相关内容的时候,就觉得像是打开了一扇通往神秘编程世界的大门。

看到那些代码一个一个字符地排列在屏幕上,我感觉既新奇又有点不知所措。

就像是看到一群有着特殊规则的小符号在等着我去理解它们的秘密。

特别印象深刻的是那些简单的C语言示例,比如输出“Hello, World!”的程序。

这么一个简单的功能,竟然只要通过几行代码就能实现。

当时我就想到,这就是编程的魔力啊,看似复杂无比的计算机操作,通过自己编写代码就能控制。

看到这里我感觉自己仿佛有了一种能够与计算机更深入对话的能力,虽然这种能力还很微弱。

但是随着观看内容的深入,我也遇到了一些难理解的地方。

像是指针这个概念,就像是一个隐藏在代码背后的神秘指针。

看似简单地定义一个指针变量,可是它背后指向内存的原理让我有点晕头转向。

那个场景让我意识到编程并不全是那么直观的,有些概念暗藏玄机,需要花更多的精力去深挖。

再看那些复杂一点的程序例如一些关于数组操作、函数嵌套的代码示例。

他们看起来就像是精密的仪器构造图,每个部分都必须准确无误,稍有差池就可能导致整个程序无法运行。

这让我想起曾经做数学题的时候,如果有一步做错,最后的答案就会南辕北辙。

编程也是如此严谨而且逻辑严密。

看完C语言相关的内容后我明白了,学习C语言不仅仅是掌握一门编程语言那么简单,它更像是一种思维的训练。

是要学会像计算机一样去思考问题,将大的问题分解成各个小的、可解决的部分。

这种思考方式对我来说是一种全新的启发,让我看到解决问题的另一种视角,一种从底层开始构建逻辑、逐步实现目标的方式。

这也让我意识到在现代科技日益发达的今天,很多事情背后都是通过这种严密的编程思维来构建和实现的,无论是我们日常使用的手机应用,还是计算机系统本身。

无论是开发新软件还是理解已有的系统机制,C语言中的编程思维都会在其中起到非常重要的作用。

在C语言中还有许多关于数据类型的定义之类的细枝末节。

  1. 1、下载文档前请自行甄别文档内容的完整性,平台不提供额外的编辑、内容补充、找答案等附加服务。
  2. 2、"仅部分预览"的文档,不可在线预览部分如存在完整性等问题,可反馈申请退款(可完整预览的文档不适用该条件!)。
  3. 3、如文档侵犯您的权益,请联系客服反馈,我们会尽快为您处理(人工客服工作时间:9:00-18:30)。

深入理解C语言指针的奥秘指针是一个特殊的变量,它里面存储的数值被解释成为内存里的一个地址。

要搞清一个指针需要搞清指针的四方面的内容:指针的类型,指针所指向的类型,指针的值或者叫指针所指向的内存区,还有指针本身所占据的内存区。

让我们分别说明。

先声明几个指针放着做例子:例一:(1)int*ptr.(2)char*ptr.(3)int**ptr.(4)int(*ptr)[3].(5)int*(*ptr)[4].如果看不懂后几个例子的话,请参阅我前段时间贴出的文章<<如何理解c和c 的复杂类型声明>>。

指针的类型从语法的角度看,你只要把指针声明语句里的指针名字去掉,剩下的部分就是这个指针的类型。

这是指针本身所具有的类型。

让我们看看例一中各个指针的类型:(1)int*ptr.//指针的类型是int*(2)char*ptr.//指针的类型是char*(3)int**ptr.//指针的类型是int**(4)int(*ptr)[3].//指针的类型是int(*)[3](5)int*(*ptr)[4].//指针的类型是int*(*)[4]怎么样?找出指针的类型的方法是不是很简单?指针所指向的类型当你通过指针来访问指针所指向的内存区时,指针所指向的类型决定了编译器将把那片内存区里的内容当做什么来看待。

从语法上看,你只须把指针声明语句中的指针名字和名字左边的指针声明符*去掉,剩下的就是指针所指向的类型。

例如:(1)int*ptr.//指针所指向的类型是int(2)char*ptr.//指针所指向的的类型是char(3)int**ptr.//指针所指向的的类型是int*(4)int(*ptr)[3].//指针所指向的的类型是int()[3](5)int*(*ptr)[4].//指针所指向的的类型是int*()[4]在指针的算术运算中,指针所指向的类型有很大的作用。

指针的类型(即指针本身的类型)和指针所指向的类型是两个概念。

当你对C 越来越熟悉时,你会发现,把与指针搅和在一起的"类型"这个概念分成"指针的类型"和"指针所指向的类型"两个概念,是精通指针的关键点之一。

我看了不少书,发现有些写得差的书中,就把指针的这两个概念搅在一起了,所以看起书来前后矛盾,越看越糊涂。

指针的值,或者叫指针所指向的内存区或地址指针的值是指针本身存储的数值,这个值将被编译器当作一个地址,而不是一个一般的数值。

在32位程序里,所有类型的指针的值都是一个32位整数,因为32位程序里内存地址全都是32位长。

指针所指向的内存区就是从指针的值所代表的那个内存地址开始,长度为si zeof(指针所指向的类型)的一片内存区。

以后,我们说一个指针的值是XX,就相当于说该指针指向了以XX为首地址的一片内存区域;我们说一个指针指向了某块内存区域,就相当于说该指针的值是这块内存区域的首地址。

指针所指向的内存区和指针所指向的类型是两个完全不同的概念。

在例一中,指针所指向的类型已经有了,但由于指针还未初始化,所以它所指向的内存区是不存在的,或者说是无意义的。

以后,每遇到一个指针,都应该问问:这个指针的类型是什么?指针指的类型是什么?该指针指向了哪里?指针本身所占据的内存区指针本身占了多大的内存?你只要用函数sizeof(指针的类型)测一下就知道了。

在32位平台里,指针本身占据了4个字节的长度。

指针本身占据的内存这个概念在判断一个指针表达式是否是左值时很有用。

指针的算术运算指针可以加上或减去一个整数。

指针的这种运算的意义和通常的数值的加减运算的意义是不一样的。

例如:例二:1、chara[20].2、int*ptr=a.......3、ptr .在上例中,指针ptr的类型是int*,它指向的类型是int,它被初始化为指向整形变量a。

接下来的第3句中,指针ptr被加了1,编译器是这样处理的:它把指针ptr的值加上了sizeof(int),在32位程序中,是被加上了4。

由于地址是用字节做单位的,故ptr所指向的地址由原来的变量a的地址向高地址方向增加了4个字节。

由于char类型的长度是一个字节,所以,原来ptr是指向数组a的第0号单元开始的四个字节,此时指向了数组a中从第4号单元开始的四个字节。

我们可以用一个指针和一个循环来遍历一个数组,看例子:例三:intarray[20].int*ptr=array....//此处略去为整型数组赋值的代码。

...for(i=0.i<20.i ){(*ptr) .ptr ;}这个例子将整型数组中各个单元的值加1。

由于每次循环都将指针ptr加1,所以每次循环都能访问数组的下一个单元。

再看例子:例四:1、chara[20].2、int*ptr=a.......3、ptr =5.在这个例子中,ptr被加上了5,编译器是这样处理的:将指针ptr的值加上5乘sizeof(int),在32位程序中就是加上了5乘4=20。

由于地址的单位是字节,故现在的ptr所指向的地址比起加5后的ptr所指向的地址来说,向高地址方向移动了20个字节。

在这个例子中,没加5前的ptr指向数组a的第0号单元开始的四个字节,加5后,ptr已经指向了数组a的合法范围之外了。

虽然这种情况在应用上会出问题,但在语法上却是可以的。

这也体现出了指针的灵活性。

如果上例中,ptr是被减去5,那么处理过程大同小异,只不过ptr的值是被减去5乘sizeof(int),新的ptr指向的地址将比原来的ptr所指向的地址向低地址方向移动了20个字节。

总结一下,一个指针ptrold加上一个整数n后,结果是一个新的指针ptrnew,ptrnew的类型和ptrold的类型相同,ptrnew所指向的类型和ptrold 所指向的类型也相同。

ptrnew的值将比ptrold的值增加了n乘sizeof(ptrold 所指向的类型)个字节。

就是说,ptrnew所指向的内存区将比ptrold所指向的内存区向高地址方向移动了n乘sizeof(ptrold所指向的类型)个字节。

一个指针ptrold减去一个整数n后,结果是一个新的指针ptrnew,ptrnew 的类型和ptrold的类型相同,ptrnew所指向的类型和ptrold所指向的类型也相同。

ptrnew的值将比ptrold的值减少了n乘sizeof(ptrold所指向的类型)个字节,就是说,ptrnew所指向的内存区将比ptrold所指向的内存区向低地址方向移动了n乘sizeof(ptrold所指向的类型)个字节。

运算符&.和*这里&.是取地址运算符,*是...书上叫做"间接运算符"。

&.a的运算结果是一个指针,指针的类型是a的类型加个*,指针所指向的类型是a的类型,指针所指向的地址嘛,那就是a的地址。

*p的运算结果就五花八门了。

总之*p的结果是p所指向的东西,这个东西有这些特点:它的类型是p指向的类型,它所占用的地址是p所指向的地址。

例五:inta=12.intb.int*p.int**ptr.p=&.a.//&.a的结果是一个指针,类型是int*,指向的类型是int,指向的地址是a的地址。

*p=24.//*p的结果,在这里它的类型是int,它所占用的地址是p所指向的地址,显然,*p就是变量a。

ptr=&.p.//&.p的结果是个指针,该指针的类型是p的类型加个*,在这里是int **。

该指针所指向的类型是p的类型,这里是int*。

该指针所指向的地址就是指针p 自己的地址。

*ptr=&.b.//*ptr是个指针,&.b的结果也是个指针,且这两个指针的类型和所指向的类型是一样的,所以用&.b来给*ptr赋值就是毫无问题的了。

**ptr=34.//*ptr的结果是ptr所指向的东西,在这里是一个指针,对这个指针再做一次*运算,结果就是一个int类型的变量。

指针表达式一个表达式的最后结果如果是一个指针,那么这个表达式就叫指针表式。

下面是一些指针表达式的例子:例六:inta,b.intarray[10].int*pa.pa=&.a.//&.a是一个指针表达式。

int**ptr=&.pa.//&.pa也是一个指针表达式。

*ptr=&.b.//*ptr和&.b都是指针表达式。

pa=array.pa .//这也是指针表达式。

例七:char*arr[20].char**parr=arr.//如果把arr看作指针的话,arr也是指针表达式char*str.str=*parr.//*parr是指针表达式str=*(parr 1).//*(parr 1)是指针表达式str=*(parr 2).//*(parr 2)是指针表达式由于指针表达式的结果是一个指针,所以指针表达式也具有指针所具有的四个要素:指针的类型,指针所指向的类型,指针指向的内存区,指针自身占据的内存。

好了,当一个指针表达式的结果指针已经明确地具有了指针自身占据的内存的话,这个指针表达式就是一个左值,否则就不是一个左值。

在例七中,&.a不是一个左值,因为它还没有占据明确的内存。

*ptr是一个左值,因为*ptr这个指针已经占据了内存,其实*ptr就是指针pa,既然pa已经在内存中有了自己的位置,那么*ptr当然也有了自己的位置。

数组和指针的关系如果对声明数组的语句不太明白的话,请参阅我前段时间贴出的文章<<如何理解c和c 的复杂类型声明>>。

数组的数组名其实可以看作一个指针。

看下例:例八:intarray[10]={0,1,2,3,4,5,6,7,8,9},value.......value=array[0].//也可写成:value=*array.value=array[3].//也可写成:value=*(array 3).value=array[4].//也可写成:value=*(array 4).上例中,一般而言数组名array代表数组本身,类型是int[10],但如果把array 看做指针的话,它指向数组的第0个单元,类型是int*,所指向的类型是数组单元的类型即int。

因此*array等于0就一点也不奇怪了。

同理,array 3是一个指向数组第3个单元的指针,所以*(array 3)等于3。

其它依此类推。

例九:char*str[3]={"Hello,thisisasample!","Hi,goodmorning.","Helloworld"}.chars[80];strcpy(s,str[0]).//也可写成strcpy(s,*str).strcpy(s,str[1]).//也可写成strcpy(s,*(str 1)).strcpy(s,str[2]).//也可写成strcpy(s,*(str 2)).上例中,str是一个三单元的数组,该数组的每个单元都是一个指针,这些指针各指向一个字符串。

相关文档
最新文档