草庐IT

-std=gnu99

全部标签

c++ - std::move 的未定义行为

来自movepage的cppreferenceUnlessotherwisespecified,allstandardlibraryobjectsthathavebeenmovedfromareplacedinavalidbutunspecifiedstate.Thatis,onlythefunctionswithoutpreconditions,suchastheassignmentoperator,canbesafelyusedontheobjectafteritwasmovedfrom因此,从同一页面上的示例来看,下面的代码被认为是未定义的行为vectorv_string;str

c++ - 无法将派生比较传递给 std::priority_queue

我需要将派生比较器传递给std::priority_queue,但由于某种原因,正在调用基类的operator()。这是显示此行为的最小代码:classBase{public:virtualbooloperator()(intl,intr)const{cout,Base>pq((A()));pq.push(1);pq.push(2);pq.push(3);pq.push(0);coutThecodeisavailableonideoneaswell请注意,我不能使用priority_queue,A>,因为我还有其他子类Base,这将导致大量代码重复1。我做错了什么?如何将比较器传递给将

c++ - 使用带有匿名类型参数的 std::enable_if

我尝试将std::enable_if与未使用和未命名的类型参数一起使用,以免扭曲return类型。但是,以下代码无法编译。#includetemplate::value>>Tfoo(){std::cout::value>>Tfoo(){std::cout();foo();}编译器说:7:3:error:redefinitionof'templateTfoo()'4:3:note:'templateTfoo()'previouslydeclaredhereInfunction'intmain()':11:12:error:nomatchingfunctionforcallto'foo()

c++ - 如何格式化 std::chrono 持续时间?

有没有方便的方法将std::chrono::duration格式化为指定格式?std::chrono::high_resolution_clock::time_pointnow,then;then=std::chrono::high_resolution_clock::now();//...now=std::chrono::high_resolution_clock::now();autoduration=now-then;//baseinmicroseconds:autotimeInMicroSec=std::chrono::duration_cast(duration);如何将ti

c++ - 奇数平台上的 std::byte

阅读HerbSutter关于最近C++标准session的博客文章,它注意到std::byte已添加到C++17。作为初步阅读,我有些担心,因为它使用unsignedchar来避免严格别名规则的复杂性。我最担心的是,它如何在CHAR_BIT不是8的平台上工作?我曾在/使用过CHAR_BIT为16或32的平台(通常是DSP)。鉴于std::byte用于处理“面向字节的内存访问”,并且大多数人将byte理解为指示八位字节(而不是底层字符类型的大小),这将如何工作对于希望这将解决连续8位内存块的个人?我已经看到有人假设CHAR_BIT是8(不知道CHAR_BIT存在...)。称为std::b

c++ - 将 std::atomic_flag 包装在 getter/setter 中是否会使它的 "atomicity"无效?

假设我有一个包含std::atomic_flag作为私有(private)成员的类,通过getter公开。类似于以下内容(伪代码):classThing{private:std::atomic_flagready=ATOMIC_FLAG_INIT;public:isReady(){returnready.test_and_set();}}我天真的问题是:通过方法查询标志是否会将其变成非原子操作,成为非原子函数调用(或者是?)?我是否应该让我的ready标记为公共(public)成员并直接查询它? 最佳答案 不,它没有。test_an

c++ - std::async 不能异步工作

我有以下非常简单的代码:voidTestSleep(){std::cout因为我使用std::launch::async我希望TestSleep()将异步运行并且我将得到以下输出:TestAsyncTestAsyncok!!!TestSleepTestSleepOk但实际上我有同步运行的输出:TestAsyncTestSleepTestSleepOkTestAsyncok!!!您能解释一下为什么以及如何使TestSleep真正异步调用吗。 最佳答案 来自thisstd::asyncreferencenotessectionIfthe

c++ - 具有模板模板参数的模板定义,可以专门化为类,例如,std::vector<std::string> 或 std::map<std::tree>

我想创建一个模板类,可以容纳容器和容器的任意组合。例如,std::vector或std::map,例如。我尝试了很多组合,但我必须承认模板的复杂性让我不知所措。我编译的关闭是这样的:templateclassContainer>classGenericContainer{ContainermLemario;};虽然它编译到目前为止,然后,当我想实例化它时,我会收到很多错误。MyContainermyContainer;我是否使用了正确的方法来创建那种类? 最佳答案 对于std::vector(以及类似的)@songyuanyao提供

c++ - 没有用于使用可变参数调用 std::forward(const std::string &) 的匹配函数

我正在尝试为不可复制、不可移动的类制作一个可移动的包装器,但是我在将conststd::string变量传递给构造函数时遇到问题。下面的最小示例会产生以下错误:#include#include#include#includestructX{std::stringx;X(conststd::string&x):x(x){}X(constX&x)=delete;X(X&&x)=delete;};structWrapper{std::unique_ptrx;Wrapper(constWrapper&wrapper)=delete;Wrapper(Wrapper&&wrapper)=defau

c++ - 将 std::weak_ptr 传递给函数有用吗?

我正在阅读thisarticle由HerbSutter撰写,关于将智能指针传递给函数。他没有提到std::weak_ptr,老实说,我找不到传递这种智能指针有用的好场景。函数是否拥有所有权?传递std::shared_ptr。函数是否只需要对底层对象进行操作?传递原始指针或引用。那么将std::weak_ptr传递给函数是否100%没用? 最佳答案 Soispassingstd::weak_ptrtofunctions100%useless?没有。考虑这个玩具示例。structPointerObserver{std::weak_pt