执行function语句_如何在C++中延迟执行——番外

纠错

前一篇《如何在C++中延迟执行》有一点疏忽,会导致在某些不正确使用的情况下发生崩溃。需将defer类更改如下:

class defer{    using OnDestructorAction = std::function;public:    defer(defer&) = delete;    defer(OnDestructorAction action) : OnDestructor(action) {}    ~defer()    {        if (OnDestructor)        {            OnDestructor();        }    }    defer operator=(defer&) = delete;    void* operator new(size_t) = delete;protected:    OnDestructorAction OnDestructor;};

这是由于可能会被有意或无意这样使用

defer clean(nullptr);

将导致运行时错误。

9c2cb359de7cc47f3aa8a4071cdde945.png

图片源自网络,与内容无关

优化

要说和Golang的defer相比,前面版本已经接近,只是不可以像Golang一样作为关键字和延时执行某一语句,如:

defer file.close()

但是由于是自定义的,就会有更高的可控性和灵活性。这里将对defer类做一点优化,以减少在一个函数中可能存在的多个defer对象。例如《如何在C++中延迟执行》中的最后的示例,为了在不同阶段执行清理,创建了2个defer对象。解决方法也很简单,让一个defer对象可以容纳多个清理方法就可以了。更改后的示例版本如下

#include #include #include class defer{    using OnDestructorAction = std::function;public:    defer(defer&) = delete;    defer(OnDestructorAction action)    {        OnDestructor.push(action);    }    ~defer()    {        while (OnDestructor.size() > 0)        {            auto action = OnDestructor.top();            OnDestructor.pop();            if (action)            {                action();            }        }    }    void Append(OnDestructorAction action)    {        OnDestructor.push(action);    }    defer operator=(defer&) = delete;    void* operator new(size_t) = delete;protected:    std::stack OnDestructor;};void fun(bool doit){    defer clean([]()        {            std::cout << "clean" << std::endl;        });    if (!doit)    {        std::cout << "! doit" << std::endl;        return;    }    clean.Append([]()        {            std::cout << "clean 2" << std::endl;        });    std::cout << "doit" << std::endl;    return;}int main(){    std::cout << "fun(false)" << std::endl;    fun(false);    std::cout << "func(true)" << std::endl;    fun(true);    return 0;}

执行程序,得到输出如下

fun(false)! doitcleanfunc(true)doitclean 2clean

没有什么特别的,只是将OnDestructor成员更改为使用容器存放多个OnDestructorAction对象。唯一需要注意的是,这里窗口选择的是stack。为什么要选择stack呢?思考一下吧!

原创文章,转载请保留出处 https://www.toutiao.com/i6895175707958346248/

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值