Standard-Verzögerungs-/Terminator-Implementierung in C
Die Verzögerungsfunktion in der Go-Sprache ist eine Möglichkeit, einen Codeblock auszuführen, wenn die Funktion beendet wird Mechanismus, der die Ressourcenbereinigung und Fehlerbehandlung vereinfacht. Dieser Artikel untersucht die Möglichkeit einer ähnlichen verzögerten Implementierung in C und die Machbarkeit von Alternativen in vorhandenen Bibliotheken.
Vorhandene Implementierungen
Die C-Standardbibliothek, Boost und andere Bibliotheken von Drittanbietern bieten noch keine fertigen Lazy-Implementierungen. Die folgende leichtgewichtige benutzerdefinierte Implementierung bietet jedoch ähnliche Funktionen wie die Go-Sprache:
<code class="cpp">struct defer_dummy {}; template <class F> struct deferrer { F f; ~deferrer() { f(); } }; template <class F> deferrer<F> operator*(defer_dummy, F f) { return {f}; } #define DEFER_(LINE) zz_defer##LINE #define DEFER(LINE) DEFER_(LINE) #define defer auto DEFER(__LINE__) = defer_dummy{} *[&]()</code>
Verwendung
Diese Implementierung wird auf die gleiche Weise wie die Go-Sprachverzögerung verwendet Die Syntax ist ähnlich:
<code class="cpp">defer { // 要在函数退出时执行的代码块 };</code>
Beispielverwendung
<code class="cpp">#include <cstdio> #include <cstdlib> bool read_entire_file(char *filename, std::uint8_t *&data_out, std::size_t *size_out = nullptr) { auto file = std::fopen(filename, "rb"); if (!file) return false; defer { std::fclose(file); }; // 自动关闭文件 // ...其他文件操作代码 return true; } int main(int argc, char **argv) { if (argc < 2) return -1; std::uint8_t *file_data = nullptr; std::size_t file_size = 0; auto read_success = read_entire_file(argv[1], file_data, &file_size); defer { delete[] file_data; }; // 自动释放文件数据 if (read_success) { // ...文件处理代码 return 0; } else { return -1; } }</code>
Vorteile
Das obige ist der detaillierte Inhalt vonKann C eine Verzögerungsfunktion im Go-Stil mit minimalem Overhead erreichen?. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!