热门标签 | 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;


推荐阅读
  • 本文由编程笔记#小编整理,主要介绍了关于数论相关的知识,包括数论的算法和百度百科的链接。文章还介绍了欧几里得算法、辗转相除法、gcd、lcm和扩展欧几里得算法的使用方法。此外,文章还提到了数论在求解不定方程、模线性方程和乘法逆元方面的应用。摘要长度:184字。 ... [详细]
  • SpringMVC接收请求参数的方式总结
    本文总结了在SpringMVC开发中处理控制器参数的各种方式,包括处理使用@RequestParam注解的参数、MultipartFile类型参数和Simple类型参数的RequestParamMethodArgumentResolver,处理@RequestBody注解的参数的RequestResponseBodyMethodProcessor,以及PathVariableMapMethodArgumentResol等子类。 ... [详细]
  • [大整数乘法] java代码实现
    本文介绍了使用java代码实现大整数乘法的过程,同时也涉及到大整数加法和大整数减法的计算方法。通过分治算法来提高计算效率,并对算法的时间复杂度进行了研究。详细代码实现请参考文章链接。 ... [详细]
  • C语言注释工具及快捷键,删除C语言注释工具的实现思路
    本文介绍了C语言中注释的两种方式以及注释的作用,提供了删除C语言注释的工具实现思路,并分享了C语言中注释的快捷键操作方法。 ... [详细]
  • This article discusses the efficiency of using char str[] and char *str and whether there is any reason to prefer one over the other. It explains the difference between the two and provides an example to illustrate their usage. ... [详细]
  • C语言判断正整数能否被整除的程序
    本文介绍了使用C语言编写的判断正整数能否被整除的程序,包括输入一个三位正整数,判断是否能被3整除且至少包含数字3的方法。同时还介绍了使用qsort函数进行快速排序的算法。 ... [详细]
  • 本文介绍了基于c语言的mcs51单片机定时器计数器的应用教程,包括定时器的设置和计数方法,以及中断函数的使用。同时介绍了定时器应用的举例,包括定时器中断函数的编写和频率值的计算方法。主函数中设置了T0模式和T1计数的初值,并开启了T0和T1的中断,最后启动了CPU中断。 ... [详细]
  • 如何用UE4制作2D游戏文档——计算篇
    篇首语:本文由编程笔记#小编为大家整理,主要介绍了如何用UE4制作2D游戏文档——计算篇相关的知识,希望对你有一定的参考价值。 ... [详细]
  • 本文介绍了P1651题目的描述和要求,以及计算能搭建的塔的最大高度的方法。通过动态规划和状压技术,将问题转化为求解差值的问题,并定义了相应的状态。最终得出了计算最大高度的解法。 ... [详细]
  • 动态规划算法的基本步骤及最长递增子序列问题详解
    本文详细介绍了动态规划算法的基本步骤,包括划分阶段、选择状态、决策和状态转移方程,并以最长递增子序列问题为例进行了详细解析。动态规划算法的有效性依赖于问题本身所具有的最优子结构性质和子问题重叠性质。通过将子问题的解保存在一个表中,在以后尽可能多地利用这些子问题的解,从而提高算法的效率。 ... [详细]
  • 猜字母游戏
    猜字母游戏猜字母游戏——设计数据结构猜字母游戏——设计程序结构猜字母游戏——实现字母生成方法猜字母游戏——实现字母检测方法猜字母游戏——实现主方法1猜字母游戏——设计数据结构1.1 ... [详细]
  • 前景:当UI一个查询条件为多项选择,或录入多个条件的时候,比如查询所有名称里面包含以下动态条件,需要模糊查询里面每一项时比如是这样一个数组条件:newstring[]{兴业银行, ... [详细]
  • 本文讨论了Kotlin中扩展函数的一些惯用用法以及其合理性。作者认为在某些情况下,定义扩展函数没有意义,但官方的编码约定支持这种方式。文章还介绍了在类之外定义扩展函数的具体用法,并讨论了避免使用扩展函数的边缘情况。作者提出了对于扩展函数的合理性的质疑,并给出了自己的反驳。最后,文章强调了在编写Kotlin代码时可以自由地使用扩展函数的重要性。 ... [详细]
  • 如何提高PHP编程技能及推荐高级教程
    本文介绍了如何提高PHP编程技能的方法,推荐了一些高级教程。学习任何一种编程语言都需要长期的坚持和不懈的努力,本文提醒读者要有足够的耐心和时间投入。通过实践操作学习,可以更好地理解和掌握PHP语言的特异性,特别是单引号和双引号的用法。同时,本文也指出了只走马观花看整体而不深入学习的学习方式无法真正掌握这门语言,建议读者要从整体来考虑局部,培养大局观。最后,本文提醒读者完成一个像模像样的网站需要付出更多的努力和实践。 ... [详细]
  • 本文讨论了编写可保护的代码的重要性,包括提高代码的可读性、可调试性和直观性。同时介绍了优化代码的方法,如代码格式化、解释函数和提炼函数等。还提到了一些常见的坏代码味道,如不规范的命名、重复代码、过长的函数和参数列表等。最后,介绍了如何处理数据泥团和进行函数重构,以提高代码质量和可维护性。 ... [详细]
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社区 版权所有