Why are C++ STL iostreams not quot;exception friendlyquot;?(为什么 C++ STL iostream 不是“异常友好的?)
问题描述
我习惯了 Delphi VCL 框架,其中 TStreams 在错误时抛出异常(例如找不到文件、磁盘已满).我正在移植一些代码来使用 C++ STL,并且被 iostreams 发现,默认情况下不会抛出异常,而是设置 badbit/failbit 标志.
I'm used to the Delphi VCL Framework, where TStreams throw exceptions on errors (e.g file not found, disk full). I'm porting some code to use C++ STL instead, and have been caught out by iostreams NOT throwing exceptions by default, but setting badbit/failbit flags instead.
两个问题...
a:为什么会这样 - 对于从一开始就内置异常的语言来说,这似乎是一个奇怪的设计决定?
a: Why is this - It seems an odd design decision for a language built with exceptions in it from day one?
b:如何最好地避免这种情况?我可以生成像我期望的那样抛出的 shim 类,但这感觉就像重新发明轮子.也许有一个 BOOST 库可以更明智地做到这一点?
b: How best to avoid this? I could produce shim classes that throw as I would expect, but this feels like reinventing the wheel. Maybe there's a BOOST library that does this in a saner fashion?
推荐答案
C++ 从一开始就没有例外.C 类"1979年开始,1989年加入异常. 同时,
streams库早在1984年就写好了(后来在1989年变成了iostreams(后来在1991年被GNU重新实现)),只是一开始就不能使用异常处理.
C++ wasn't built with exceptions from day one. "C with classes" started in 1979, and exceptions were added in 1989. Meanwhile, the
streamslibrary was written as early as 1984 (later becomesiostreamsin 1989 (later reimplemented by GNU in 1991)), it just cannot use exception handling in the beginning.
参考:
- Bjarne Stroustrup,C++ 的历史:1979−1991
- C++ 库
您可以通过.exceptions 方法.
You can enable exceptions with the .exceptions method.
// ios::exceptions
#include <iostream>
#include <fstream>
#include <string>
int main () {
std::ifstream file;
file.exceptions(ifstream::failbit | ifstream::badbit);
try {
file.open ("test.txt");
std::string buf;
while (std::getline(file, buf))
std::cout << "Read> " << buf << "
";
}
catch (ifstream::failure& e) {
std::cout << "Exception opening/reading file
";
}
}
这篇关于为什么 C++ STL iostream 不是“异常友好的"?的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持编程学习网!
本文标题为:为什么 C++ STL iostream 不是“异常友好的"?
基础教程推荐
- 初始化列表*参数*评估顺序 2021-01-01
- 为什么 RegOpenKeyEx() 在 Vista 64 位上返回错误代码 2021-01-01
- 为什么派生模板类不能访问基模板类的标识符? 2021-01-01
- 为什么 typeid.name() 使用 GCC 返回奇怪的字符以及如 2022-09-16
- CString 到 char* 2021-01-01
- 我应该对 C++ 中的成员变量和函数参数使用相同的名称吗? 2021-01-01
- 非静态 const 成员,不能使用默认赋值运算符 2022-10-09
- 通过引用传递 C++ 迭代器有什么问题? 2022-01-01
- 如果我为无符号变量分配负值会发生什么? 2022-01-01
- GDB 显示调用堆栈上函数地址的当前编译二进制文 2022-09-05
