草庐IT

move_if_noexcept

全部标签

c++ - "if"语句对性能有多大影响?

有一些不同大小的IPTables(例如255或16384或512000!!)。每个表的每个条目都包含一个唯一的IP地址(十六进制格式)和一些其他值。IP总数为800万。所有IPTables的所有IP都排序我们需要每秒搜索IPTable300,000次。我们目前查找IP的算法如下://10_ipTable[i].start&&ip可以看出,在最坏的情况下,给定IP地址的比较次数为_rangeCount*2,“if”语句检查的次数为_rangeCount。假设我想更改searchIPTable并使用更有效的方法在IPTables中查找IP地址。据我所知,对于排序数组,二进制搜索等著名搜索算

c++ - 带有 std::enable_if 和 std::is_default_constructible 的 SFINAE 用于 libc++ 中的不完整类型

我刚刚在使用SFINAE检测模板类型是否默认可构造时观察到libc++的一个奇怪问题。以下是我能够想出的一个最小示例:#include#includetemplatestructDummy;templatestructDummy{};templatestructhas_dummy:std::false_type{};templatestructhas_dummy>::value>>:std::true_type{};intmain(){std::cout{}(){}()它编译并输出预期的行true和false使用libstdc++使用g++或clang++编译时.但是,当我尝试使用li

c++ - 为什么 SFINAE (enable_if) 从类定义内部工作而不是从外部工作

过去几个小时我一直在努力解决一个非常奇怪的问题(在用SFINAE解决了5-6个其他问题之后,因为我是新手)。基本上在下面的代码中,我想让f()为所有可能的模板实例化工作,但是g()仅在N==2:#include#includetemplateclassA{public:voidf(void);voidg(void);};templateinlinevoidA::f(){std::cout::type*=nullptr>inlinevoidA::g(){std::coutobj;obj.f();obj.g();return0;}当我尝试编译它时,我收到一个关于有3个而不是两个模板参数的错

c++ - 对于具有抛出复制构造函数和 noexcept 按值复制赋值的类,is_nothrow_copy_assignable 的值是多少?

根据C++标准,以下程序的预期(如果有)输出是什么:#include#include#includeclassA{public:A()=default;~A()=default;A(Aconst&other){}A(A&&other)noexcept{}A&operator=(Aother)noexcept{return*this;}};intmain(){std::cout::value::value换句话说,类型特征值的评估是否只看赋值运算符的声明,即noexcept,并因此产生truetrue或者它是否考虑调用上下文(a、b是A的实例)a=b;//maythrow,implici

c++ - 循环 : future iterations overwrite results of previous iterations 中的 If-else 条件

我尝试在items列表中突出显示selectedItem及其children。constQListitems=/*...*/;Item*selectedItem=/*...*/;Q_FOREACH(Item*item,items){if(selectedItem==item){item->setHighlightEnabled(true);//Highlightselecteditem}else{item->setHighlightEnabled(false);//De-highlightotheritems}}item->setHighlightEnabled方法递归地对子项执行相同

c++ - 我是唯一一个觉得 std::move 有点太难理解的人吗?

所以我一直在SO和其他地方阅读有关std::move、std::forward、右值、左值广告等的内容。但我发现我无法把握它。尽管我有时会进行修复,但我认为我了解有关指针、引用等的基本知识,这些都是在此之前在C++中的。是我还是这些东西变得太重了? 最佳答案 如果您还没有阅读原始提案,我建议您阅读:AProposaltoAddMoveSemanticsSupporttotheC++Language它非常清楚地列出了可以使用右值引用和move语义解决的问题,以及如何使用右值引用和move语义来解决这些问题。标准委员会的文件往往内容繁多

c++ - 为什么 std::move() 没有 _Remove_reference 就不能工作?

如您所知,_Remove_reference的存在是为了将T&转换为T或将T&&转换为T。我怀着一种玩乐的心情写了下面的代码,它根本没有像我预期的那样工作,但不知道为什么。templatestruct_Remove_reference{//removereferencetypedef_Ty_Type;staticvoidfunc(){cout//struct_Remove_reference//{//removereference//typedef_Ty_Type;//staticvoidfunc(){cout//struct_Remove_reference//{//removerv

c++ - if ('fstream object' ) 如何根据文件是否打开返回真值或假值?

我很好奇fstreamclass是如何简单地返回一个true或false值的将对象的名称放在条件语句中。例如……std::fstreamfileStream;fileStream.open("somefile.ext");if(!fileStream)//Howdoesthiswork?std::cout我问这个是因为如果我以类似的方式使用它,我希望我自己的类返回一个值。 最佳答案 它并不是真的等于真或假,而是它重载了!运算符以返回其状态。参见http://www.cplusplus.com/reference/iostream/i

c++ - 具有 move 构造函数和赋值的类的默认复制构造函数和赋值

假设我有这个类(class):classTest{public:Test();};据我所知,编译器提供了默认的复制构造函数和赋值运算符,它们将其他实例的每个成员分配给当前实例。现在我添加move构造函数和赋值:classTest{public:Test();Test(Test&&other);Test&operator=(Test&&other);};这个类是否仍然包含编译器生成的复制构造函数和赋值运算符,或者我需要实现它们?编辑。这是我的测试:classTest{public:Test(){}Test(Test&&other){}Test&operator=(Test&&other)

java - 在现在的C++和Java中,double类型和float类型: if (x == 0. 0)是正确的吗?

这个问题在这里已经有了答案:doublearithmeticandequalityinJava(3个答案)关闭8年前。根据我的旧知识:当我们想要检查double或float是否等于0.0时,我们不应该这样写:doublex=0.0;if(x==0.0)System.out.println("yes");elseSystem.out.println("no");但是几分钟前,我在Java(1.7)和C++(AppleLLVM6.0版)下再次尝试了,这样写是没有问题的!我分别在Java和C++下尝试了“double”类型和“float”类型。我的问题:我是不是漏掉了什么,或者我们真的可以检