草庐IT

is_equal

全部标签

C++ move 语义 : why copy assignment operator=(&) is called instead of move assignment operator=(&&)?

我有以下代码:#include#includeusingstd::cout;structSomeType{SomeType(){}SomeType(constSomeType&&other){cout我希望move构造函数调用move赋值运算符。下面是这个程序的输出:SomeType(SomeType&&)operator=(constSomeType&)operator=(SomeType&&)如您所见,move赋值运算符已成功调用,但在move构造函数内分配给*this时未成功调用。为什么会发生这种情况,我能以某种方式解决它吗? 最佳答案

C++11 使用带有自定义比较函数的 std::equal_range

考虑这个例子(请注意,这只是我为了说明问题而编造的东西。我很清楚有更有效的方法来解析算术表达式,虽然这个主题很吸引人,但这与我的实际无关问题。这只是一个半现实的例子,如果我可以这样说的话。我同意解析器可能会使问题看起来更复杂,但我想不出更抽象的例子)。假设您想做一个简单的表达式解析器。您将从分词器中获取一些字符串,其中一些可能不明确。例如,字符串“-”可以表示一元减号或二进制减号。假设您想获得字符串“-”的所有可能含义。你可以这样做:1)定义一个描述所有可能运算符的排序数组//typesofoperatorsenumclassopType:char{unary,lasso,rasso,

c++ - std::is_constructible<T, Args> 是如何实现的?

这个问题在这里已经有了答案:C++98/03std::is_constructibleimplementation(4个答案)关闭5年前。到目前为止,我在网上找不到任何ELI5。对于一个学习项目,我想实现我自己的is_constructible。有人可以解释一下它是如何工作的吗?

c++ - 修复 GCC 中的 "comparison is always false ..."警告

我遇到了一个我确定很容易解决的问题,但我不知所措......我有一个执行以下代码的模板:Tvalue=d;if(std::numeric_limits::is_signed){if(value现在,出于显而易见的原因,当此代码针对无符号类型编译时,GCC会给我一个警告(由于数据类型的范围有限,比较总是错误的)。我完全理解这背后的原因,我进行了numeric_limits检查以查看是否可以让编译器关闭它(它适用于MSVC)。唉,在GCC下,我得到了警告。有什么办法(除了禁用警告,我什至不知道你是否可以使用GCC)来修复这个警告?代码永远不会被调用,我假设优化器也会编译它,但我无法摆脱警告

c++ - 为什么我在使用 dynamic_cast 和模板时收到错误 "A is an inaccessible base of B"?

为什么对f的调用没有解析为第一个函数重载?我收到错误:source.cpp:Infunction'intmain()':source.cpp:12:31:error:'A'isaninaccessiblebaseof'B'classA{};classB:A{};voidf(constA&){std::coutvoidf(T){std::cout(b));}请注意,如果我取出dynamic_cast,代码将起作用,但secondf被调用(它打印“Generic”)。但我想做的是接到第一个电话。我认为dynamic_cast会起作用,但由于某种原因它会导致问题。我在这里做错了什么?

c++ - 在 C++ 中 : why does a constructor get called when an array of objects is declared?

MyClassmc2[]={MyClass(),MyClass()};//thiscallstheconstructortwiceMyClassmc1[4];//thiscallstheconstructor4times.Why?所以,我的问题是:为什么没有初始化的对象数组声明会导致调用默认构造函数? 最佳答案 在C++中,大小为4的MyClass数组是四个实际对象。它有点像包含该类型的四个成员的结构,当然您可以使用不同的语法访问这些成员,并且存在其他技术差异。因此,定义该数组导致构建4个对象的原因(并且在大致相同的情况下)与定义该

c++ - 使用 std::is_same,为什么我的函数仍然不能用于 2 种类型

我正在尝试编写一个可以打印堆栈和队列的函数,我的代码如下templatevoidprint_container(Cont&cont){while(!cont.empty()){if(std::is_same>::value){autoelem=cont.top();std::coutstk;stk.push(1);stk.push(2);stk.push(3);queueq;q.push(1);q.push(2);q.push(3);std::cout但是这里不行,错误信息是:demo_typeof.cpp:35:30:error:nomembernamed'front'in'std:

c++ - 为什么像 std::is_permutation() 这样的函数本质上不是不安全的?

在过去十年左右的时间里,C和C++程序员因经常未能执行正确的边界检查而遭受打击,尤其是在字符串上。这些故障通常会导致主要软件产品出现严重的安全问题。由于缓冲区溢出的不安全性变得广为人知,建立适当的边界检查的动力使许多程序员远离了传统的缓冲区和字符串操作函数,如strcpy()。和sprintf()至少部分是因为这些函数倾向于通过对目标缓冲区的大小进行假设来引发缓冲区溢出问题。STL类型的优点之一,如std::string和std::vector是他们对缓冲区访问的强大控制。但是有一件事让我很困惑。中许多最广泛使用的功能C++头文件似乎积极地乞求溢出滥用:具体来说,那些采用begin的函

C++ is_member_pointer 实现

在c++标准库中,is_member_pointer实现为templatestruct__is_member_pointer_helper:publicfalse_type{};templatestruct__is_member_pointer_helper:publictrue_type{};///is_member_pointertemplatestructis_member_pointer:public__is_member_pointer_helper::type>::type{};有人可以解释一下_Cp是如何推导出来的吗?它像魔术一样工作。 最佳答

c++ - std::is_const 将 const 指针标识为非常量

我很困惑std::is_const识别const的行为指针为非const.我自己的实现is_const做完全一样的事情。我不确定为什么更通用的模板化结构正在挑选版本。gcc4.7和clang3.1-svn表现出相同的行为。任何人都可以解释发生了什么事吗?代码如下:#include#include#includeclassCEmptyClass{};namespacejbc{templatestructis_const:std::false_type{};templatestructis_const:std::true_type{};}intmain(intargc,char*argv[