草庐IT

move_function_imp

全部标签

c++ - C2556 : overloaded function differs only by return type

我正在阅读EffectiveC++,它告诉我“可以重载仅因常量不同而不同的成员函数”。书中的例子是:classTextBlock{public:constchar&operator[](std::size_tposition)const;char&operator[](std::size_tposition);private:std::stringtext;}我下面的示例使用了一个存储指针。classA{public:A(int*val):val_(val){}int*get_message(){returnval_;}constint*get_message(){returnval_

c++ - 继续获取 "error: use of undeclared identifier ' cout' 和错误 : reference to overloaded function could not be resolved

我正在编写一个使用许多不同函数的排序程序,你们都可以从我的声明。但是,当我尝试编译和运行我的程序时,我不断遇到这些相同的错误它们如下:error:useofundeclaredidentifier'cout';didyoumean'count'?couterror:referencetooverloadedfunctioncouldnotberesolved;didyoumeantocallit?couterror:useofundeclaredidentifier'endl';didyoumean'end'?cout我不太确定为什么会出现这些错误....我想我已经包含了我需要的一切为

c++ - 什么时候添加 move 构造函数和 move 赋值运算符才会真正开始有所作为?

考虑到当今编译器在返回值优化(RVO和NRVO)方面的高质量,我想知道开始添加move构造函数和move赋值运算符实际上对什么类复杂性有意义。例如,对于这个really_trivial类,我只是假设move语义不能提供比RVO和NRVO在复制它的实例时已经做的更多的东西:classreally_trivial{intfirst_;intsecond_;public:really_trivial();...};在这个semi_complex类中,我会毫不犹豫地添加move构造函数和move赋值运算符:classsemi_complex{std::vectorstrings_;public

c++ - 为什么宏 __STL_FUNCTION_TMPL_PARTIAL_ORDER 应该将模板函数包含在 std_pair.h 中

今天在STL_pair.h中看到如下代码:#ifdef__STL_FUNCTION_TMPL_PARTIAL_ORDERtemplateinlinebooloperator!=(constpair&__x,constpair&__y){return!(__x==__y);}templateinlinebooloperator>(constpair&__x,constpair&__y){return__y我不认为模板函数与偏特化有任何关联的功能模板。我错了吗? 最佳答案 编译器如何处理函数调用在C++中调用函数模板经历了名称查找(标准

c++ - 按值传递和 move ,或两种方法

这个问题在这里已经有了答案:WhyisvaluetakingsettermemberfunctionsnotrecommendedinHerbSutter'sCppCon2014talk(BacktoBasics:ModernC++Style)?(4个答案)关闭7年前。假设我有以下类,它有一个方法set_value。哪种实现方式更好?classS{public://aset_valuemethodprivate:Some_typevalue;};按值传递,然后movevoidS::set_value(Some_typevalue){this->value=std::move(value

c++ - 无法在 C++ 中重载构造函数

我正在制作一个只移动的等价于std::function的函数。move_function包含指向基类的指针,move_function_base类型删除底层仿函数类型。move_function_imp继承自move_function_base并保存类型化的底层仿函数。move_function_imp定义如下:templateclassmove_function_imp:publicmove_function_base{typenamestd::remove_reference::typef_;public:virtualReturnTypecallFunc(ParamTypes&&

C#如何在不使用file.move的情况下重命名文件

我有一个连接到服务器的C#应用​​程序,获取DataGrid,操纵每一行,然后根据每个更新的行,新行被上传到服务器,每行每行都会在HDD上重命名一个文件。该应用程序的工作状态完全不错,但我与Profiler进行了分析,并意识到这条代码:File.Move(symbolsOldPath,symbolsPath);我的应用程序需要花费80%的时间来完成其任务。如果有一种不同的表现方式,我经历了所有问题和其他问题,但我并没有成功。我发现唯一的另一种方式是实现VB使用重命名方法,但是正如它称为文件一样。移动方法没有改进。你们是否知道另一种表现更好的方式?这是更改数据的类的代码。publicDataTa

无法移动选定的资源组合。 MOVE请求中缺少资源:“ XXX”。

我有一个看起来像这样的资源组:应用程序服务计划UispWestEuServerFarm仅包含单个应用程序:evisserver.当我尝试将Evisserver与UISPWESTEUSERVERFARM一起移动到另一个资源组时,我会发现一个错误:无法移动选定的资源组合。资源:'/blabla/resourcegroups/vyvojari.sk/providers/microsoft.web/sites/vyvojari-sk-dev'来自移动请求中缺少。请选择源订阅和资源组中的所有资源,以便它们可以一起移动。(代码:BadRequest,目标:Microsoft.web/serverfarms

C++ 设计 : Overloading/Overriding many many functions, 的清理方式?

我在这里尝试实现的案例是一个基类,它有一个函数(我们称之为modify_command),它实际上可以接受许多不同的类型,因此派生类可以实现它们认为合适的modify_command函数。现在我在基类中有一些类似的东西:classBase{templatevoidmodify_command(Commandcmd){std::cout(cmd);//Callsthetemplatedfunction}virtualvoidmodify_command(SpecificCommandBcmd){modify_command(cmd);//Callsthetemplatedfunction

c++ - 单步执行 std::function 调用时如何跳过 std 命名空间中的方法调用? (使用 GDB。)

如果我需要通过std::function调用,使用调试器单步执行函数对象可能会非常困惑。是否可以通过某种方式跳过这些帧? 最佳答案 gdb7.4为此添加了skip系列命令。(gdb)aproposskipinfoskip--Displaythestatusofskipssetstep-mode--Setmodeofthestepoperationshowstep-mode--Showmodeofthestepoperationskip--Ignoreafunctionwhilesteppingskipdelete--Deletesk