C#数组和指针怎么理解
这篇文章主要讲解了“C#数组和指针怎么理解”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“C#数组和指针怎么理解”吧!
什么时候C#数组和C#指针相同
所有作为函数参数的数组名总是可以通过编译器转换为指针。在其他所有情况下,数组的声明就是数组,指针的声明就是指针,两者不能混淆。但在语句或表达式中引用时,数组总是可以写成指针的形式,两者可以互换。然而,C#数组和C#指针在编译器处理时是不同的,在运行时的表示形式也是不一样的。对编译器而言,一个数组就是一个地址,一个指针就是一个地址的地址,你应该根据情况做出选择。
为什么会发生混淆
当人们学习编程时,一开始总是把所有的代码都放到一个函数里。随着水平的进步,他们把代码分别放在几个函数中。在水平继续提高后,他们最终学会了如何用几个文件来构造一个程序。
什么时候C#数组和C#指针是相同的?C#语言标准对此作了如下说明:
规则1 表达式中的数组名(与声明不同)被编译器当作一个指向该数组***个元素的指针。
规则2 下标总是与指针的偏移量相同。
规则3 在函数参数的声明中,数组名被编译器当作指向该数组的***个元素的指针。
规则1:“表达式中的数组名”就是指针
规则1和2合在一起理解,就是对数组下标的引用总是可以写成“一个指向数组的起始地址的指针加上偏移量。”(个人认为,表述为“一个指向该数组***个元素的指针加上偏移量”更明确。)
对数组的引用如a[i]在编译时总是被编译器改写成*(a+i)的形式。C#语言标准要求编译器必须具备这个概念性的行为。于是,a[6]和6[a]都是正确的。
编译器自动把下标值的步长调整到数组元素的大小。这就是为什么指针总是有类型限制,每个指针只能指向一种类型的原因,因为编译器需要知道对指针进行解除引用操作时应取几个字节,以及每个下标的步长应取几个字节。
规则2:C#语言把数组下标作为指针的偏移量
事实上,下标范围检测被认为并不值得加入到C#语言中。数组下标是定义在指针的基础上的,所以优化器常常可以把它转换为更有效率的指针表达式,并生成相同的机器指令。C#语言把数组下标改写成指针偏移量的根本原因是指针和偏移量是底层硬件所使用的基本模型。
为什么C#语言把数组形参当作指针
之所以要把传递给函数的数组参数转换为指针是出于效率的考虑,这个理由常常也是对违反软件工程做法的辩解。我们倾向于始终把参数定义为指针,因为这是编译器内部所使用的形式。以上介绍C#数组和C#指针。
感谢各位的阅读,以上就是“C#数组和指针怎么理解”的内容了,经过本文的学习后,相信大家对C#数组和指针怎么理解这一问题有了更深刻的体会,具体使用情况还需要大家实践验证。这里是编程网,小编将为大家推送更多相关知识点的文章,欢迎关注!
免责声明:
① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。
② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341