草庐IT

init_from_stream

全部标签

c++ io streams sync_with_stdio 没有区别

出于某种原因,我无法使我的输出流使用该行运行得更快std::ios_base::sync_with_stdio(false);包含在我程序的开头。我正在用这两个程序对此进行测试:#includeintmain(){for(inti=0;i和#includeintmain(){std::ios_base::sync_with_stdio(false);for(inti=0;i每个程序的运行时间如下第一次测试(同步)real0m1.095suser0m0.472ssys0m0.299ssecond_test(关闭同步)real0m1.091suser0m0.471ssys0m0.299s我

c++ - 为继承 enable_shared_from_this 的类获取 unique_ptr

通常我更喜欢从工厂返回unique_ptr。最近我遇到了为继承enable_shared_from_this的类返回unique_ptr的问题。此类的用户可能会意外调用shared_from_this(),尽管它不属于任何shared_ptr,这会导致std::bad_weak_ptr异常(或C++17之前的未定义行为,通常作为异常实现)。代码的简单版本:classFoo:publicenable_shared_from_this{stringname;Foo(conststring&_name):name(_name){}public:staticunique_ptrcreate(c

c++ - 继承类中的 shared_from_this() 类型错误(是否有 dyn.type-aware 共享指针?)

我有一个使用enable_shared_from_this的ViewController基类classViewController:publicstd::enable_shared_from_this{//...};和一个child:classGalleryViewController:publicViewController{voidupdateGallery(floatdelta);}问题出现了,当我尝试将我当前的实例传递给第3方时(比如lambda函数被安排在某处)实例(GalleryViewController)会释放一个(罕见的)条件,所以我不能直接捕获“this”,我需要用

c++ - 错误 "lambda is not derived from ' std::function'

我正在尝试将lambda传递给通过可变参数模板定义的std::function,但似乎这在gcc上不起作用。有什么原因,为什么这段代码在gcc7.4.0上不起作用,但在VisualStudio2017上却能正常工作?有没有办法让它在gcc上也能工作,而无需先手动将其转换为std::function?#includetemplateintTestFunction(std::function){return0;}voidTest(){autofce=[](int/*n*/,double/*d*/){};//Thisdoesn'tworkwitherrornomatchingfunction

c++ - Boost Asio SSL Stream lowest_layer() 和 next_layer() 之间的区别

文档似乎并没有说明太多:lowest_layer(),next_layer().它们之间有什么区别以及何时使用它们? 最佳答案 要回答这个问题,首先要记住的是boost::asio::ssl::stream是一个模板类。通常它看起来像boost::asio::ssl::stream.因此使用boost::asio::ip::tcp::socket实现.这将是boost::asio::ssl::stream的下一层.另一方面,lowest_layer始终是basic_socket(它在docs中有描述)。它有点模棱两可,尤其是当您在标

c++ - 我们应该如何在函数中使用带有 std::accumulate 的模板来通过考虑模板而不是 "init"来返回正确的类型

std::accumulate的返回类型取决于“init”,即如果它是整数,它将返回整数,如果是double,它将返回double。我有一个像这样求和的模板函数:Tmean(std::vectorvector){Tsum=std::accumulate(vector.begin(),vector.end(),X);}我应该用什么代替X? 最佳答案 您可以只使用T{},它是默认构造的T。例如Tsum=std::accumulate(vector.begin(),vector.end(),T{});如果你需要用一些初始值来初始化它,你可

c++ - boost::interprocess : cout a string variable when iterating through a map that references an object from a struct

我正在使用boost::interprocess在进程之间共享对象。我有两个文件,一个生成结构对象并将该对象传递到具有int索引的映射中的“server.cpp”;和一个“client.cpp”文件,它检索内存数据并遍历数据,输出到控制台。结构看起来像这样:structmydatao{stringMY_STRING;intMY_INT;};和对象:mydatao;o.MY_STRING="hello";o.MY_INT=45;服务器和客户端都能正确编译。但是出于某种原因,如果我尝试访问客户端中的字符串而不是float或整数,客户端可执行文件会抛出段错误。例如下面的second.MY_I

猫头虎分享已解决Bug || docker: Error response from daemon: invalid mount config for type ‍

博主猫头虎的技术世界🌟欢迎来到猫头虎的博客—探索技术的无限可能!专栏链接:🔗精选专栏:《面试题大全》—面试准备的宝典!《IDEA开发秘籍》—提升你的IDEA技能!《100天精通鸿蒙》—从Web/安卓到鸿蒙大师!《100天精通Golang(基础入门篇)》—踏入Go语言世界的第一步!《100天精通Go语言(精品VIP版)》—踏入Go语言世界的第二步!领域矩阵:🌐猫头虎技术领域矩阵:深入探索各技术领域,发现知识的交汇点。了解更多,请访问:猫头虎技术矩阵新矩阵备用链接文章目录猫头虎分享已解决Bug||docker:Errorresponsefromdaemon:invalidmountconfigfo

c++ - 评估 C++ 字符串中的表达式 : "Hi ${user} from ${host}"

我正在寻找一种干净的C++方法来解析包含用${}包裹的表达式的字符串,并从以编程方式评估的表达式构建结果字符串。示例:如果我实现让“user”评估为“foo”的程序,“Hi${user}from${host}”将评估为“Hifoofrombar”等我正在考虑的当前方法包括一个状态机,该状态机一次从字符串中吃掉一个字符,并在到达“}”后计算表达式。有什么提示或其他建议吗?注意:boost::是最受欢迎的!:-)更新感谢前三个建议!不幸的是我让这个例子太简单了!我需要能够检查${}中的内容,所以这不是简单的搜索和替换。也许它会说${uppercase:foo}然后我必须使用“foo”作为H

c++ - 使用 std::streams 格式化输出

我有一个我希望能够流式传输的对象。但是我希望能够通过使用不同的格式以不同的方式流式传输它,或者我应该说描述这个对象的方法。我想知道这应该如何用流来解决。我想要的是能够使用通用格式并使用某种格式适配器将通用格式转换为首选格式。我还希望能够将格式与Item的实现分开,这样我就不必在每次添加或更改新格式时都更改Item。这段代码大致说明了我想要什么。Itemitem;std::cout但这可能是不可能的或不切实际的。面对这样的问题,流媒体库打算如何使用? 最佳答案 我个人会写一套格式化程序。格式化程序必须知道他们正在格式化的对象的内部结构