草庐IT

std-ranges

全部标签

c++ - 用户定义类型的 std::common_type 特征

自C++11以来,引入了类型特征std::common_type。std::common_type确定其所有模板参数之间的公共(public)类型。在C++14中,还引入了辅助类型std::common_type_t以缩短使用std::common_type类型特征的代码。std::common_type在重载算术运算符中特别有用,例如,templatestd::common_type_toperator+(T1const&t1,T2const&t2){returnt1+t2;}如果它的模板参数是内置类型(例如,int、double),它会工作得很好。但是,如果我将用户定义的类型作为模

c++ - 为什么 C++ 字符串不需要 std::forward 来调用所需的函数?

我正在学习std::forward。我写了一个简短的程序来测试如果我们在将参数转发给另一个函数调用之前不调用std::forward会发生什么:#include#include#includeusingnamespacestd;classExample{};ostream&operatorvoidtest_forward_wrapper(T&&arg){test_forward_inner(arg);}intmain(){Examplee;test_forward_wrapper(e);test_forward_wrapper(Example());cout在这里,我尝试将左值和右值从

c++ - std::string 停止在\0

我在使用std::string时遇到问题..问题是'\0'被识别为字符串的结尾,就像在类C的字符串中一样。例如下面的代码:#include#includeintmain(){std::strings("String!\0Thisisastringtoo!");std::cout输出这个:7String!这里有什么问题?std::string不应该像对待任何其他字符一样对待'\0'吗? 最佳答案 想一想:如果给定constchar*,您将如何确定哪里是真正的终止0,哪里是嵌入的0?您需要明确传递字符串的大小,或者从两个迭代器(指针?)

C++ std::get<变量> 失败

如何通过std::get使用变量索引元组?我有以下代码:#include#includeusingnamespacestd;intmain(){tupledata(5,10);for(inti=0;i(data)它因以下编译器错误而失败:prog.cpp:Infunction'intmain()':prog.cpp:10:39:error:thevalueof'i'isnotusableinaconstantexpressioncout(data)&)'cout(data)constexprtypenamestd::tuple_element>::type&std::get(std::

c++ - 我需要 std::atomic<bool> 还是 POD bool 足够好?

考虑这段代码://globalstd::atomicrun=true;//thread1while(run){/*dostuff*/}//thread2/*dostuffuntilit'stimetoshutdown*/run=false;我在这里需要与原子变量相关的开销吗?我的直觉是,bool变量的读/写或多或少是原子的(这是一个常见的g++/Linux/Intel设置),如果有一些写/读时序异常,我在线程1上的运行循环会停止一个结果是早晚通过,对于这个应用程序我不是很担心。还是我在这里遗漏了一些其他考虑因素?查看perf,我的代码似乎在std::atomic_bool::opera

c++ - 在 C++11 智能指针中存储 std::thread

在C++11及更高版本中,像这样直接将std::thread存储为类的成员时,有什么优点或缺点:std::threadmy_thread;与像这样将std::shared_ptr或std::unique_ptr存储到线程相反:std::shared_ptrmy_thread_ptr;是否有任何代码选项比其他选项更好?或者没关系,只需2种不同的方式来处理线程对象。 最佳答案 使用指针(或智能指针)成员可能有一些不太常见的原因,但对于常见用法,似乎是std::thread要么不适用,要么本身就足够灵活:我们可能希望更好地控制对象的生命周

c++ - 如何将来自 std::vector<short> 的数据存储在 std::vector<uint8_t> 中

我想做的是将数据存储在std::vector中在std::vector,将每个short分成两个uint8_t值。我需要这样做,因为我有一个只会发送std::vector的网络应用程序的,所以我需要转换为uint8_t以发送,然后在收到uint8_tvector时转换回来。通常我会做的(以及我在查找问题时看到的)是:std::vectornewVec(oldvec.begin(),oldvec.end());但是,如果我理解正确,这将采用每个单独的短值,截断为uint8_t的大小,并在我想要的相同时创建一个包含一半数据量和相同条目数的新vector条目数量翻倍的数据量。包含逆向过程的方

c++ - 是否可以使用 std::byte 作为枚举类的基础类型?

由于std::byte根据定义不是整数类型,因此以下片段格式错误:enumclassfoo:std::byte{bar=1,baz=2};在C++17中有没有办法做与此等效的事情?编辑:我不是要解决任何特定问题。显然enumclasswhatever:unsignedchar可以做到。但是,我希望std::byte更灵活一点,并且想知道这是否可能。 最佳答案 std::byte是definedbythestandard成为一个枚举类。因此,它有一个基础类型(unsignedchar)。所以你可以创建一个具有相同底层类型的枚举:enu

c++ - 为什么我不能将 std::unique_ptr 用作 "template<class> class"参数?

这段代码:#includetemplateclassPtr>classA{Ptrints;};usingB=A;产生以下错误(使用GCC6.3):a.cpp:6:28:error:type/valuemismatchatargument1intemplateparameterlistfor‘templateclassPtr>classA’usingB=A;^a.cpp:6:28:note:expectedatemplateoftype‘templateclassPtr’,got‘templateclassstd::unique_ptr’现在,我可以像这样解决这个问题:templateu

c++ - 为什么 std::map 有一个 find 成员函数?

我和一位同事正在讨论成员职能与非成员职能的相对优点。一个问题出现了:为什么std::map有一个find成员函数。我的回答是,虽然您可以在map上使用std::find,但您必须搜索键值对,或者使用find_if和例如一个lambda。然而,这是线性的,map.find提供了比线性时间更好的按键搜索。我最后断言,如果它可能是非成员(member),那么它本来就是!(尽管std::string表明我的概括可能有些草率)。我的同事指出,可以使用map.lower_bound以与非成员函数相同的方式实现find。map.find成为成员(member)是否有理由?