正文共296个字,预计阅读时间5分钟。
提出问题
在所有异常分之里记得释放资源,存在较为严重的安全隐患。此处,引入ScopedExit的封装,使用C++特有的RAII机制,在析构函数中完成资源的安全释放;即使程序在运行中抛出异常,也能保证资源的安全释放。
函数指针
1int fd = open("file.dat", O_RDONLY);
2ScopedExit e(fd, close);
Lambda表达式
1File* f = fopen("file.dat", "r");
2ScopedExit e(f, [](FILE* f) {
3fclose(f);
4});
ScopedExit实现
此处,显式地加上+deleter,使得lambda表达式能够安全地转型为原生的函数指针类型。举个例子,auto test = +[]{},test的类型推演为void(*)()。
1class ScopedExit {
2using Handle = void*;
3using Deleter = void(*)();
4using Wrapper = void(*)(Deleter*, Handle*);
5
6Wrapper wrapper;
7Deleter deleter;
8Handle handle;
9
10public:
11template<typename T, typename D>
12ScopedExit(T handle, D deleter)
13: deleter(reinterpret_cast<Deleter>(+deleter))
14, handle(reinterpret_cast<Handle>(handle)) {
15wrapper = [](Deleter* deleter, Handle* handle) {
16auto d = (*reinterpret_cast<D*>(deleter));
17auto h = (*reinterpret_cast<T*>(handle));
18d(h);
19};
20}
21~ScopedExit() {
22wrapper(&deleter, &handle);
23}
24};
原文链接:https://www.jianshu.com/p/d8d1dc07a5c7