Clang, std::shared_ptr and std::less/operator<

Clang, std::shared_ptr and std::less/operator<

本文关键字:std operator lt less ptr shared Clang and      更新时间:2023-10-16

具有以下代码

#include <memory>
int main() {
    std::shared_ptr<int> ptr0( new int );
    std::shared_ptr<int> ptr1( new int );
    bool result = ptr0 < ptr1;
}

使用 clang 编译时产生以下错误(版本 3.1、LLVM 3.1、Debian GNU/Linux Sid)

/usr/bin/../lib/gcc/x86_64-linux-gnu/4.7/../../../../include/c++/4.7/bits/shared_ptr.h:364:14: error: no matching function for call to object of type 'std::less<_CT>'
      return std::less<_CT>()(__a.get(), __b.get());
             ^~~~~~~~~~~~~~~~
foo.cpp:9:21: note: in instantiation of function template specialization 'std::operator<<int, int>' requested here
        bool result = ptr0 < ptr1;
                           ^
/usr/bin/../lib/gcc/x86_64-linux-gnu/4.7/../../../../include/c++/4.7/bits/stl_function.h:236:7: note: candidate function not viable: no known conversion from 'int *' to 'int *&&&' for
      1st argument;
      operator()(const _Tp& __x, const _Tp& __y) const
      ^

使用 GCC(版本 4.7.0)编译相同的代码不会引发任何错误消息。运算符<() 不适用于 clang 中的共享指针有什么原因吗?

clang++ 和 libstdc++ 还不能完全匹配。您可以执行以下操作之一:

  • 切换到 libc++(通过使用 clang++ -stdlib=libc++ -std=c++11 ...
  • 将以下修补程序应用于/usr/include/c++/4.7.0/type_traits(如 http://clang.llvm.org/cxx_status.html 中所述):

    Index: include/std/type_traits
    ===================================================================
    --- include/std/type_traits (revision 185724)
    +++ include/std/type_traits (working copy)
    @@ -1746,7 +1746,7 @@
       template<typename _Tp, typename _Up>
         struct common_type<_Tp, _Up>
    -    { typedef decltype(true ? declval<_Tp>() : declval<_Up>()) type; };
    +    { typedef typename decay<decltype(true ? declval<_Tp>() : declval<_Up>())>::type type; };
       template<typename _Tp, typename _Up, typename... _Vp>
         struct common_type<_Tp, _Up, _Vp...>
    

如果你检查bits/shared_ptr.h你确实发现了一个std::common_type,并且clang开发人员声称它实际上是libstdc++的错误,尽管我不相信单独的libstdc++的错误会导致不存在的类型int*&&&出现。

相关文章: