C++中对象的常引用总结_C 语言

直接传递对象名

用对象名做函数参数时,在函数调用时将建立一个新的对象,它是形参对象的拷贝。

================下面给出一个直接传递对象名的例子程序1.1==================

复制代码 代码如下:

#include<iostream>
using namespace std;
class Time
{
 public:
  Time(int,int,int);//构造函数
  void Print();//输出信息函数
  void reset(Time t);//重置函数
 private:
  int year;
  int month;
  int day;  
};
Time::Time(int y,int m,int d)
{
 year=y;
 month=m;
 day=d;
}
void Time::Print()
{
 cout<<year<<"/"<<month<<"/"<<day<<endl;
}
void Time::reset(Time t)
{
 t.year=0;
 t.month=0;
 t.day=0;
}
int main()
{
 Time t1(12,12,12);//定义一个对象并初始化
 t1.Print();//输出t1的数据成员
 t1.reset(t1);//重置t1中的数据成员
 t1.Print();//输出t1中的数据成员
 return 0;
}

运行结果:

从运行结果来看,reset函数并没有起到作用。

实参把值传递给形参,二者分别占不同的存储空间。无论形参是否修改都不会到实参的值。这种形式的虚实结合,要产生实参的拷贝,当对象的规模比较大的时候,则时间开销和空间开销都可能很大。

因此,这种方法虽然可行,但是并不提倡这种用法~

形参为对象的引用
如果形参为对象的引用名,实参为对象名,则在调用函数进行虚实结合时,并不是为形参另外开辟一个存储空间(常称为建立实参的一个拷贝),而是把实参变量的地址传给形参(引用名),这样引用名也指向实参变量。
对于程序1.1而言,我们只需要将reset函数的形参声明为对象的引用即可。

复制代码 代码如下:

#include<iostream>
using namespace std;
class Time
{
 public:
  Time(int,int,int);//构造函数
  void Print();//输出信息函数
  void reset(Time &t);//重置函数 ============对这一行代码进行了修改======================
 private:
  int year;
  int month;
  int day;  
};
Time::Time(int y,int m,int d)
{
 year=y;
 month=m;
 day=d;
}
void Time::Print()
{
 cout<<year<<"/"<<month<<"/"<<day<<endl;
}
void Time::reset(Time &t)//==============对这一行代码进行了修改=================
{
 t.year=0;
 t.month=0;
 t.day=0;
}
int main()
{
 Time t1(12,12,12);
 t1.Print();
 t1.reset(t1);
 t1.Print();
 return 0;
}

运行结果:
形参为对象的常引用
如果我们在声明函数的参数为对象引用的时候,还可以将它声明为const(常引用)

复制代码 代码如下:

void reset(const Time &t);

则在函数中只能使用对象t中的数据成员和成员函数,而不能修改其中的成员函数,也就是不能修改其对应的实参中的数据成员的值。

复制代码 代码如下:

#include<iostream>
using namespace std;
class Time
{
 public:
  Time(int,int,int);//构造函数
  void Print();//输出信息函数
  void reset(const Time &t);//重置函数
 private:
  int year;
  int month;
  int day;  
};
Time::Time(int y,int m,int d)
{
 year=y;
 month=m;
 day=d;
}
void Time::Print()
{
 cout<<year<<"/"<<month<<"/"<<day<<endl;
}
void Time::reset(const Time &t)
{       //既然声明了t是对象的常引用,就不可以修改其数据成员的值,因此,下面的三行代码是错误的。。
 t.year=0;
 t.month=0;
 t.day=0;
}
int main()
{
 Time t1(12,12,12);
 t1.Print();
 t1.reset(t1);
 t1.Print();
 return 0;
}

该程序会报错,因为在函数reset中,企图修改对象t中的数据成员的值

时间: 2024-09-08 10:28:56

C++中对象的常引用总结_C 语言的相关文章

C++中对象的常引用、动态建立和释放相关知识讲解_C 语言

C++对象的常引用 我们知道,一个变量的引用就是变量的别名.实质上,变量名和引用名都指向同一段内存单元. 如果形参为变量的引用名,实参为变量名,则在调用函数进行虚实结合时,并不是为形参另外开辟一个存储空间(常称为建立实参的一个拷贝), 而是把实参变量的地址传给形参(引用名),这样引用名也指向实参变量. [例] 对象的常引用. #include <iostream> using namespace std; class Time { public: Time(int,int,int); int

C++中指向对象的常指针与指向常对象的指针详解_C 语言

