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


推荐阅读
  • 2012年9月12日优酷土豆校园招聘笔试题目解析与备考指南
    2012年9月12日,优酷土豆校园招聘笔试题目解析与备考指南。在选择题部分,有一道题目涉及中国人的血型分布情况,具体为A型30%、B型20%、O型40%、AB型10%。若需确保在随机选取的样本中,至少有一人为B型血的概率不低于90%,则需要选取的最少人数是多少?该问题不仅考察了概率统计的基本知识,还要求考生具备一定的逻辑推理能力。 ... [详细]
  • C语言中fprintf函数写入文件出现空白问题及解决方法
    C语言中fprintf函数写入文件出现空白问题及解决方法 ... [详细]
  • 本指南从零开始介绍Scala编程语言的基础知识,重点讲解了Scala解释器REPL(读取-求值-打印-循环)的使用方法。REPL是Scala开发中的重要工具,能够帮助初学者快速理解和实践Scala的基本语法和特性。通过详细的示例和练习,读者将能够熟练掌握Scala的基础概念和编程技巧。 ... [详细]
  • 具备括号和分数功能的高级四则运算计算器
    本研究基于C语言开发了一款支持括号和分数运算的高级四则运算计算器。该计算器通过模拟手算过程,对每个运算符进行优先级标记,并按优先级从高到低依次执行计算。其中,加减运算的优先级最低,为0。此外,该计算器还支持复杂的分数运算,能够处理包含括号的表达式,提高了计算的准确性和灵活性。 ... [详细]
  • 深入理解 Java 控制结构的全面指南 ... [详细]
  • 无论是计算机专业学生还是非计算机专业的学习者,在掌握C语言的过程中可能会遇到诸多挑战,不清楚从何入手。为此,本文系统地梳理了2019年福建省C语言的核心知识点,并结合最新的技术进展进行了详细总结,旨在为初学者提供全面的学习指导。文章不仅涵盖了基础语法和数据结构,还深入探讨了指针、内存管理和算法优化等高级主题,帮助读者快速提升编程能力。 ... [详细]
  • 在编程笔试和面试中,全排列算法因其适中的难度而备受青睐,不仅能够考察应聘者的算法基础,还能测试其对递归和回溯的理解。本文将深入解析全排列算法的实现原理,探讨其应用场景,并提供优化建议,帮助读者更好地掌握这一重要算法。 ... [详细]
  • 本文深入解析了Java面向对象编程的核心概念及其应用,重点探讨了面向对象的三大特性:封装、继承和多态。封装确保了数据的安全性和代码的可维护性;继承支持代码的重用和扩展;多态则增强了程序的灵活性和可扩展性。通过具体示例,文章详细阐述了这些特性在实际开发中的应用和优势。 ... [详细]
  • 手指触控|Android电容屏幕驱动调试指南
    手指触控|Android电容屏幕驱动调试指南 ... [详细]
  • 本文探讨了 Java 中 Pair 类的历史与现状。虽然 Java 标准库中没有内置的 Pair 类,但社区和第三方库提供了多种实现方式,如 Apache Commons 的 Pair 类和 JavaFX 的 javafx.util.Pair 类。这些实现为需要处理成对数据的开发者提供了便利。此外,文章还讨论了为何标准库未包含 Pair 类的原因,以及在现代 Java 开发中使用 Pair 类的最佳实践。 ... [详细]
  • 贪心策略在算法设计中的应用与优化
    贪心算法在算法设计中具有广泛的应用,特别是在解决优化问题时表现出色。本文通过分析经典问题“买卖股票的最佳时机II”,探讨了贪心策略的基本原理及其在实际问题中的应用。通过实例分析,展示了贪心算法如何通过局部最优选择逐步达到全局最优解,并讨论了其在时间和空间复杂度上的优势。此外,还提出了一些优化方法,以提高算法的效率和适用性。 ... [详细]
  • Spring框架的核心组件与架构解析 ... [详细]
  • 第二章:Kafka基础入门与核心概念解析
    本章节主要介绍了Kafka的基本概念及其核心特性。Kafka是一种分布式消息发布和订阅系统,以其卓越的性能和高吞吐量而著称。最初,Kafka被设计用于LinkedIn的活动流和运营数据处理,旨在高效地管理和传输大规模的数据流。这些数据主要包括用户活动记录、系统日志和其他实时信息。通过深入解析Kafka的设计原理和应用场景,读者将能够更好地理解其在现代大数据架构中的重要地位。 ... [详细]
  • 在解决区间相关问题时,我发现自己经常缺乏有效的思维方式,即使是简单的题目也常常需要很长时间才能找到解题思路,而一旦得到提示便能迅速理解。题目要求对一个包含n个元素的数组进行操作,并给出一个参数k,具体任务是…… ... [详细]
  • 题目要求将数字字符串转换为对应的字母组合,例如“111”可以转化为“AAA”、“KA”或“AK”。本文通过深入解析暴力递归方法,详细探讨了这一问题的解法,并结合真实的 Facebook 面试题目,提供了从左至右尝试模型的具体实现和优化策略。 ... [详细]
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社区 版权所有