C语言中的指针是什么意思?
9个回答
展开全部
其实与其你在这里问,还不如看一看c语言教科书,上面写的都很详细
以下是谭浩强版的
在计算机中,所有的数据都是存放在存储器中的。一般把存储器中的一个字节称为一个内存单元,不同的数据类型所占用的内存单元数不等,如整型量占2个单元,字符量占1个单元等,在前面已有详细的介绍。为了正确地访问这些内存单元,必须为每个内存单元编上号。根据一个内存单元的编号即可准确地找到该内存单元。内存单元的编号也叫做地址。
既然根据内存单元的编号或地址就可以找到所需的内存单元,所以通常也把这个地址称为指针。
内存单元的指针和内存单元的内容是两个不同的概念。
可以用一个通俗的例子来说明它们之间的关系。我们到银行去存取款时,
银行工作人员将根据我们的帐号去找我们的存款单,
找到之后在存单上写入存款、取款的金额。在这里,帐号就是存单的指针,
存款数是存单的内容。对于一个内存单元来说,单元的地址即为指针,其中存放的数据才是该单元的内容。在C语言中,允许用一个变量来存放指针,这种变量称为指针变量。因此,一个指针变量的值就是某个内存单元的地址或称为某内存单元的指针。
严格地说,一个指针是一个地址,是一个常量。而一个指针变量却可以被赋予不同的指针值,是变量。但常把指针变量简称为指针。为了避免混淆,我们中约定:“指针”是指地址,是常量,“指针变量”是指取值为地址的变量。定义指针的目的是为了通过指针去访问内存单元。
既然指针变量的值是一个地址,那么这个地址不仅可以是变量的地址,也可以是其它数据结构的地址。在一个指针变量中存放一个数组或一个函数的首地址有何意义呢?
因为数组或函数都是连续存放的。通过访问指针变量取得了数组或函数的首地址,也就找到了该数组或函数。这样一来,凡是出现数组,函数的地方都可以用一个指针变量来表示,只要该指针变量中赋予数组或函数的首地址即可。这样做,将会使程序的概念十分清楚,程序本身也精练,高效。在C语言中,一种数据类型或数据结构往往都占有一组连续的内存单元。
用“地址”这个概念并不能很好地描述一种数据类型或数据结构,而“指针”虽然实际上也是一个地址,但它却是一个数据结构的首地址,它是“指向”一个数据结构的,因而概念更为清楚,表示更为明确。
这也是引入“指针”概念的一个重要原因。
以下是谭浩强版的
在计算机中,所有的数据都是存放在存储器中的。一般把存储器中的一个字节称为一个内存单元,不同的数据类型所占用的内存单元数不等,如整型量占2个单元,字符量占1个单元等,在前面已有详细的介绍。为了正确地访问这些内存单元,必须为每个内存单元编上号。根据一个内存单元的编号即可准确地找到该内存单元。内存单元的编号也叫做地址。
既然根据内存单元的编号或地址就可以找到所需的内存单元,所以通常也把这个地址称为指针。
内存单元的指针和内存单元的内容是两个不同的概念。
可以用一个通俗的例子来说明它们之间的关系。我们到银行去存取款时,
银行工作人员将根据我们的帐号去找我们的存款单,
找到之后在存单上写入存款、取款的金额。在这里,帐号就是存单的指针,
存款数是存单的内容。对于一个内存单元来说,单元的地址即为指针,其中存放的数据才是该单元的内容。在C语言中,允许用一个变量来存放指针,这种变量称为指针变量。因此,一个指针变量的值就是某个内存单元的地址或称为某内存单元的指针。
严格地说,一个指针是一个地址,是一个常量。而一个指针变量却可以被赋予不同的指针值,是变量。但常把指针变量简称为指针。为了避免混淆,我们中约定:“指针”是指地址,是常量,“指针变量”是指取值为地址的变量。定义指针的目的是为了通过指针去访问内存单元。
既然指针变量的值是一个地址,那么这个地址不仅可以是变量的地址,也可以是其它数据结构的地址。在一个指针变量中存放一个数组或一个函数的首地址有何意义呢?
因为数组或函数都是连续存放的。通过访问指针变量取得了数组或函数的首地址,也就找到了该数组或函数。这样一来,凡是出现数组,函数的地方都可以用一个指针变量来表示,只要该指针变量中赋予数组或函数的首地址即可。这样做,将会使程序的概念十分清楚,程序本身也精练,高效。在C语言中,一种数据类型或数据结构往往都占有一组连续的内存单元。
用“地址”这个概念并不能很好地描述一种数据类型或数据结构,而“指针”虽然实际上也是一个地址,但它却是一个数据结构的首地址,它是“指向”一个数据结构的,因而概念更为清楚,表示更为明确。
这也是引入“指针”概念的一个重要原因。
展开全部
首先,
要明白指针是一种变量类型
指针里面存有一个地址,
这个地址里面存有数据
因为C语言是一种强类型语言,所有的常量和变量都是分为各种类型的
void
,char,
short
,
int
,
long,
float,
double,
(分为符号,和无符号)
struct,
union
(有部分没列,如long
double,
long
long
,
记住没有bool型)
所以,相应的指针也有类型
指针的类型决定了其运算的方式
如
short
*p;
p+1;
则p所指的地址往后移动
2个字节(ANSI规定
short类型不长于32位)
char
*p;
p+1;
则p所指的地址往后移动1个字节
指针,一般用来干什么呢?
通常,我们写程序,
有一个函数A,
和一个函数B,
当,我们需要对一个数据进行处理,
往往要经过A和B的一系列函数的处理之后,才能得到正确的结果
如果,按照普通的方式赋值,
过程是这样的,
传入x给A,
则将x的内容赋值一份到y,
A对y进行处理,A执行结束,返回y值,或者不返回(丢弃)y值
B对x的处理也是类似的
如果按照指针的方式处理,
过程如下:
将要处理信息的地址告诉A,
A对保存的信息区域进行处理,
将要处理信息的地址告诉B,
B对保存的信息区域进行处理,
可以看到,如果要实现一串处理的过程,
用普通的方式,你必须用复制,传入,处理,返回的模式来解决
而,用指针,
你只需要
通知处理区域,
处理,
的模式来解决
所以,指针在这个方面的灵活度和效率更高,
至于究竟什么情况下用,我看是这样的
当需要传入复杂的数据的时候,
不如传入指针,减少复制时产生的不必要的消耗
当传入简单数据的时候,不使用指针,
因为,
你传入内容虽不需要复制,但是指向此内容的指针变量还是需要被复制一份的。
要明白指针是一种变量类型
指针里面存有一个地址,
这个地址里面存有数据
因为C语言是一种强类型语言,所有的常量和变量都是分为各种类型的
void
,char,
short
,
int
,
long,
float,
double,
(分为符号,和无符号)
struct,
union
(有部分没列,如long
double,
long
long
,
记住没有bool型)
所以,相应的指针也有类型
指针的类型决定了其运算的方式
如
short
*p;
p+1;
则p所指的地址往后移动
2个字节(ANSI规定
short类型不长于32位)
char
*p;
p+1;
则p所指的地址往后移动1个字节
指针,一般用来干什么呢?
通常,我们写程序,
有一个函数A,
和一个函数B,
当,我们需要对一个数据进行处理,
往往要经过A和B的一系列函数的处理之后,才能得到正确的结果
如果,按照普通的方式赋值,
过程是这样的,
传入x给A,
则将x的内容赋值一份到y,
A对y进行处理,A执行结束,返回y值,或者不返回(丢弃)y值
B对x的处理也是类似的
如果按照指针的方式处理,
过程如下:
将要处理信息的地址告诉A,
A对保存的信息区域进行处理,
将要处理信息的地址告诉B,
B对保存的信息区域进行处理,
可以看到,如果要实现一串处理的过程,
用普通的方式,你必须用复制,传入,处理,返回的模式来解决
而,用指针,
你只需要
通知处理区域,
处理,
的模式来解决
所以,指针在这个方面的灵活度和效率更高,
至于究竟什么情况下用,我看是这样的
当需要传入复杂的数据的时候,
不如传入指针,减少复制时产生的不必要的消耗
当传入简单数据的时候,不使用指针,
因为,
你传入内容虽不需要复制,但是指向此内容的指针变量还是需要被复制一份的。
本回答被提问者采纳
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
展开全部
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
展开全部
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
展开全部
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
推荐律师服务:
若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询