草庐IT

has_equal_operator

全部标签

c++ - 为什么在空指针上调用 "operator delete"时会调用 "delete"?

阅读thisquestion的答案时我注意到答案(例如this)暗示即使在空指针上执行delete语句时也可以调用operatordelete。所以我写了一个小片段:classTest{public:void*operatornew(size_t){/*doesn'tmatter*/return0;}voidoperatordelete(void*ptr){ptr;//tosuppresswarningandhavealinetoputbreakpointon}};intmain(){Test*ptr=0;deleteptr;}而且-令我惊讶的是-Test::operatordelet

c++ - 如何将 lambda 的 operator() 声明为 noreturn?

如何将lambda的operator()声明为noreturn?Ideone接受以下代码:#includeintmain(){[]()[[noreturn]]{std::exit(1);}();return0;}Clang3.5拒绝它:error:'noreturn'attributecannotbeappliedtotypes你可以在godbolt中试试:http://goo.gl/vsuCsF哪个是对的?更新:相关的标准部分似乎是5.1.2.5、7.6.3、7.6.4但在阅读后我仍然不是100%清楚(i)什么是正确的行为,(ii)如何将lambda的operator()标记为nor

c++ - 如何将 lambda 的 operator() 声明为 noreturn?

如何将lambda的operator()声明为noreturn?Ideone接受以下代码:#includeintmain(){[]()[[noreturn]]{std::exit(1);}();return0;}Clang3.5拒绝它:error:'noreturn'attributecannotbeappliedtotypes你可以在godbolt中试试:http://goo.gl/vsuCsF哪个是对的?更新:相关的标准部分似乎是5.1.2.5、7.6.3、7.6.4但在阅读后我仍然不是100%清楚(i)什么是正确的行为,(ii)如何将lambda的operator()标记为nor

c++ - 常见问题解答 : Why does dynamic_cast only work if a class has at least 1 virtual method?

这在C++中无法编译:classA{};classB:publicA{};...A*a=newB();B*b=dynamic_cast(a); 最佳答案 因为dynamic_cast只能向下转换多态类型,所以标准这么说。您可以通过向基类添加virtual析构函数来使您的类具有多态性。事实上,你可能应该无论如何(见脚注)。否则,如果您尝试通过A指针删除B对象,您将调用UndefinedBehavior.classA{public:virtual~A(){};};瞧!脚注关于在多态类型中需要虚拟析构函数的“规则”有一些异常(except

c++ - 常见问题解答 : Why does dynamic_cast only work if a class has at least 1 virtual method?

这在C++中无法编译:classA{};classB:publicA{};...A*a=newB();B*b=dynamic_cast(a); 最佳答案 因为dynamic_cast只能向下转换多态类型,所以标准这么说。您可以通过向基类添加virtual析构函数来使您的类具有多态性。事实上,你可能应该无论如何(见脚注)。否则,如果您尝试通过A指针删除B对象,您将调用UndefinedBehavior.classA{public:virtual~A(){};};瞧!脚注关于在多态类型中需要虚拟析构函数的“规则”有一些异常(except

为什么重写equals方法,还必须要重写hashcode方法

原因:1.为了提高效率采取重写hashcode方法,先进行hashcode比较,如果不同,那么就没必要在进行equals的比较了,这样就大大减少了equals比较的次数,这对比需要比较的数量很大的效率提高是很明显的,一个很好的例子就是在集合中的使用。我们都知道java中的List集合是有序的,因此是可以重复的,而set集合是无序的,因此是不能重复的,那么怎么能保证不能被放入重复的元素呢,但靠equals方法一样比较的话,如果原来集合中以后又10000个元素了,那么放入10001个元素,难道要将前面的所有元素都进行比较,看看是否有重复,这个效率可想而知,因此hashcode就应遇而生了,java

为什么重写equals方法,还必须要重写hashcode方法

原因:1.为了提高效率采取重写hashcode方法,先进行hashcode比较,如果不同,那么就没必要在进行equals的比较了,这样就大大减少了equals比较的次数,这对比需要比较的数量很大的效率提高是很明显的,一个很好的例子就是在集合中的使用。我们都知道java中的List集合是有序的,因此是可以重复的,而set集合是无序的,因此是不能重复的,那么怎么能保证不能被放入重复的元素呢,但靠equals方法一样比较的话,如果原来集合中以后又10000个元素了,那么放入10001个元素,难道要将前面的所有元素都进行比较,看看是否有重复,这个效率可想而知,因此hashcode就应遇而生了,java

c++ - 使用 ? 返回可选值: operator

我经常需要对函数使用可选类型:std::optionalget(conststd::string&field){autoit=map.find(field);if(it!=map.end())returnit->second;return{};}有没有办法在一行中返回可选值?例如这个:std::optionalget(conststd::string&field){autoit=map.find(field);returnit!=map.end()?it->second:{};}导致错误error:expectedprimary-expressionbefore'{'tokenretu

c++ - 使用 ? 返回可选值: operator

我经常需要对函数使用可选类型:std::optionalget(conststd::string&field){autoit=map.find(field);if(it!=map.end())returnit->second;return{};}有没有办法在一行中返回可选值?例如这个:std::optionalget(conststd::string&field){autoit=map.find(field);returnit!=map.end()?it->second:{};}导致错误error:expectedprimary-expressionbefore'{'tokenretu

c++ - `pair::operator=(pair&&)` 错误与 `auto&` 推断 move 操作 - libstdc++ 回归?

鉴于这个程序:structVal{Val()=default;Val(Val&&)=default;auto&operator=(Val&&);};/*PLACEHOLDER*/auto&Val::operator=(Val&&){return*this;}替换/*PLACEHOLDER*/与...intmain(){std::vector>v;v.emplace(std::begin(v),0,Val{});}...编译成功:g++6.2.0g++6.3.0g++7.0.1(主干)clang++3.9.1clang++5.0.0(HEAD)onwandbox替换/*PLACEHOLD