草庐IT

basic_istream

全部标签

C++:std::istream 检查 EOF 而不读取/消耗 token /使用运算符>>

我想测试std::istream是否已经到达结尾而不读取它。我知道我可以像这样检查EOF:if(is>>something)但这有一系列的问题。想象有许多(可能是虚拟的)方法/函数期望std::istream&作为参数传递。这意味着我必须做一些检查EOF的“家务”,可能使用不同类型的something变量,或者创建一些奇怪的包装器来处理调用输入法的情况.我需要做的就是:if(!IsEof(is))Input(is);IsEof方法应保证流不会因读取而改变,因此上面的行等同于:Input(is)关于在Input方法中读取的数据。如果没有通用的解决方案来表示和std::istream,有没

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

c++ - 提升精神 : how to convert basic types?

假设我有一个std::string属性,但为了便于解析,我想使用qi::int_或qi::double_.是否有一种简单的方法可以将转换作为语义操作进行?我试过这样的:std::stringstreamss;my_int_as_str=qi::int_[ref(ss)但这甚至无法编译。编辑-尝试使用下面sehe的回答#include#include#include#includenamespaceqi=boost::spirit::qi;namespacephx=boost::phoenix;intmain(intargc,char*argv[]){std::stringtest="1

c++ - 在 istream 上用 << 读取固定数量的字符

我在C++中尝试了一些文件读取策略,我遇到了这个问题。ifstreamifsw1("c:\\trys\\str3.txt");charifsw1w[3];do{ifsw1>>ifsw1w;if(ifsw1.eof())break;cout文件的内容是firstfirstfirstsecondsecondfirstsecondsecond当我看到输出时,它被打印为firstfirstfirstsecondsecondfirst我希望输出是这样的:firstfirstfi.....而且我看到没有打印“secondsecond”。估计是上次read遇到了eof,cout可能还没有执行。但是第

c++ - 使用运算符将​​字符串流传递给 istream >>

我正在尝试将字符串流传递到一个对象(类)中,该对象(类)具有已声明和定义的重载提取运算符>>>。例如,object1中重载的提取运算符的声明是friendistream&operator>>(istream&in,Object1&input);在object2中,我的声明几乎一样friendistream&operator>>(istream&in,Object2&input);在object1提取函数期间,func.获取一行,将其转换为字符串流并尝试使用Object2的提取(>>)运算符。istream&operator>>(istream&in,Object1&input){Obj

c# - 是否有与 boost::interprocess::basic_string 等效的 C#?

在C++中,您可以使用boost::interprocess定义一个boost::interprocess::basic_string,它基本上是对存储在内存映射文件中的字符串的抽象。您可以像在您的应用程序中使用任何其他字符串一样无缝地使用它(当然假设您注意线程安全)。是否有任何等效的C#库/nuget包/代码段? 最佳答案 没有。但是,即使可以透明地实现,C#中的字符串也是不可变的。因此,我认为拥有一个像那样的图书馆甚至不会非常有用。 关于c#-是否有与boost::interproc

c++ - istream::tellg() 在与我的自定义 streambuf 类一起使用时返回 -1?

我正在尝试创建一个直接从原始内存缓冲区读取的istream。我在这里的另一篇文章中找到了一个很好的方法来做到这一点:classmembuf:publicbasic_streambuf{public:membuf(char*p,size_tn){setg(p,p,p+n);}};然后我使用这个membuf创建我的istream:membufmb(dataPointer,dataLength);istreamreader(&mb);然后我使用getline()和>>>运算符阅读,一切都很棒。但是,我似乎无法使用seekg()返回缓冲区的开头,并且istream::tellg()总是返回-1

c++ - 类似 istream::getline() 的东西,但有替代的 delim 字符?

获得istream::getline(string,256,'\n'OR';')效果的最简洁方法是什么?我知道编写循环非常简单,但我觉得我可能遗漏了一些东西。我是吗?我用过的:while((is.peek()!='\n')&&(is.peek()!=';'))stringstream.put(is.get()); 最佳答案 不幸的是,没有办法有多个“行尾”。您可以做的是阅读该行,例如std::getline并将其放入std::istringstream并使用std::getline(使用';'分隔符)在istringstream的循

c++ - 如何使用 libc++ istream_iterator 读取文件中的 0xFF?

考虑以下示例代码:#includeusingnamespacestd;intmain(){istreambuf_iteratoreos;istreambuf_iteratoriit(cin.rdbuf());inti;for(i=0;iit!=eos;++i,++iit){cout以及包含以下内容的输入文件:“foo\xffbar”:$hexdumptestin0000000666f6fff6261720000007现在使用clanglibc++与gnulibstdc++进行测试:$maketestclang++-std=c++11-stdlib=libc++-Wall-stdlib=

c++ - boost::lexical_cast 无法识别重载的 istream 运算符

我有以下代码:#include#includestructvec2_t{floatx;floaty;};std::istream&operator>>(std::istream&istream,vec2_t&v){istream>>v.x>>v.y;returnistream;}intmain(){autov=boost::lexical_cast("1231.2152.9");std::cout我从Boost收到以下编译错误:Error1errorC2338:Targettypeisneitherstd::istreamablenorstd::wistreamable这看起来很简单,