热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

c语言中指针p=4,c语言指针用法

本文目录一览:1、c语言中(*p)[4]是什么意思

本文目录一览:


  • 1、c语言中(*p)[4]是什么意思


  • 2、int *p=4;**q; q=&p; 中&p和p分别代表什么?**q怎么理解?


  • 3、C语言 指针 (*p)[4] 是什么意思?怎么用?


  • 4、C语言中 int*p[4] 和 int(*p)[4]的区别


  • 5、C语言数组指针的元素个数怎么定义,为什么是4?

c语言中(*p)[4]是什么意思

int*p[4]是指针的数组,也就是说它是一个数组,数组里存的是一个个的指针

int(*p)[4]是数组的指针,也就是说它是一个指针,指向的是一个数组。指针指向的类型会影响到指针加减运算时地址的位移。比如说有一个数组 int a[4],加上取址运算符 a,这个表达式的类型就是指向数组的指针,可以这样赋值 p = a;。一般用于向函数传递二维数组的时候使用这种类型,这时还有一种更直观的写法

void matrix_sum(int matrix_a[][4], int matrix_b[][4]) {...}

这种写法和

void matrix_sum(int (*matrix_a)[4], int (*matrix_b)[4]) {...}

是等价的。

int *p=4;**q; q=&p; 中&p和p分别代表什么?**q怎么理解?

在C语言中指针变量也是一个变量,它存在于内存之中,跟普通的int变量没有什么区别。

但是指针变量跟int变量的访问方式有一点区别。

当你访问int变量时,是直接取变量所占内存中的值。

而当你使用*p访问指针变量时,是先取p所占内存中的值,把取出的值当作一个地址,然后再取出新地址的值作为最终值。

如下图,假如p是int型的,那值就等于p。假如p是指针型的,值就等于x。

(图画的比较简单)

| |

------------

| |

| x |

| |-|

------------ |

| |---

| p |

| |

------------

| |

int **q;这句话声明了一个指向指针变量的指针变量,见下图,其中q是双重指针变量,p是指针变量,z就是具体数据了。访问过程请自己推一下吧(用上面的方法)。

q=p;其中p表示求出p这个指针变量的在内存中的地址,而q=p就表示把p的地址作为q这个双重指针变量的值。

| |

------------

| |

| z |

| |-|

------------ |

| |---

| p |

| |-|

------------ |

| |---

| q |

| |

------------

| |

我可怜的图啊,为什么把中间的空格都给我删除了?

C语言 指针 (*p)[4] 是什么意思?怎么用?

指向数组的指针,相当于一个二维数组

{

int (*p)[4];

int a[4];

p = a;

a[0] = 1;

printf("%d\n",p[0][0]);

}

C语言中 int*p[4] 和 int(*p)[4]的区别

一、结合性不同:

前者是指针数组,为4个int指针的数组,有4个元素;

后者是数组指针,为一个指针,类型为指向包含4个int类型元素的一维数组的指针。

二、含义不同:

int*p[4]是指针的数组,也就是说它是一个数组,数组里存的是一个个的指针。

int(*p)[4]是数组的指针,也就是说它shu是一个指针,指向的是一个数组。

三、写法不同:

一般用于向函数传递二维数组的时候使用这种类型,这时还有一种更直观的写法:

void matrix_sum(int matrix_a[][4],int matrix_b[][4]) {...}

这种写法和void matrix_sum(int (*matrix_a)[4], int (*matrix_b)[4]) {...}是等价的。

扩展资料:

指针数组:如char *str_B[5] 系统至少会分配5个连续的空间用来存储5个元素,表示str_B是一个5个元素的数组,每个元素是一个指向字符型数据的一个指针。如果定义如下数组:

char a[3][8]={"gain","much","strong"};

char *n[3]={"gain","much","strong"};

他们在内存的存储方式分别如图1所示,可见,系统给数组a分配了

3×8的空间,而给n分配的空间则取决于具体字符串的长度。

此外,系统分配给a的空间是连续的,而给n分配的空间则不一定连续。

参考资料来源;百度百科-指针数组

C语言数组指针的元素个数怎么定义,为什么是4?

int (*p)[4]是将p定义成了数组指针(即指向一维数组的指针)。

既然要指向一维数组,就得知道可以指向的一维数组的大小,[]中就是指定可以指向的一维数组的大小的。

而这里4说明只能用p指向具有4个int元素的一维数组。

当然用p指向列大小为4的二维数组的某一行也是可以的,就像图中一样。

下面给个例子:

int a[4]={1,2,3,4};

int b[2][4]={5,6,7,8,9,10,11,12};

int (*p)[4];

//下面都可以

p=a;

p=b;

p=b+1;


推荐阅读
author-avatar
笨雄不笨
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有