ZKX's LAB

c 返回对象的引用类型 c++中为什么赋值运算符重载返回类型是引用

2020-07-23知识10

c++中为什么赋值运算符重载返回类型是引用 一、c/c++赋值运算符的本意为“返回左值的引用”(左值:赋值号左面的变量而非其值)例:int a,b=3,c=2;(a=b)=c;cout;对于a=b(a,b均为对象时),若不返回左值的引用,将会生成临时对象。如果不处理a=b=c这样的表达式,也会正常(只是会调用拷贝构造函数和析构函数处理临时对象)。二、为了进行连续赋值,即 x=y=z1、赋值返回引用x=y=z 先执行y=z,返回y的引用,执行x=y2、赋值不返回引用x=y=z 先执行y=z,返回用y初始化的临时对象(注意临时对象都是常对象),再执行x=y的临时对象(要求operator=(const X&)),返回用x初始化的临时对象(此处要求拷贝构造函数必须为X(const X&))。所以也并非必须返回引用,返回引用的好处既可以于赋值的原始语义已知,又可避免拷贝构造函数和析构函数的调用。C#值类型和引用类型的区别 1、分配不同。值类型zhidao分配在线程堆栈上(管理由操作系统负责),引用类型分配在托管堆上(管理由垃圾回收器GC负责)。管理指内存空间的分配和释放:变量本身是存储在堆栈上的(无论是值类型变量还是引用类型变量);但是对于实际数据:引用类型存在托管堆上,值类型存在堆栈。2、继承不同。值类型继承自valueType,valueType继承自System.Object;引用类型直接继承自System.Object。专3、释放方式不同。值类型在作用属域内结束时,会被操作系统自释放,减少托管堆压力;引用类型则靠GC。因此值类型在性能上由优势。4、属性不同。值类型是密封的,不能作为基类。引用类型一般具有继承性.5、null上的不同。值类型不能为null,默认初始化为该类型的默认值;引用类型默认初始化为null。6、参数传递上的不同。值类型作为参数传递时,不影响本身。引用类型作为参数传递时,会改变最终该变量的值。返回引用类型的返回引用的好处如下:(1)传递引用给函数与传递指针的效果是一样的。这时,被调函数的形参就成为原来主调函数中的实参变量或对象的一个别名来使用,所以在被调函数中对形参变量的操作就是对其相应的目标对象(在主调函数中)的操作。(2)使用引用传递函数的参数,在内存中并没有产生实参的副本,它是直接对实参操作;而使用一般变量传递函数的参数,当发生函数调用时,需要给形参分配存储单元,形参变量是实参变量的副本;如果传递的是对象,还将调用拷贝构造函数。因此,当参数传递的数据较大时,用引用比用一般变量传递参数的效率和所占空间都好。(3)使用指针作为函数的参数虽然也能达到与使用引用的效果,但是,在被调函数中同样要给形参分配存储单元,且需要重复使用\"*指针变量名\"的形式进行运算,这很容易产生错误且程序的阅读性较差;另一方面,在主调函数的调用点处,必须用变量的地址作为实参。而引用更容易使用,更清晰。返回引用一般是用在c或者c++等高级语言上。为什么要实现 a=b=c 这种情况时候,重载赋值运算符要返回引用类型呢。不返回引用怎么就不行啊。 因为经改变数据本身的值,只有引用和指针两种方式.而指针需要*,故只能选择引用可以达到此目的.详情到58057516群讨论.共同进步.返回引用类型的将“引用”作为函数返回值类型 格式:类型标识符&函数名(形参列表及类型说明){/函数体 }好处:在内存中不产生被返回值的副本;(注意:正是因为这点原因,所以返回一个局部变量的引用是不可取的。因为随着该局部变量生存期的结束,相应的引用也会失效,产生runtime error。注意事项:(1)不能返回局部变量的引用。这条可以参照Effective C++[1]的Item 31。主要原因是局部变量会在函数返回后被销毁,因此被返回的引用就成为了无所指的引用,程序会进入未知状态。(2)不能返回函数内部new分配的内存的引用。这条可以参照Effective C++[1]的Item 31。虽然不存在局部变量的被动销毁问题,可对于这种情况(返回函数内部new分配内存的引用),又面临其它尴尬局面。例如,被函数返回的引用只是作为一个临时变量出现,而没有被赋予一个实际的变量,那么这个引用所指向的空间(由new分配)就无法释放,造成memory leak。(3)可以返回类成员的引用,但最好是const。这条原则可以参照Effective C++[1]的Item 30。主要原因是当对象的属性是与某种业务规则(business rule)相关联的时候,其赋值常常与某些其它属性或者对象的状态有关,因此有必要将赋值操作封装在一个业务规则当中。如果其它对象可以获得。C#里的引用类型变量是什么意思,能不能通俗一点解释,是不是类似于C语言里面的结构体数组里的变量啊? 引用类型是相对于值类型说的值类型传递时,复制出一个新副本出来引用类型不会复制出新副本,相当于指针,传递的是对象指针,对象的内存首地址,而不是整个对象。我的理解就是,类都是引用类型,结构体和int/uint/byte这些都是值类型int a=10;test(a);值传递 相当于 int b=a;也就是 int b=10;object obj=new object();test2(obj);引用传递void test(int b){}void test2(object obj){} 那些类对象有个方法名叫 Clone 也就是克隆,也就是因为=号只是引用传递,所以无法复制出一份副本出来,所以才需要和弄出了这个克隆函数,才能通过此方法复制出副本出来c++ 类中对象的引用 引用引入了对象的一个同义词。定义引用的表示方法与定义指针相似,只是用&代替了*。引用(reference)是c++对c语言的重要扩充。引用就是某一变量(目标)的一个别名,对引用的操作与对变量直接操作完全一样。引用的声明方法:类型标识符&引用名=目标变量名;引用说明:(1)&在此不是求地址运算,而是起标识作用。(2)类型标识符是指目标变量的类型。(3)声明引用时,必须同时对其进行初始化。(4)引用声明完毕后,相当于目标变量名有两个名称,即该目标原名称和引用名,且不能再把该引用名作为其他变量名的别名。int a=2,int&ra=a;a为目标原名称,ra为目标引用名。给ra赋值:ra=1;等价于 a=1;(5)对引用求地址,就是对目标变量求地址。ra与&a相等。即我们常说引用名是目标变量名的一个别名。别名一词好像是说引用不占据任何内存空间。但是编译器在一般将其实现为const指针,即指向位置不可变的指针。即引用实际上与一般指针同样占用内存。(6)不能建立引用的数组。因为数组是一个由若干个元素所组成的集合,所以无法建立一个由引用组成的集合。但是可以建立数组的引用.例如:int&ref[3]={2,3,5};声明ref引用的数组错误但是可以这样写:const int(&ref)[3]={。c++ 类中对象的引用? 引用引入了对象的一个同义词。定义引用的表示方法与定义指针相似,只是用&代替了*。引用(reference)是c++对c语言的重要扩充。引用就是某一变量(目标)的一个别名,对引用的操作与对变量直接操作完全一样。引用的声明方法:类型标识符&引用名=目标变量名;引用说明:(1)&在此不是求地址运算,而是起标识作用。(2)类型标识符是指目标变量的类型。(3)声明引用时,必须同时对其进行初始化。(4)引用声明完毕后,相当于目标变量名有两个名称,即该目标原名称和引用名,且不能再把该引用名作为其他变量名的别名。inta=2,int&ra=a;a为目标原名称,ra为目标引用名。给ra赋值:ra=1;等价于a=1;(5)对引用求地址,就是对目标变量求地址。ra与&a相等。即我们常说引用名是目标变量名的一个别名。别名一词好像是说引用不占据任何内存空间。但是编译器在一般将其实现为const指针,即指向位置不可变的指针。即引用实际上与一般指针同样占用内存。(6)不能建立引用的数组。因为数组是一个由若干个元素所组成的集合,所以无法建立一个由引用组成的集合。但是可以建立数组的引用.例如:int&ref[3]={2,3,5};声明ref引用的数组错误 但是可以这样写:constint(&ref)[3]={2,3,5};gcc编译。

#c语言指针#指针变量#引用类型#c++#指针

随机阅读

qrcode
访问手机版