指向对象的常指针 将指向对象的指针变量声明为const型,并使之初始化,这样指针值始终保持为其初始值,不能改变. 复制代码 代码如下: Time t1(10,12,15),t2;Time * const ptr1=&t1;ptr1=&t2; 定义指向对象的常指针的一般形式为 类名    *    const    指针变量=对象地址; 注意应该在定义指针变量时使之初始化 指向对象的常指针变量的值不能被改变,即始终指向同一个对象,但可以改变其所指向对象中的数据成员(非const型)的值. 往

详解C++中常量的类型与定义_C 语言

常量是固定值,在程序执行期间不会改变.这些固定的值,又叫做字面量. 常量可以是任何的基本数据类型,可分为整型数字.浮点数字.字符.字符串和布尔值. 常量就像是常规的变量,只不过常量的值在定义后不能进行修改. 整数常量 整数常量可以是十进制.八进制或十六进制的常量.前缀指定基数:0x 或 0X 表示十六进制,0 表示八进制,不带前缀则默认表示十进制. 整数常量也可以带一个后缀,后缀是 U 和 L 的组合,U 表示无符号整数(unsigned),L 表示长整数(long).后缀可以是大写,也可以是小

c++中const的使用详解_C 语言

Const 是C++中常用的类型修饰符,常类型是指使用类型修饰符const说明的类型,常类型的变量或对象的值是不能被更新的. 1.定义常量(1)const修饰变量,以下两种定义形式在本质上是一样的.它的含义是:const修饰的类型为TYPE的变量value是不可变的.  TYPE const ValueName = value;      const TYPE ValueName = value; (2)将const改为外部连接,作用于扩大至全局,编译时会分配内存,并且可以不进行初始化,仅仅作为

实例讲解C++编程中对设计模式中的原型模式的使用_C 语言

原型模式的实现完整代码示例(code):原型模式的实现很简单,这里为了方便初学者的学习和参考,将给出完整的实现代码(所有代码采用 C++实现,并在 VC 6.0 下测试运行). 代码片断 1:Prototype.h //Prototype.h #ifndef _PROTOTYPE_H_ #define _PROTOTYPE_H_ class Prototype{ public: virtual ~Prototype(); virtual Prototype* Clone() const = 0;

c++ const引用与非const引用介绍_C 语言

const引用是指向const对象的引用. 复制代码 代码如下: const int i = 10; const int &ref = i; 可以读取ref,但不能修改.这样做是有意义的,因为i本身就不可修改,当然也不能通过ref来修改了.所以也就有将const变量赋值给非const引用是非法的. 复制代码 代码如下: int &ref1 = i; // error: nonconst reference to a const object 非const引用是指向非const类型变量的引用

c++ 中__declspec 的用法详解_C 语言

c++ 中__declspec 的用法如下,想要了解的继续往下看吧. 语法说明: __declspec ( extended-decl-modifier-seq ) 扩展修饰符: 1:align(#) 用__declspec(align(#))精确控制用户自定数据的对齐方式 ,#是对齐值. e.g __declspec(align(32)) struct Str1{ int a, b, c, d, e; }; 它与#pragma pack()是一对兄弟,前者规定了对齐的最小值,后者规定了对齐的最

简单讲解C语言中宏的定义与使用_C 语言

宏定义是预编译功能的一种, 预编译又称为预处理, 是为编译做的预备工作的阶段.处理#开头的指令, 比如拷贝 #include 包含的文件代码,#define宏定义的替换,条件编译等. 使用宏定义的好处:使用宏定义的好处:可提高程序的通用性和易读性,减少不一致性,减少输入错误和便于修改.例如 π 这个常量,我们有时候会在程序的多个地方使用,如果每次使用都重新定义,一来比较麻烦,二来容易出错,所以我们可以把 π 做成宏定义来使用.   语法说明: (1)宏名一般用大写 (2)使用宏可提高程序的通用性

C语言中static的作用及C语言中使用静态函数有何好处_C 语言

想了解Java中static关键字的作用和用法详细介绍,请点击此处了解详情. 在C语言中,static的字面意思很容易把我们导入歧途,其实它的作用有三条,分别是: 一是隐藏功能,对于static修饰的函数和全局变量而言 二是保持持久性功能,对于static修饰的局部变量而言. 三是因为存放在静态区,全局和局部的static修饰的变量,都默认初始化为0 下面我逐一给大家介绍: (1)先来介绍它的第一条也是最重要的一条:隐藏. 当我们同时编译多个文件时,所有未加static前缀的全局变量和函数都具有