ZKX's LAB

C#值类型和引用类型的区别 c 返回对象和引用类型

2020-07-25知识15

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#里的引用类型变量是什么意思,能不能通俗一点解释,是不是类似于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 也就是克隆,也就是因为=号只是引用传递,所以无法复制出一份副本出来,所以才需要和弄出了这个克隆函数,才能通过此方法复制出副本出来返回引用类型的返回引用的好处如下:(1)传递引用给函数与传递指针的效果是一样的。这时,被调函数的形参就成为原来主调函数中的实参变量或对象的一个别名来使用,所以在被调函数中对形参变量的操作就是对其相应的目标对象(在主调函数中)的操作。(2)使用引用传递函数的参数,在内存中并没有产生实参的副本,它是直接对实参操作;而使用一般变量传递函数的参数,当发生函数调用时,需要给形参分配存储单元,形参变量是实参变量的副本;如果传递的是对象,还将调用拷贝构造函数。因此,当参数传递的数据较大时,用引用比用一般变量传递参数的效率和所占空间都好。(3)使用指针作为函数的参数虽然也能达到与使用引用的效果,但是,在被调函数中同样要给形参分配存储单元,且需要重复使用\"*指针变量名\"的形式进行运算,这很容易产生错误且程序的阅读性较差;另一方面,在主调函数的调用点处,必须用变量的地址作为实参。而引用更容易使用,更清晰。返回引用一般是用在c或者c++等高级语言上。返回引用类型的将“引用”作为函数返回值类型 格式:类型标识符&函数名(形参列表及类型说明){/函数体 }好处:在内存中不产生被返回值的副本;(注意:正是因为这点原因,所以返回一个局部变量的引用是不可取的。因为随着该局部变量生存期的结束,相应的引用也会失效,产生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#值类型和引用类型有什么不同? 值类型和引用类型有很多不同。下面列一些马上可以想到的。1、值类型存储在栈内存或堆内存之中,而引用类…

#赋值#引用类型#变量#返回值

随机阅读

qrcode
访问手机版