赞
踩
智能指针是针对内存泄漏的问题进行处理。
我们写一个模拟除法函数,调用一下。该函数会对除数为0的情况抛异常:
- #include<iostream>
- using namespace std;
-
- double chu(int a, int b)
- {
- if (b == 0)
- {
- throw invalid_argument("除数不能为0!");
- }
- else
- {
- return (double)a / b;
- }
- }
- void funb()
- {
- int* p = new int[10];
- int a = 0, b = 0; cin >> a >> b;
- cout << chu(a, b) << endl;
- delete[] p;
- cout << "deletc[]" << p << endl;
- }
-
- int main()
- {
- try
- {
- funb();
- }
- catch (const exception &e)
- {
- cout << e.what() << endl;
- }
- return 0;
- }
抛异常不调用析构:
正常情况会释放:
我们发现如果没有抛异常就程序最后释放(调用析构),如果抛异常了那么最后不会析构(不调用析构)。
那么如果遇到抛异常的情况,没有调用析构,最后可能会导致内存泄漏的问题。
这个时候就可以用聪明的指针来解决这个问题:
- #include<iostream>
- using namespace std;
- class SmartPtr
- {
- public:
- SmartPtr(int* ptr)
- :_ptr(ptr)
- {}
-
- ~SmartPtr()
- {
- delete[] _ptr;
- cout<<"delete[]"<< " "<< _ptr<<endl;
- }
- private:
- int* _ptr;
- };
- double chu(int a, int b)
- {
- if (b == 0)
- {
- throw invalid_argument("除数不能为0!");
- }
- else
- {
- return (double)a / b;
- }
- }
- void funb()
- {
- int* p = new int[10];
- SmartPtr sp(p);
- int a = 0, b = 0; cin >> a >> b;
- cout << chu(a, b) << endl;
- //delete[] p;
- //cout << "deletc[]" << p << endl;
- }
-
- int main()
- {
- try
- {
- funb();
- }
- catch (const exception &e)
- {
- cout << e.what() << endl;
- }
- return 0;
- }
Copyright © 2003-2013 www.wpsshop.cn 版权所有,并保留所有权利。