草庐IT

operator-arrow-star

全部标签

c++ - 为什么不为 std::vector 重载 operator+=()?

我已经开始学习C++,所以由于缺乏知识/经验,我不知道为什么像我将要描述的那样对新手来说如此简单的东西现在还没有出现在STL中。要将vector添加到另一个vector,您必须输入:v1.insert(v1.end(),v2.begin(),v2.end());我想知道在现实世界中人们是否只是重载+=运算符以使其不那么冗长,例如templatevoidoperator+=(std::vector&v1,conststd::vector&v2){v1.insert(v1.end(),v2.begin(),v2.end());}那么你就可以了v1+=v2;我还为push_back设置了这个

c++ - 为什么不为 std::vector 重载 operator+=()?

我已经开始学习C++,所以由于缺乏知识/经验,我不知道为什么像我将要描述的那样对新手来说如此简单的东西现在还没有出现在STL中。要将vector添加到另一个vector,您必须输入:v1.insert(v1.end(),v2.begin(),v2.end());我想知道在现实世界中人们是否只是重载+=运算符以使其不那么冗长,例如templatevoidoperator+=(std::vector&v1,conststd::vector&v2){v1.insert(v1.end(),v2.begin(),v2.end());}那么你就可以了v1+=v2;我还为push_back设置了这个

c++ - 为什么 auto_ptr<T> 没有定义 operator!() ?

标题几乎概括了我的问题。为什么不能做以下检查空指针?auto_ptrp(some_expression);//...if(!p)//error必须改为这样做:if(!p.get())//OK为什么不auto_ptr只需拥有operator!()定义? 最佳答案 它的设计似乎有错误。这将在C++0x中修复。unique_ptr(替换auto_ptr)包含explicitoperatorbool()const;引用新C++标准:Theclasstemplateauto_ptrisdeprecated.[Note:Theclasstemp

c++ - 为什么 auto_ptr<T> 没有定义 operator!() ?

标题几乎概括了我的问题。为什么不能做以下检查空指针?auto_ptrp(some_expression);//...if(!p)//error必须改为这样做:if(!p.get())//OK为什么不auto_ptr只需拥有operator!()定义? 最佳答案 它的设计似乎有错误。这将在C++0x中修复。unique_ptr(替换auto_ptr)包含explicitoperatorbool()const;引用新C++标准:Theclasstemplateauto_ptrisdeprecated.[Note:Theclasstemp

c++ - void operator()() 的功能

我对voidoperator()()的功能感到困惑。你能告诉我,例如:classbackground_task{public:voidoperator()()const{do_something();do_something_else();}};background_taskf;std::threadmy_thread(f);这里,为什么我们需要operator()()?第一个和第二个()是什么意思?其实,普通算子的操作我都知道,但是这个算子比较困惑。 最佳答案 你可以重载()操作符来调用你的对象,就好像它是一个函数:classA{

c++ - void operator()() 的功能

我对voidoperator()()的功能感到困惑。你能告诉我,例如:classbackground_task{public:voidoperator()()const{do_something();do_something_else();}};background_taskf;std::threadmy_thread(f);这里,为什么我们需要operator()()?第一个和第二个()是什么意思?其实,普通算子的操作我都知道,但是这个算子比较困惑。 最佳答案 你可以重载()操作符来调用你的对象,就好像它是一个函数:classA{

c++ - 删除 operator=(Type type) 就够了吗?

对于不可移动类型,以下内容是否足够(从最佳实践的角度来看)?classA{A(constA&)=delete;A(A&&)=delete;A&operator=(A)=delete;public:A();};或者我必须单独删除复制/移动赋值运算符吗?这里还需要析构函数吗? 最佳答案 是的,将复制构造函数和复制赋值运算符声明为deleted就足够了。由于您要声明复制构造函数和复制赋值运算符,因此不会自动生成移动构造函数和移动赋值运算符。您不需要显式声明它们deleted。来自§12.8/9(已添加重点)Ifthedefinitiono

c++ - 删除 operator=(Type type) 就够了吗?

对于不可移动类型,以下内容是否足够(从最佳实践的角度来看)?classA{A(constA&)=delete;A(A&&)=delete;A&operator=(A)=delete;public:A();};或者我必须单独删除复制/移动赋值运算符吗?这里还需要析构函数吗? 最佳答案 是的,将复制构造函数和复制赋值运算符声明为deleted就足够了。由于您要声明复制构造函数和复制赋值运算符,因此不会自动生成移动构造函数和移动赋值运算符。您不需要显式声明它们deleted。来自§12.8/9(已添加重点)Ifthedefinitiono

c++ - 什么是 C++ 中的 ->* 运算符?

C++继续让我感到惊讶。今天我发现了->*运算符。它是可重载的,但我不知道如何调用它。我设法在类里面重载它,但我不知道如何调用它。structB{inta;};structA{typedefint(A::*a_func)(void);B*p;inta,b,c;A(){a=0;}A(intbb){b=b;c=b;}intoperator+(inta){return2;}intoperator->*(a_funca){return99;}intoperator->*(inta){return94;}intoperator*(inta){return2;}B*operator->(){ret

c++ - 什么是 C++ 中的 ->* 运算符?

C++继续让我感到惊讶。今天我发现了->*运算符。它是可重载的,但我不知道如何调用它。我设法在类里面重载它,但我不知道如何调用它。structB{inta;};structA{typedefint(A::*a_func)(void);B*p;inta,b,c;A(){a=0;}A(intbb){b=b;c=b;}intoperator+(inta){return2;}intoperator->*(a_funca){return99;}intoperator->*(inta){return94;}intoperator*(inta){return2;}B*operator->(){ret