jjzjj

basic_istream

全部标签

c++ - 模板化 ostream 重载歧义错误 : basic_ostream<char> vs const char[]

我正在尝试了解ostream重载。考虑一下#includeusingstd::ostream;enumclassA{a1,a2,a3};templateostream&operator编译时出现如下错误test.cpp:13:17:error:ambiguousoverloadfor‘operator}’and‘constchar[3]’)returnout虽然取消注释正常功能和注释模板版本工作正常。为什么二义性不是在正常功能中,为什么是模板化版本 最佳答案 非模板运算符不会引起任何歧义,因为该运算符本身无法解决此调用:return

c++ - 当非限定名称查找涉及 using-directives 时 [basic.scope.hiding]p2 的解释

在c++中有两种隐藏的名字:1)普通名称隐藏:[basic.scope.hiding]p1(http://eel.is/c++draft/basic.scope.hiding#1):Anamecanbehiddenbyanexplicitdeclarationofthatsamenameinanesteddeclarativeregionorderivedclass([class.member.lookup]).2)隐藏在[basic.scope.hiding]p2(http://eel.is/c++draft/basic.scope.hiding#2)中的特殊名称类型:Aclassn

c++ - 从 std::istream 读取 SDL_RWops

我很惊讶Google没有找到解决方案。我正在寻找一种允许SDL_RWops与std::istream一起使用的解决方案。SDL_RWops是在SDL中读取/写入数据的替代机制。是否有指向解决该问题的网站的链接?一个明显的解决方案是将足够的数据预读到内存中,然后使用SDL_RWFromMem。但是,这样做的缺点是我需要事先知道文件大小。似乎这个问题可以通过“覆盖”SDL_RWops函数以某种方式解决... 最佳答案 我觉得不好回答我自己的问题,但它困扰了我一段时间,这是我想出的解决方案:intistream_seek(structSD

c++ - 为什么 "gptr"类型的basic_streambuf是char_type*而不是const char_type*?

设置流缓冲的三个“gptr”的basic_streambuf成员,setg声明为:protected:voidsetg(char_type*gback,char_type*gptr,char_type*egptr);我想知道:为什么每个gptr的类型都是char_type*而不是constchar_type*?在这里使用const_cast为这些gptrs使用constchar指针是否安全? 最佳答案 它不是const,因为streambuf接口(interface)不知道您如何填充缓冲区。例如,underflow和uflow方法可

c++ - 如何手动将数据放入 boost::asio::streambuf 以便稍后使用 std::istream 读取它?

我正在尝试使用std::istream作为数据源。我想将自定义二进制数据放置到istream的流缓冲区中,以便稍后可以从istream中检索它。我已经阅读了有关boost::asio::streambuf的内容,以及如何使用它来完成我想要的,但使用套接字作为数据源而不是我想使用的内存缓冲区。据我了解documentation,步骤应该是:创建一个boost::asio::streambuf创建一个传递streambuf的std::istream调用boost::asio::streambuf::prepare以获取表示输出序列的缓冲区列表。以某种方式写入输出序列。调用boost::as

c++ - 我应该在 ATL/WTL 中使用 CString、basic_string<TCHAR> 还是其他东西?

我这几天只学了一点ATL(在意识到纯Win32有多痛苦之后),也学了WTL和MFC,据我所见,有很多不同的字符串我可以上课。我曾经做过这样的事情:#include#includenamespacestd{typedefbasic_string_tstring;}然后在我的代码中到处使用_tstring。在学习了一些ATL之后,我了解到在atltmp.h中有一个CString类。显然,在WTL中还有另一个CString类,在MFC中还有一个CString类。我不知道是继续使用ATL还是转而使用WTL、MFC或其他软件。但是现在,我正在将我的Win32代码转换为ATL,我不确定要更改什么以

c++ - 为什么 std::basic_string 不支持通过表达式模板进行连接?

Qt的QString可以通过operator%连接起来,它使用表达式模板预先计算结果字符串的大小并优化对operator+的多个链式调用.参见thisquestionofmine了解更多信息。为什么std::basic_string没有采用类似的结构?C++11甚至允许这样做吗?我只看到优点,很明显,库实现者可以在需要时破坏ABI兼容性(C++11甚至为libstdc++提供了一个很好的理由)。 最佳答案 因为没有人提出标准;除非有人提出建议,否则它不会进入。还因为它可能会破坏现有代码(如果他们使用operator+就是这样)。此外

c++ - 为什么调用 istream::tellg() 会影响我的程序的行为?

我正在尝试将24位位图图像转换为灰度图像。#include#include#include#includeusingnamespacestd;classpixel{public:unsignedcharb;unsignedcharg;unsignedcharr;voiddisplay(){cout当我删除couttellg语句时,循环只运行两次!我不明白删除cout语句有什么不同?结果:只有一个像素变为灰度。我在这里找到了我的问题的一个更简单的版本Readingandwritingtofilessimultaneously?但是没有找到解决方案... 最佳答

c++ - std::istream 类型是 EqualityComparable 吗?

我的问题会有一个bool值答案:是或否。不管是哪一个,有人能解释一下下面的代码是如何被GNU-g++4.9.2和clang3.5编译的,而GNU-g++5.1.1不再接受它,声称没有匹配的operator==?以及如何更改它,对于最后一个编译器,为了获得相同的结果,即让operator>>能够以如此简单的方式区分,是否它是由标准输入流或其他东西调用的?#include#includestructS{};std::istream&operator>>(std::istream&i,S&s){if(i==std::cin)std::clog>s;std::ifstreaminp(args[

c++ - 来自 istream 的子流

假设我有一个ifstream,它表示一个包含许多聚合在一起的子文件的大文件。我希望能够从代表文件一部分的较大ifstream(给定大小和偏移量)创建一个“子”istream,以便其他代码可以从中读取子流就好像它是一个独立的istream。关于如何实现这一点有什么想法吗?编辑-我宁愿避免提升。 最佳答案 这是一个streambuf“过滤器”的示例,它从指定位置开始读取包含的streambuf并读取到指定大小。您创建substreambuf,将原始streambuf传入,然后substreambuf转换访问,以便从底层中的所需位置读取所