首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >宇宙飞船操作符的clang-整齐解析错误

宇宙飞船操作符的clang-整齐解析错误
EN

Stack Overflow用户
提问于 2021-01-04 14:49:58
回答 2查看 587关注 0票数 3

使用clang++-11libstdc++-11clang-tidy-11一起使用时,当使用clang-tidy链接代码时会遇到失败--即在处理著名的轨枕std::this_thread::sleep_for(std::chrono::seconds(1));时出现解析错误。

代码语言:javascript
复制
clang-tidy-11 -header-filter=include/ -p=/tmp/dev/build/bin/aggregation/ -quiet /tmp/de
v/build/aggregation/src/main.cc
PLEASE submit a bug report to https://bugs.llvm.org/ and include the crash backtrace.
Stack dump:
0.      Program arguments: clang-tidy-11 -header-filter=include/ -p=/tmp/dev/build/bin/
aggregation/ -quiet /tmp/dev/build/aggregation/src/main.cc
1.      <eof> parser at end of file
2.      While analyzing stack:
        #0 Calling std::chrono::operator<=> at line /usr/include/c++/11/thread:125:6
        #1 Calling std::this_thread::sleep_for at line 159
        #2 Calling main
3.      /usr/include/c++/11/chrono:771:9: Error evaluating statement
4.      /usr/include/c++/11/chrono:771:9: Error evaluating statement
/usr/lib/x86_64-linux-gnu/libLLVM-11.so.1(_ZN4llvm3sys15PrintStackTraceERNS_11raw_ostre
amE+0x1f)[0x7f4ae7718e7f]
/usr/lib/x86_64-linux-gnu/libLLVM-11.so.1(_ZN4llvm3sys17RunSignalHandlersEv+0x50)[0x7f4
ae77171e0]
/usr/lib/x86_64-linux-gnu/libLLVM-11.so.1(+0xbd1355)[0x7f4ae7719355]
/lib/x86_64-linux-gnu/libpthread.so.0(+0x14140)[0x7f4aee8ec140]
/usr/lib/x86_64-linux-gnu/libclang-cpp.so.11(_ZN5clang4ento17BasicValueFactory25getPers
istentSValWithDataERKNS0_4SValEm+0x58)[0x7f4aedd82e38]

我检查过它在基本宇宙飞船操作人员使用上正常工作

代码语言:javascript
复制
#include <compare>
struct IntWrapper {
  int value;
  constexpr IntWrapper(int value): value{value} { }
  auto operator<=>(const IntWrapper&) const = default;
};

constexpr bool is_lt(const IntWrapper& a, const IntWrapper& b) {
  return a < b;
}
int main() {
  static_assert(is_lt(0, 1));
}

这个失败似乎发生在<chrono>模板的最后一行。

代码语言:javascript
复制
    template<typename _Rep1, typename _Period1,
         typename _Rep2, typename _Period2>
      requires three_way_comparable<common_type_t<_Rep1, _Rep2>>
      constexpr auto
      operator<=>(const duration<_Rep1, _Period1>& __lhs,
          const duration<_Rep2, _Period2>& __rhs)
      {
    using __ct = common_type_t<duration<_Rep1, _Period1>,
                   duration<_Rep2, _Period2>>;
    return __ct(__lhs).count() <=> __ct(__rhs).count();
      }

我设法克服了这个问题,通过临时解决办法(suure)使用boost::this_thread::sleep_for(boost::chrono::seconds(1));,因为它是我项目中的一个依赖项。

你有什么指点吗?我是不是在某个地方失败了,或者可能是“clang”中著名的bug,我应该毫不犹豫地提交一份bug报告?

EN

回答 2

Stack Overflow用户

回答已采纳

发布于 2021-01-05 04:30:19

您可以使用以(now() + 1s)作为参数的直到方法。

票数 2
EN

Stack Overflow用户

发布于 2021-01-04 22:24:17

确认了叮当整洁的虫子,bug.cgi?id=47511。我将保留这个问题,也许有人会发现boost技巧很有用,直到它被修复为止。

票数 2
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/65564677

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档