C++ Primer中&、*符号的多重定义与int *p和int* p的区别讲解
&
和*
这样的符号,既能用作表达式里的运算符,也能作为声明的一部分出现,符号的上下文决定了符号的意义:
int i = 42; int &r = i; //&紧随类型名出现,因此是声明的一部分,r是一个引用 int *p; //*紧随类型名出现,因此是声明的一部分,p是一个指针p p = &i; //&出现在表达式中,是一个取地址符 *p = i; //*出现在表达式中,是一个解引用符 int &r2 = *p; //&是声明的一部分,*是一个解引用符
在声明的语句中,&
和*
用于组成复合类型;在表达式中,他们的角色又转变成运算符。在不同场景下出现的虽然
是同一个符号,但是由于含义截然不同,所以我们完全可以把他们当做不同的符号来看待。
根据C++Primer介绍:
对于int* p
(这种写法合法,但是容易造成误导),其基本数据类型是int
,后面的*
其实是声明符。在一组公用的数据类型后面可以使用不同的声明符。例如:
int i =1024, *p = &i, &r = i; //i是一个int类型的数据,p是一个int型的指针,r是一个int型引用。
对于int *p
,其和int* p
的含义一样,都表示int类型的指针变量p。
但是将声明符紧跟着变量名是一种更容易理解的做法。否则可能会出现误导现象:
例如
int* p1, p2;表示含义是p1是一个int型的指针,p2是一个int型变量。而不是p1,p2都是指针变量,它们共用的是基本数据类型部分。
如果写成int *p1,p2;
则和上式表示的含义完全一样,但是更加清晰,不会造成误导。
不过对于以上两种写法的使用,主要看个人的习惯,但是最好不要混用。
总结
以上就是这篇文章的全部内容了,希望本文的内容对大家的学习或者工作具有一定的参考学习价值,谢谢大家对我们的支持。如果你想了解更多相关内容请查看下面相关链接
相关推荐
-
C++基类指针和派生类指针之间的转换方法讲解
函数重载.函数隐藏.函数覆盖 函数重载只会发生在同作用域中(或同一个类中),函数名称相同,但参数类型或参数个数不同. 函数重载不能通过函数的返回类型来区分,因为在函数返回之前我们并不知道函数的返回类型. 函数隐藏和函数覆盖只会发生在基类和派生类之间. 函数隐藏是指派生类中函数与基类中的函数同名,但是这个函数在基类中并没有被定义为虚函数,这种情况就是函数的隐藏. 所谓隐藏是指使用常规的调用方法,派生类对象访问这个函数时,会优先访问派生类中的这个函数,基类中的这个函数对派生类对象来说是隐藏起来的.
-
C++类中变量也可以是引用的代码实例
C++类中变量也可以是引用哈------要用初始化列表来初始化(因为C++引用一旦绑定,就无法更换,有点类似const) #include <iostream> using namespace std; class A { public: int &x; int &y; A(int &tmpX, int &tmpY):x(tmpX), y(tmpY){} }; int main() { int tmpX = 1; int tmpY = 2; A a(tmpX,
-
C++begin和end运算符的返回迭代器的类型如何判断?
begin和end返回的具体类型应该由对象是否是常量进行确定,如果对象是常量,则这两个函数返回const_iterator; 如果对象不是常量,则这个函数返回iterator类型.下面利用一个超级简单的小程序进行验证二者的类型,源代码如下: #include <iostream> #include <vector> using namespace std; int main() { vector<int> ivec; const vector<int> cv
-
c++编写String类代码实例
本文实例为大家分享了c++编写String类的具体代码,供大家参考,具体内容如下 class String { public: String(const char* = nullptr); //普通构造函数 String(const String& other); //拷贝构造函数 ~String(void); //析构函数 String& operator = (const String& other); //赋值函数 private: char* m_data; }; //普通
-
C++与namespace有关的两个编译错误的讲解
某次,在大型的工程代码中,我这样调用: #include <iostream> using namespace std; namespace A { void fun() { printf("aaa\n"); } } namespace B { void fun() { printf("bbb\n"); } } int main() { fun(); return 0; } 编译出错:error: 'fun' was not declared in th
-
C++直接cout指针名的含义?
首先看下面这个代码实例: #include <iostream> using namespace std; int main() { char *str = "this is a test"; cout << "str=" << str << endl; cout << "*str=" << *str << endl; cout << "&a
-
C++中箭头运算符的含义与用法讲解
C++中箭头运算符->,相当于把解引用和成员访问符两个操作符结合在一起,换句话说, p->func()和(*p).func()所表示的意思一样. 例如: class A { public: func(); } class B { A *p = new A(); *p.a(); //或者使用p->a,二者等价,且更加简洁 } 理解就是,->的功能就是提供了一种对象指针更方便的访问对象成员的方法. 运算符 -> 是指向结构体成员运算符,结合方向为自左向右. 举例说明如下: #in
-
C++中rapidjson组装继续简化的方法
rapidjson组装继续简化------人生苦短,我用rapidjson 看最简单的: #include <iostream> #include <stdio.h> #include<unistd.h> #include <sys/types.h> #include <sys/stat.h> #include <fcntl.h> #include<sstream> // 请自己下载开源的rapidjson #includ
-
C++堆和栈的区别与联系讲解
C++中,内存分为5个区:堆.栈.自由存储区.全局/静态存储区和常量存储区. 栈:是由编译器在需要时自动分配,不需要时自动清除的变量存储区.通常存放局部变量.函数参数等. 堆:是由new分配的内存块,由程序员释放(编译器不管),一般一个new与一个delete对应,一个new[]与一个delete[]对应.如果程序员没有释放掉, 资源将由操作系统在程序结束后自动回收. 自由存储区:是由malloc等分配的内存块,和堆十分相似,用free来释放. 全局/静态存储区:全局变量和静态变量
-
strings命令分析浅谈Go和C++编译时的一点小区别
最近查一个bug, 用strings命令分析, 竟然出乎意料地没有结果, 非常纳闷. 最后根据这个线索查出了bug的根本原因. 1. 在C++中, 即使函数在代码层面没有被调用, 也会最终编译到二进制中, 用strings可以分析. #include <iostream> using namespace std; void fun() { printf("hello world\n"); // strings分析有结果 } int main() { return 0;
随机推荐
- Oracle性能究极优化 下
- jQuery EasyUI Accordion可伸缩面板组件使用详解
- JS中利用swiper实现3d翻转幻灯片实例代码
- C#利用ReportViewer生成报表
- dos 创建文件夹 md
- Oracle 查询表信息获取表字段及字段注释
- ASP.NET中URL Routing和IIS上URL Rewriting的区别
- 在aspx页面引用html页的写法
- javascript实用小函数使用介绍
- js简单的表格添加行和删除行操作示例
- yii 2.0中表单小部件的使用方法示例
- php数组函数序列之array_combine() - 数组合并函数使用说明
- js实现的类似QQ的等级的代码
- 十大经典误会
- python检测某个变量是否有定义的方法
- javascript强制弹出新窗口实现代码
- $.getJSON在IE下失效的原因分析及解决方法
- wwjod.dll加载失败,win32.troj.mnless.82432的清除方法
- JAVA/JSP学习系列之四
- 如何对交换机进行初始化配置