草庐IT

c++ - std::forward_iterator_tag 的作用是什么?

在分析一个应用程序时,我碰到了gcc4.7.1附带的那部分标准库实现。它是include/g++-v4/bits/vector.tcc:templatetemplatevoidvector::_M_range_insert(iterator__position,_ForwardIterator__first,_ForwardIterator__last,std::forward_iterator_tag){…}我注意到函数签名的最后一个参数只是一个标记,我开始想知道它为什么会在这里。快速浏览thispage表明std::forward_iterator_tag是一个空结构。它在这里的作

c++ - 在 C 中定义的 C++ 中向前声明枚举

我搜索了有关前向声明的信息,但没有找到任何方法来解决我的情况。所以这里是:1)有一个C-header文件,可以说是一个大型多组件软件的导出接口(interface),它包含一个枚举类型定义“导出.h”://Thisisin"C"!typedefenum_VM_TYPE{....,....,...,}VM_TYPE;2)C++中的一部分代码使用该导出。“cpp_code.cpp”://ThisisinC++#include"export.h"#include"cpp_header.hpp"{....usingVM_TYPEvaluestodostuffs....}“cpp_header.

c++ - 视觉 C++ : forward an array as a pointer

我已经将一些无法在VisualStudio2015上编译的C++11代码缩减为以下我认为应该编译的代码(并且使用clang和gcc):#includevoidtest(constchar*x);intmain(){constcharx[]="Helloworld!";test(std::forward(x));}我知道这里不需要调用forward。这是从一段更复杂的代码中删除的,该代码将可变参数中的任何数组衰减为指针并转发所有内容。我确信可以通过模板特化或SFINAE找到解决此问题的方法,但我想在走那条路之前知道它是否有效的C++。编译器是VisualStudio2015,问题可以重现

c++ - 前向声明和循环依赖

我有两个类,实体和级别。两者都需要访问彼此的方法。因此,使用#include,就会出现循环依赖的问题。因此,为了避免这种情况,我尝试在Entity.h中转发声明级别:classLevel{};然而,由于Entity需要访问Level中的方法,它无法访问这些方法,因为它不知道它们的存在。有没有办法在不重新声明实体中的大部分级别的情况下解决这个问题? 最佳答案 正确的前向声明很简单:classLevel;请注意缺少大括号。这告诉编译器有一个名为Level的类,但没有关于它的内容的信息。然后,您可以自由地使用指向这个未定义类的指针(Lev

c++ - 为什么需要转发返回值

在docstd::forward,它给出了以下示例:templatevoidwrapper(T&&arg){foo(forward(arg).get())>(forward(arg).get()));}这里为什么要转发返回值呢?它与以下代码不同的情况是什么:templatevoidwrapper(T&&arg){foo(forward(arg).get());} 最佳答案 让我们分解一下可能性。T::get可以返回一个左值引用(它是一个左值表达式)、一个右值引用(它是一个xvalue表达式)或一个纯右值。forward表达式会将左值

c++ - 为什么要为 std::forward_list 拼接整个列表或线性范围?

将范围从一个列表拼接到另一个列表可以在常数时间内完成,但代价是使size()的复杂度呈线性。C++11改变了std::list的情况,要求size()为常数时间。例如,这破坏了gcc的实现,参见[C++0x]std::list::sizecomplexity.除了splice()范围外,还有什么其他原因size()不能成为常量时间在早期,C++03符合std::listimplementations?为什么拼接整个列表或范围是线性的std::forward_list?参见splice_after(),案例(1)和(3)。另见standarddraftN3485中的23.3.4.6for

c++ - 将函数应用于元组的每个元素

给定一个类似于std::tuple的对象(即具有定义的tuple_size和get语义)和一个一元仿函数对象ftor,我希望能够在类似tuple的对象的每个元素上调用ftor。如果我忽略返回值,我知道int数组技巧:namespacedetails{templatevoidapply_unary(Ftor&&ftor,Tuple&&tuple,std::index_sequence){usingstd::get;intarr[]={(ftor(get(std::forward(tuple))),void(),0)...};}}//namespacedetailstemplatevoid

c++ - 使用 std::forward 而不是 std::move 来初始化对象有什么好处吗?

我有一个函数模板,它采用某种可调用类型的参数,并使用std::bind为原始可调用对象创建一个具有预定义参数值的新可调用对象。我用转发引用参数和std::forward编写了它,如下所示:templateautomake_example_caller(F&&f){returnstd::bind(std::forward(f),123,456,789);}cppreferencedocumentationforstd::bind表示绑定(bind)对象“包含一个由std::decay::type构造的std::forward(f)类型的成员对象”。由于std::bind将函数转发给它的内

c++ - std::forward_list 成员可以实现为静态的吗?

std::forward_list提供了insert_after和erase_after成员,它们可能不需要实际访问std::forward_list对象。因此,它们可以作为static成员函数实现,并且可以在没有列表对象的情况下被调用——对于想要从列表中删除自身的对象很有用,这是一种非常常见的用法。编辑:此优化仅适用于std::allocator或用户定义的无状态分配器的forward_list特化。符合标准的实现可以做到这一点吗?§17.6.5.5/3说AcalltoamemberfunctionsignaturedescribedintheC++standardlibrarybe

c++ - 为什么 `const int ci = 2; std::forward<int>(ci);` 不起作用以及如何修复/解决它?

简单的问题,为什么不thefollowing工作(意味着ci的拷贝)?#includeintmain(){constintci=2;std::forward(ci);}prog.cpp:Infunction'intmain()':prog.cpp:6:23:error:nomatchingfunctionforcallto'forward(constint&)'问题在编写一些模板内容时表现出来,我有一个简单的holder类型,如下所示。为了避免不必要的拷贝,我尽可能使用完美转发,但事实证明这似乎是问题的根源。templatestructholder{Tvalue;holder(T&&v