草庐IT

std-ranges

全部标签

c++ - `constexpr` `std::array` 的二元运算

我想写一个constexpr函数,减少给定的std::array用二元运算。IE。实现的函数templatereduce(std::array,binary_function);为了简单起见,我想从加法开始。例如sum(std::array{{1,2,3,4,5}});//returns15.到目前为止我得到了什么。我使用常用​​的索引技巧来索引数组元素。IE。生成int序列,可用于通过参数列表扩展进行索引。templatestructseq{};templatestructgen_seq:gen_seq{};templatestructgen_seq:seq{};//gen_seq-

c++ - 将 std::exception_ptr 转换为 boost::exception_ptr

我想使用boost::promise::set_exception()需要一个boost::exception_ptr。问题是boost:exception_ptr似乎只有在我用enable_current_exception包裹所有我的抛出时才能正常工作,我想避免这种情况。(无论如何,我无法为第3方图书馆做到这一点。)我在整个代码中使用std::exception_ptr/std::current_exception,所以我正在寻找一种方法来传递std::exception_ptr,其中boost:exception_ptr是预期的。执行以下操作但编译的东西:boost::excep

c++ - 具有直接输出缓冲区/字符串结果访问的 std::stringstream,避免复制?

是否有std::stringstream的规范/公共(public)/免费实现变体,我每次调用时都不需要为完整的字符串拷贝付费海峡()?(可能通过在osteam类中提供直接的c_str()成员?)我在这里发现了两个问题:C++stlstringstreamdirectbufferaccess(是的,它基本上是相同的标题,但请注意,它被接受的答案根本不适合这里的问题。)Streamfromstd::stringwithoutmakingacopy?(同样,接受的答案与这个问题不匹配。)“当然”还有已弃用的std::strstream类确实允许直接缓冲区访问,尽管它的接口(interfac

c++ - 为右值特化 std::swap

在标准(20.2.2[utility.swap])中,std::swap是为左值引用定义的。我知道当你想交换两件事时,这是常见的情况。然而,有时交换右值是正确且可取的(当临时对象包含引用时,如下所示:swaptemporarytuplesofreferences)。为什么右值没有重载?对右值进行无意义交换的风险是否超过潜在yield?是否有合法的方式来支持交换包含引用的右值std::tuple对象?对于用户定义的类型,我会特化swap以按值接受其参数,但对于像std::tuple这样的库类型做同样的事情似乎不太合乎规范。 最佳答案

c++ - 将 std::function 代理到需要参数数组的 C 函数

我正在处理一个提供这种形式的钩子(Hook)的C系统:int(*EXTENSIONFUNCTION)(NATIVEVALUEargs[]);可以注册一个EXTENSIONFUNCTION和它需要的参数数量。我的想法是创建一个类Extension来包装一个扩展。它可以从std::function(或者任何Callable,理想情况下,但我们现在只说它包含一个std::function)构造。扩展采用Value参数,这些参数包含NATIVEVALUE(但更大)。例如,我会使用sizeof...(Ts)自动处理参数计数。它可能看起来像这样:Extensionfoo=[](lib::Integ

c++ - std::future::wait_for 虚假唤醒?

std::condition_variable::wait_for采用可选谓词在内部处理虚假唤醒。std::future::wait_for没有任何此类可选参数。如果我想确保等待指定的超时时间至少,或者是否已经以其他方式处理,是否需要防止虚假唤醒? 最佳答案 只有条件变量可以“虚假地”唤醒。显然,允许虚假唤醒简化了某些系统上条件变量的实现。(C++编程语言第4版。) 关于c++-std::future::wait_for虚假唤醒?,我们在StackOverflow上找到一个类似的问题:

c++ - 如何有效地将 std::vector 视为 C 缓冲区?

对于Cbuffer,我经常这样做:BYTEbuffer[MAX_SIZE];intdataSize=0;while(appRunning()){dataSize+=Receive(buffer+dataSize,MAX_SIZE-dataSize);intprocessedSize=ProcessBuffer(buffer,dataSize);ASSERT(processedSize是否可以在不损失太多性能的情况下使用std::vector这样做?编辑:我找到了一种用std::vector替换原始C缓冲区的方法。std::vectorvbuf;vbuf.reserve(MAX_SIZE

c++ - 使用 std::string 在 DLL 中创建类。 C4251 警告

我想在DLL中实现一个简单的类,例如:classMY_EXPORT_IMPORTMyClass{public://std::stringanyPublicStr;//seepoint3protected:std::stringanyStr;};问题是VisualC++编译器(在本例中为2013)抛出以下警告:C:...MyClass.hpp:X:warning:C4251:'MyClass::postfix':class'std::basic_string,std::allocator>'needstohavedll-interfacetobeusedbyclientsofstruct

c++ - 解决 std::showbase 不加前缀零的问题

无法在线找到帮助。有什么办法可以解决这个问题?std::showbase只为非零数字添加前缀(例如,0x在std::hex的情况下)(如解释here)。我想要一个格式化为0x0的输出,而不是0.但是,仅使用:std::cout不是一个选项,因为右侧参数可能并不总是整数(或等价物)。我正在寻找一个showbase替代品,它会在0前加上0x而不是扭曲非整数(或等价物),像这样:usingnamespacestd;/*Desiredresult:*/cout非常感谢。 最佳答案 尝试std::cout此方式号码将以0x为前缀总是,但你必须

c++ - std::condition_variable::wait with predicate

在std::condition_variable的文档中,有一个以谓词函数作为参数的wait()重载。该函数将等到谓词函数为真的第一个wake_up。在documentation据说这等同于:while(!pred()){wait(lock);}还有:Thisoverloadmaybeusedtoignorespuriousawakeningswhilewaitingforaspecificconditiontobecometrue.Notethatbeforeentertothismethodlockmustbeacquired,afterwait(lock)exitsitisals