2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 | #pragma once #include <string> #include <iostream> class CMyException { public: int info()const { return _iValue; } void Set(int n) { _iValue = n; } private: int _iValue; // 异常值 }; /* * @Func : 测试:throw操作究竟是真正的异常对象被繁殖还是一个复制品被构造出来.h * * @测试方法:在catch块中改变异常对象的值,通过观察原来的值及对象的地址,判断是否发生了改变 * * @测试结果及分析 * (1) 当catch中的形参为 * const CMyException &ex * CMyException &ex * CMyException ex * 时,输出信息如下 tye块中异常值为:1,地址为002DF8D4 catch块中异常值为:2,地址为002DF8C8 非异常块中异常值为:1,地址为002DF8D4 * 从输出信息可以看出,在上述三种情况下,原来的值未发生改变,因此有一个复制品被构造出来了 * (2) 当catch中的形参为 * CMyException *ex * 时,输出信息如下 tye块中异常值为:1,指针地址为001AF94C catch块中异常值为:2,指针地址为001AF940 非异常块中异常值为:2,指针地址为001AF94C * 从输出信息可以看出,在这种情况下,也有一个指针的复制品被构造出来了(地址发生该表了),但是对象的值的改变被保留下来了 * * @说明:throw语句会复制构建抛出的对象,因此如果需要记录在catch语句块中的改变,需将抛出类型设为对象指针 */ inline void Test_Throw(){ CMyException ex; CMyException *pEx = &ex; ex.Set(1); // 值设为1 try{ std::cout << "tye块中异常值为:" << ex.info() << ",指针地址为" << &ex << std::endl; throw ex; // 此处,以ex为初值构建了一个异常对象(Exception Object) } catch (CMyException ex) // 此处的参数形式决定了在下面这个catch块中的改变是否会应用于EO // 只有在一个catch子句评估完毕并且知道它不会再抛出exception之后,真正的 // 异常对象才会被销毁 { ex.Set(2); // 改变值,在后面观察上面定义的ex的值是否发生了改变 std::cout << "catch块中异常值为:" << ex.info() << ",指针地址为" << &ex << std::endl; } std::cout << "非异常块中异常值为:" << ex.info() << ",指针地址为" << &ex << std::endl; } |
联系客服