草庐IT

c++ - 在更改文件描述符 1 以引用不同的文件后,我应该如何管理::std::cout?

我想做dup2(fd,1);close(fd);并让::std::cout写入新的fd1.如何重置::std::cout所以没有什么好笑的?例如,预先冲洗是否足够?或者还有更多事情要做?我也很好奇::std::cin的相同之处。如果您更改了它们在它们下面使用的文件描述符,是否有重置它们的标准机制?明确地说,我的目标基本上是将我自己的输入和输出重定向到其他地方。我不想让进程无意中在其父级的标准输出上打嗝或试图从其父级的标准输入中消耗任何东西。而且我再也不想碰我parent的标准输入或标准输出了。我想忘记它们曾经存在过。我尤其不想无意中将输出发送到我parent在不同文件描述符上使用的同一

c++ - 自定义转换运算符的 Clang 歧义

我一直在开发一种适配器类,当我在clang下遇到问题。当定义了左值引用和右值引用的转换运算符时,您会在尝试从您的类中移出时遇到歧义编译错误(当这样的代码应该没问题时,如operatorconstT&()const&仅允许用于左值AFAIK)。我用简单的例子重现了错误:#includeclassStringDecorator{public:StringDecorator():m_string("Stringdatahere"){}operatorconststd::string&()const&//lvalueonly{returnm_string;}operatorstd::strin

c++ - 我可以在 C++ 中仅使用 std::atomic 而不使用 std::mutex 安全地跨线程共享变量吗?

我制作了一个在多核上计算素数的程序。(请忽略该算法并非完全有效,这里将数字0和1视为质数。目的只是练习使用线程。)变量taken(接下来要测试的数字)正在8个线程之间共享。问题是它可以由一个线程递增,紧接着由另一个线程递增,并在它已经递增两次(或更多次)时被它们读取,因此可以跳过一些值,这是一件坏事。我以为它可以通过使用std::atomic_uint作为变量类型来解决,但我显然错了。有什么方法可以在不需要使用std::mutex的情况下解决这个问题,因为我听说它会导致相当大的开销?源代码:#include#include#include#include#include#include

c++ - std::vector 和 std::list 的重载运算符

我想重载operator对于std::list和std::vector使用以下代码。但是两者的功能几乎是一样的。有什么方法可以将它们组合起来,即,创建一个更通用的重载?#include#include#include#includetemplatestd::ostream&operator&v){if(!v.empty())std::copy(v.begin(),v.end(),std::ostream_iterator(out,","));returnout;}templatestd::ostream&operator&v){if(!v.empty())std::copy(v.beg

c++ - 如何使用 lambda 作为 std::unique_ptr 的删除器?

检查以下设计的程序:#include#includetemplateusingUniPtr=std::unique_ptr>;int*alloc(){returnnewint;}UniPtrfunc(){autodealloc=[](int*p){deletep;};returnUniPtr{alloc(),dealloc};}intmain(){autop=func();return0;}来自std::functionconstructormanual,我认为构建std::function对象可能会抛出异常,即使这个比例很低:UniPtrfunc(){autodealloc=[](i

c++ - lambda 如何在 MSVC2017 15.9.3 with/std :c++17? 中使用静态本地错误返回值

下面的示例代码打印来自lambda函数的值,该函数简单地递增并返回静态局部计数器变量的值。它打印0,1和2,3正如预期的那样,gcc和C++17的clang。但在VisualStudioCommunity201715.9.3中没有/std:c++17设置-它打印0,0和2,3相反。#includeintmain(){autof=[]{staticinti=0;returni++;};constintv1=f();//Expectv1=0constintv2=f();//Expectv2=1//Printsthewrongvalues(MSVC15.9.3with/std:c++17)s

c++ - 为什么我得到 std::exp 的平台特定结果?

这个问题在这里已经有了答案:Isfloatingpointmathbroken?(31个答案)MathprecisionrequirementsofCandC++standard(1个回答)关闭3年前。我有一个程序在Android和Windows下给出了截然不同的结果。当我根据包含预期结果的二进制文件验证输出数据时,即使差异很小(舍入问题)也很烦人,我必须找到一种方法来修复它。这是一个示例程序:#include#include#includeintmain(intargc,char*argv[]){//thisvaluewasidentifiedasproducingdifferent

c++ - 在编译时像未知边界数组一样初始化 C++ 结构

我可以写这个并且它工作得很好:structFoo{inti;std::strings;};constFoofoo[]={{42,"theanswertotheultimatequestions"},{23/*initializingonlythefirstmember,'s'getsthedefaultvalue*/}};我想做的是用一个结构来包装数组,这样我就可以向它添加方法:templatestructMap{std::array,Count>mappings;//or//std::pairmappings[Count];V1operator()(constV2&)const;V2

c++ - 为什么这个不正确的 std::function 初始化使用 MSVC 编译?

今天遇到一个有趣的问题,由我自己的错字引起。我创建了一个lambda,它接收对结构的引用,并错误地将其设置为std::function,该函数按值接收它的参数。这是一个更简洁的版本:#includestructInputStruct{inti;InputStruct():i(1){}};voidfunction_rcv(std::function&func_ref){InputStructin;func_ref(in);}intmain(){std::functionmy_func=[](InputStruct&in)->bool{returnin.i==1;};function_rc

c++ - 如何在成对集合上使用 lower_bound()?

我给了一个std::set>和一个整数x,我必须找到第一个元素大于或等于给定整数x的第一对的迭代器.我了解到如果s是set>和{x,y}是一对然后我可以使用s.lower_bound({x,y}).但是,就我而言,我只需要关心第一个元素x.所以,我的问题是如何使用lower_bound在set>当我只关心第一个元素时? 最佳答案 核心问题是你的std::set实例已经排序,但默认为std::pairoperator.您不能直观地使用成员函数std::set::lower_bound,因为它使用了其类类型的比较函数。你不能使用std: