草庐IT

basic_streambuf

全部标签

c++ - streambuf 获取 streampos

我将C++streambuf类用于编译器项目,需要一种方便的方法来获取流中的当前位置。有两个成员函数,streambuf::pubseekpos和一个streambuf::pubseekoff,用来修改位置,我很困惑没有streambuf::pubgetpos成员函数(或类似的东西)来读取它。似乎有两种可能的解决方法:我可以将当​​前位置保存在一个单独的变量中并修改每当我从流中读取字符时手动执行它。我可以调用streambuf::pubseekoff(0,ios_base::cur),它会返回新的流位置。第二个选项似乎可用,但对于这样一个微不足道的任务来说效率低下且不美观。有更好的方法

c++ - solaris (x86) 上std::basic_string 的一些疑惑

solaris(x86)上std::basic_string的一些困惑#include#includeintmain(){constwchar_t*s=L"abcdef";std::wstringws(s,s+6);for(inti=0;i运行结果为:9799101000为什么不是979899100101102代码#include#includeintmain(){constwchar_t*s=L"abcdef";std::wstringws;ws.resize(6);for(inti=0;i可以得到预期的结果。我使用gcc3.4.6,构建命令是g++-fshort-wcharstri

c++ - 如何处理读入 ASIO streambuf 的额外字符?

大多数库的解析器仅在std::istream或单个连续缓冲区上工作。这些解析器读取istream直到eof,而不是文档的末尾。即使有一个很好的boost::asio::streambuf,它可以与istream一起使用,但只读取一帧并向其提交一帧仍然存在问题。read_until之类的函数正在提交它们读取的任何内容,如果它们读取下一帧的片段,则解析填充会失败。这mockexampleonColiru显示了问题。假设我们需要一个高效的解决方案,无需复制缓冲区,我需要确保流的结尾是文档的正确结尾。我当前的解决方案是扫描数据并在一个准备好的缓冲区上进行多次提交/使用:size_tread_s

c++ - 错误 : no matching function for call to ‘to_string(std::basic_string<char>&)’

即使在模板中我可以有任何类型,函数to_string对基本字符串不起作用:例如:std::stringstr("mystring");my_class(str);用这个仿函数定义:templatevoidoperator()(valuetypevalue){...private_string_field=std::to_string(value);不起作用。这是错误:error:nomatchingfunctionforcallto‘to_string(std::basic_string&)’避免它的最佳方法是什么。事先,我要求避免仅仅因为一些常见的关键字就链接到不相关的问题。

c++ - 在 C++ 的编译时检查类型是否为 std::basic_string<T>

我在我的C++代码中定义了is_string:#includetemplatestructis_string{staticconstboolvalue=false;};templatestructis_string>{staticconstboolvalue=true;};intmain(){std::cout::value::value对于std::string和std::wstring都是如此。但我需要这样的谓词:is_string::value//tobetrueis_string::value//tobefalseis_string::value//tobefalseis_st

c++ - boost::asio::streambuf - 如何重用缓冲区?

我正在实现使用asiosocket.async_read()和boost::asio::async_read_until()方法从套接字异步读取数据的TCP服务器。两者都使用相同的处理程序从boost::asio::streambuf读取数据。通过async_read()调用的完美处理程序:voidhandle_read(constboost::system::error_code&ec,std::size_tytes_transferred)){m_request_buffer.commit(bytes_transferred);boost::asio::streambuf::con

c++ - 如何使用类似 `std::basic_istream<std::byte>` 的东西

本题旨在使用std::byte具有标准输入输出。是否有任何计划为read(_bytes)添加适当的函数重载?和write(_bytes)到basic_istream的接口(interface)和basic_ostream在未来的标准?有什么理由反对它?我知道CharT*-应保留过载。我可以做什么来使用std::byte?我目前在我的项目功能中定义std::istream&read(std::istream&,std::byte*,std::streamsize)std::ostream&write(std::ostream&,conststd::byte*,std::streamsiz

c++ - std::basic_string 完全特化(g++ 冲突)

我正在尝试定义std::basic_string,allocator>的完全特化这是由定义的(在g++中)标题。问题是,如果我包含首先,g++将typedef视为basic_string的实例化并给我错误。如果我先进行特化,那么我就没有问题。我应该能够在之后定义我的特化已经包括了。我必须做什么才能做到这一点?我的代码:#include//#include//classbasic_string,allocator>{public:intblah(){return42;}size_tsize(){return0;}constchar*c_str(){return"";}voidreserv

c++ - 当你有一个 std::string 时如何使用 basic_istream

我有一个使用basic_istream作为参数的函数,我有一个std::string和我需要传递给它的数据。我该怎么做? 最佳答案 您可以将字符串数据放入流中:std::stringx;std::stringstreamss(x);//putstringintostreamfunction_taking_stream(ss); 关于c++-当你有一个std::string时如何使用basic_istream,我们在StackOverflow上找到一个类似的问题:

c++ - 为什么这个编译器错误? - 没有匹配函数调用 'std::basic_ofstream<char>::open(std::string&)'

这适用于VisualStudio,并且适用于一台计算机上的GCC4.9.2。但在不同的计算机上,我认为它是相同的GCC4.9.2编译器,但它给了我这个错误。我错过了什么吗?怎么回事?#include#include#includeusingnamespacestd;intmain(){stringfilename;filename="teststring";ofstreamfout;fout.open(filename);fout.||===Build:Debuginfileiotest(compiler:TDM32GNUGCCCompiler4.9.2dw2)===|F:\Users