首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往

论函数的设计应如何才好,返回临时变量 | 返回引用 | 传递引用

首先这个函数里面,会发生两次构造函数,一次是 变量t,另外一次是return 前,做的一次拷贝构造 tempTest testTemp(){ tempTest t; return t; } 第一种,返回临时变量...tt = testTemp"<<endl; //这样写,就2次构造函数 tempTest tt2 = testTemp(); 首先这个函数的话,只会发生一次构造函数,返回引用...tempTest& testTemp2(){ tempTest * t = new tempTest(); return *t; } 第三种,然后,注意这里的变量要用引用,这样,总得来说...一次是最少了,但是如果返回引用的话,就得注意一个问题,内存泄露,所以不用得时候,要delete掉。返回指针同理。...tempTest& tt3 = testTemp2(); _CrtDumpMemoryLeaks(); delete &tt3; 这个函数,就通过传入引用来修改变量

2K21

引用返回与节省内存

PHP中的引用是什么: 1.在 PHP 中引用意味着用不同的名字访问同一个变量内容 2.引用可以被看作是 Unix 文件系统中的硬链接。...3.使用unset的话,只是删除他这个名字自身对内容的引用,并没有删除内容本身 php > $a="test";$b=&$a;unset($a);var_dump($b); string(4) "test...";$b=&$a;$b=null;var_dump($a); NULL php > $a="test";$b=&$a;$a=null;var_dump($b); NULL php的引用返回与节省内存...: 1.这里必须在两个地方都用 & 符号——指出返回的是一个引用,而不是通常的一个拷贝,同样也指出 $myValue 是作为引用的绑定,而不是通常的赋值 2.返回的必须是类属性的形式 使用引用返回所占内存是...221344 ; 不使用引用返回多次调用后占884968 <?

