golang 引用和指针的区别
时间:2019-12-27 13:35
包括 C、C++ 在内的一些语言支持指针。其他语言包括 C++、Java、Python、Ruby、Perl 和 PHP 都支持引用。从表面上看,引用和指针非常相似,它们都用来让一个变量提供对另一个变量的访问。 (推荐学习:go)
由于两者都提供了许多相同的功能,所以常常不清楚它们各自的内部机制有什么不同。在本文中,我将说明指针和引用之间的区别。
为什么这很重要
指针是 Go 语言的核心。大多数程序员都是在上面提到的一种语言的基础上学习 Go 的。因此,理解指针和引用之间的区别对于理解 Go 至关重要。
即使你使用过具有指针的语言,Go 对指针的实现也不同于 C 和 C++,因为它保留了引用的一些优秀属性,同时保留了指针的功能。
本文的其余部分旨在广泛地讨论引用的概念,而不是具体的实现。我们将使用 Go 作为指针的参考实现。
有什么不同?
指针变量存储的是另一个变量的地址。
引用变量指向另外一个变量。
为证明我们的观点,用 C++ 举个例子,它同时支持指针和引用。
int i = 3;2int *ptr = &i;3int &ref = i;
第一行定义了变量 i;第 2 行定义了一个指向变量 i 内存地址的指针 ptr;第 3 行定义了一个指向变量 i 的引用 ref。
不仅操作符不同,而且使用的方法也不同。对于指针,必须使用 * 操作符来解引用。对于引用,不需要任何操作符。据了解,你倾向于使用引用的变量。
继续我们的示例,下面两行代码都将把 i 的值更改为13。
ptr = 13; ref = 13;
你可能会问,如果我尝试直接访问变量 ptr 而不使用解引用。这就引出了指针和引用之间的第二个关键区别。指针可以重分配,而引用不能。换句话说,指针可以被分配另一个不同的地址。
以上就是golang 引用和指针的区别的详细内容,更多请关注gxlsystem.com其它相关文章!