50220
  • 您找到你想要的搜索结果了吗?
    是的
    没有找到

    浅析 SpringMVC 中返回对象的循环引用问题

    @RestController、@ResponseBody 等注解是我们在写 Web 应用时打交道最多的注解了,我们经常有这样的需求:返回一个对象给前端,SpringMVC 帮助我们序列化成 JSON...而今天我要分享的话题也不是什么高深的内容,那就是返回对象中存在循环引用时问题的探讨。 该问题非常简单容易复现,直接上代码。...public class IdCard { private String id; private Person person; } 在 SpringMVC 的 controller 中直接返回存在循环引用的对象...,"name":"kirito"} 已经正常返回了,fastjson 使用了"$ref":".."...使用 FastJsonHttpMessageConverter 可以彻底规避掉循环引用的问题,这对于返回类型不固定的场景十分有帮助,而 @JsonIgnore 只能作用于那些固定结构的循环引用对象上。

    6K30

    c++中引用作为返回

    返回函数的普通类型 a = fun1(); // 2. 返回函数的引用 b = fun2(); // 3....返回引用实际返回的是一个指向返回值的隐式指针,在内存中不会产生副本,是直接将temp拷贝给a,这样就避免产生临时变量,相比返回普通类型的执行效率更高,而且这个返回引用的函数也可以作为赋值运算符的左操作数...千万别返回局部对象的引用,当函数执行完局部对象也就被销毁,栈空间被释放,从而返回的地址已经不存在,导致后面执行出错。 2)....返回堆区对象的引用,这种情况要特别注意,这时候返回函数的引用是作为一个临时变量出现,没有将它赋值给一个实际存在的变量,那么这个堆区对象的内存空间就没有释放,可能造成内存泄漏。有人说这样做是非法的?...返回函数的引用去初始化一个新的引用 这个和前面一样,都是不会产生副本,但是现在是用返回值去初始化一个引用声明c,也就是说这时候变成了变量temp的别名,在c的生命周期内temp是一直有效的,这样做完全可以

    64210

    【C++】C++ 引用详解 ⑤ ( 函数 “ 引用类型返回值 “ 当左值被赋值 )

    函数返回值 能作为 左值 , 是很重要的概念 , 这是实现 " 链式编程 " 的基础 ; 一、函数返回值不能是 " 局部变量 " 的引用或指针 1、函数返回值常用用法 在 C++ 语言中 , 函数返回值...如果 是 外部通过 函数参数 传入到函数中的 指针 / 引用 , 没有必要返回 , 外部已经有了 , 你再返回一次意义不大 ; 2、分析函数 " 普通返回值 " 做左值的情况 函数普通返回值 不能做左值...========== 生成: 成功 0 个,失败 1 个,最新 0 个,跳过 0 个 ========== 3、分析函数 " 引用返回值 " 做左值的情况 函数引用返回值 可以做左值 ; 下面的 fun2...函数 , 返回 局部变量 中 创建的 静态变量 a 的引用 , 相当于 将 静态变量 的 内存地址返回回去了 , 该 静态变量的 内存地址 直到程序结束之前 都是有效的 , 因此该引用返回值 可以正常使用...为其 赋值 100 , 然后打印 之前获取的 引用值 , 值也变为 100 ; 函数的引用返回值 可以作为 左值使用 ; 函数返回值 做 左值 代码示例 : // 导入标准 io 流头文件 // 其中定义了

    31930

    【C++】C++ 引用详解 ④ ( 函数返回 静态变量 全局变量 的 引用 指针 )

    一、函数返回 静态变量 / 全局变量 的 引用 / 指针 1、函数返回局部变量引用或指针无意义 上一篇博客 【C++】C++ 引用详解 ③ ( 函数返回值不能是 “ 局部变量 “ 的引用或指针 | 函数内的...“ 局部变量 “ 的引用或指针做函数返回值无意义 ) 得出如下结论 : 函数的返回值 是 “ 局部变量 “ 的 引用 或 指针 时 , 是无意义的 ; 函数 执行完毕后 , 该 函数对应的 栈内存 会被回收..., 相应的 局部变量 地址 也有没有了意义 , 此时 , 再持有一个 函数返回的 没有意义的 引用 / 指针 , 取出的值是随机无意义的值 ; 2、函数返回静态变量/全局变量的引用或指针 函数 返回的是..., 该内存都不会被回收 , 返回它们的 引用 / 指针 , 可以正常访问 对应 内存中的数据 ; 3、代码示例 - 函数返回静态变量/全局变量的引用或指针 在下面的代码中 , fun 函数作为 参照...; 使用 引用 接收 fun2 函数返回引用 , 获取的是静态变量的引用地址 , 该引用对应的内存一直是有效的 , 因此可以通过该引用获取到内存中正确的 静态变量值 ; 代码示例 : // 导入标准

    21030

    【C++】C++ 引用详解 ③ ( 函数返回值不能是 “ 局部变量 “ 的引用或指针 | 函数内的 “ 局部变量 “ 的引用或指针做函数返回值无意义 )

    一、函数返回值不能是 " 局部变量 " 的引用或指针 1、引用通常做右值 之前使用 引用 时 , 都是作为 右值 使用 , 引用只在 声明 的 同时 进行初始化时 , 才作为左值 , // 定义变量 a...2、函数返回值特点 函数 的 返回值 几乎很少是 引用 或 指针 ; 函数 的 计算结果 经常是借用 参数中的 地址 / 引用 进行返回的 , 函数 的 返回值 一般返回一个 int 类型的值 , 如果..., 也就是 修改 地址 / 引用 指向的 内存中的数据 , 该操作可以修改 外部 main 函数中的变量值 ; 如果 想要 在 函数 中 , 返回一个 地址 / 引用 作为返回值 , 这个 地址 /...如果 想要 在 函数中 , 返回 引用 / 指针 , 函数局部变量的 引用 / 指针 是返回不出来的 , 即使强行返回 引用 / 指针 , 也是当前 局部变量 被 分配的 栈内存 地址 , 该函数 执行完毕后..." 引用或指针做函数返回值测试 ---- 下面的 int& getNum2() 函数 , 返回一个引用 , 该 引用 是 局部变量 的引用 ; 下面的 int* getNum3() 函数 , 返回一个指针

    39620

    引用,软引用,弱引用,虚引用

    引用,软引用,弱引用,虚引用 ⽆论是通过引⽤计数法判断对象引⽤数量,还是通过可达性分析法判断对象的引⽤链是否可达,判定对象的存活都与“引⽤”有关。...软引用可用来实现内存敏感的高速缓存。 软引⽤可以和⼀个引⽤队列(ReferenceQueue)联合使⽤,如果软引⽤所引⽤的对象被垃圾回收,JAVA虚拟机就会把这个软引用加入到与之关联的引⽤队列中。...弱引用(WeakReference) 如果⼀个对象只具有弱引⽤,那就类似于可有可无的⽣活⽤品。 弱引⽤与软引⽤的区别在于: 只具有弱引⽤的对象拥有更短暂的⽣命周期。...虚引用(PhantomReference) "虚引⽤"顾名思义,就是形同虚设,与其他几种引⽤都不同,虚引⽤并不会决定对象的生命周期。...虚引用主要用来跟踪对象被垃圾回收的活动。 虚引⽤与软引⽤和弱引⽤的⼀个区别在于: 虚引⽤必须和引⽤队列(ReferenceQueue)联合使用。

    7310

    Java引用类型:强引用,软引用,弱引用,虚引用

    在Java中提供了4个级别的引用:强引用,软引用,弱引用,虚引用。在这4个引用级别中,只有强引用FinalReference类是包内可见,其他3中引用类型均为public,可以在应用程序中直接使用。...强引用具备一下特点: 强引用可以直接访问目标对象 强引用所指向的对象在任何时候不会被系统回收,JVM宁愿抛出OOM异常,也不回收强引用所指向的对象 强引用可能导致内存泄漏 所以当我们在使用强引用创建对象时...软引用引用是除强引用外,最强的引用类型。...接着申请一块堆大小的的堆空间,并catch异常,从执行结果发现,在这次GC后,softRef.get()不再返回MyObject对象,而是返回null。...弱引用引用时一种比软引用较弱的引用类型。

    2.2K31

    【小家java】引用类型(强引用、软引用、弱引用、虚引用

    一旦SoftReference保存了对一个Java对象的软引用后,在垃圾线程对这个Java对象回收前,SoftReference类所提供的get()方法返回Java对象的强引用 先看一个最简单的使用...= new SoftReference(obj); softRef.get(); //此方法需要注意:若softRef没被回收,返回对obj的强引用,若被回收了,则返回null,所以不可靠,...()永远是有返回值的。...obj = null; //删除掉强引用 这时,Obj对象就只剩下软引用了,是软可达的。这个时候如果用get(),返回值就有可能是null了,因此使用的时候要十分注意。...一个对象与虚引用关联,则跟没有引用与之关联一样,所以get()方法永远返回null,在任何时候都可能被垃圾回收器回收。

    2.1K40

    Java中弱引用、软引用、虚引用、强引用、 Finalizer引用

    在Java层面,一共有四种引用:强引用、软引用、弱引用、虚引用,这几种引用的生命周期由强到弱。转换关系大致如下图所示: ?...强引用(Strong Reference)   就是我们最常见的普通对象引用,只要还有强引用指向一个对象,就能表明对象还“活着”,垃圾收集器不会碰这种对象。...对于一个普通的对象,如果没有其他的引用关系,只要超过了引用的作用域或者显式地将相应(强)引用赋值为 null,就是可以被垃圾收集的了。...引用何时被加到ReferenceQueue队列里   在构造软引用,弱引用和幻象引用的时候,可以传入一个ReferenceQueue的对象,这个队列是用来做什么的呢?...当软引用,弱引用和幻象引用引用的对象被回收之后,对应的SoftReference,WeakReference,PhantomReference 对象已经不再具有存在的价值,需要一个适当的清除机制,避免大量

    2.1K30

    Java 的强引用、弱引用、软引用、虚引用

    >(obj); obj = null; wf.get();//有时候会返回null wf.isEnQueued();//返回是否被垃圾回收器标记为即将回收的垃圾 弱引用是在第二次垃圾回收时回收,短时间内通过弱引用取对应的数据...,可以取到,当执行过第二次垃圾回收时,将返回null。...弱引用主要用于监控对象是否已经被垃圾回收器标记为即将回收的垃圾,可以通过弱引用的isEnQueued方法返回对象是否被垃圾回收器标记。...(obj); obj=null; pf.get();//永远返回null pf.isEnQueued();//返回是否从内存中已经删除 虚引用是每次垃圾回收的时候都会被回收,通过虚引用的...如果队列为空,将返回一个null,否则该方法返回队列中前面的一个Reference对象。利用这个方法,我们可以检查哪个SoftReference所软引用的对象已经被回收。

    1.6K10

    引用、软引用、弱引用、虚引用的对比

    引用、软引用、弱引用、虚引用 从Jdk1.2开始,在java.lang.ref包下就提供了三个类:SoftReference(软引用),PhantomReference(虚引用)和WeakReference...(弱引用),它们分别代表了系统对对象的中的三种引用方式:软引用,虚引用以及弱引用。...因此java语言对对象的引用有如下四种: 强引用:就是正常的引用。...2 软引用和弱引用的区别 弱引用不会影响GC的清理,也就是说当GC检测到一个对象存在弱引用也会直接标记为可清理对象,而软引用只有在内存告罄的时候才会被清理 3 弱引用和虚引用的区别 说两者的区别之前要说一下...虚引用必须和一个ReferenceQueue联合使用,当GC准备回收一个对象的时候,如果发现该对象还有一个虚引用,就会将这个虚引用加入到与之关联的队列 弱引用是当GC第一次试图回收该引用指向的对象时会执行该对象的

    2.1K20

    引用和弱引用的区别_强引用引用引用引用的区别

    第二次由于分配了较大的内存,导致GC,这时候由于内存资源紧张,软引用被回收了,也就是虽然User对象有一个软引用引用着它,但User对象在此条件下也会被GC回收。...所以软引用的对象在一定条件下可被回收,故软引用对象不会导致内存溢出。...软引用到底有没有被回收,可以通过给软引用一个ReferenceQueue来跟踪,将上面的代码片段稍作修改,如下: import java.lang.ref.Reference; import java.lang.ref.ReferenceQueue...,所以ReferenceQueue为空,第二次GC回收了软引用对象,所以ReferenceQueue队列不为空,那为什么可以强转成UserSoftReference呢?...此处自定义一个UserSoftReference类主要是为了跟踪User对象的id,你无法跟踪User对象,因为User对象已经被回收了,如果调用reference.get(),将会返回null。

    1.2K10

    C++核心准则编译边学-F.45 不要返回右值引用

    F.45: Don't return a T&& F.45:不要返回右值引用 Reason(原因) It's asking to return a reference to a destroyed...返回右值引用是在要求返回一个已经销毁的临时对象的引用。&&对于临时对象来说具有吸引力。 译者注:后面这句真没理解。...returned rvalue reference goes out of scope at the end of the full expression to which it is returned: 返回的右值引用在所有表达式的最后一个返回时退出了有效范围...当引用的对象是向下(向内)传递给调用者时返回右值引用时会工作得很好。这种情况下可以保证临时变量的生命周期会长于函数调用(参见F.18和F.19)。...对于传递输入参数(通过原始引用或者完美的fowrard处理)而且需要返回值的透过型函数,使用简单的auto类型返回类型推断(不是auto&&)。

    83030
    领券