草庐IT

c++ - 具有未触及的非 constexpr 参数 : Who is correct, clang 或 gcc 的 constexpr?

我有4个测试用例,我相信它们都是有效的:constexprintf(intconst&/*unused*/){return1;}voidg(intconst&p){constexprinta=f(p);//clangerror,gccvalidintv=0;constexprintb=f(v);//clangvalid,gccvalidintconst&r=v;constexprintc=f(r);//clangerror,gccerrorintn=p;constexprintd=f(n);//clangvalid,gccvalid}intmain(){intp=0;g(p);}Cla

c++ - 我的 g++ 使用 vector<weak_ptr> erase() 方法生成奇怪的警告

我有以下C++代码:#include#include#include#includevoiderase_from_vector(std::vector>&mvec){for(automvec_it=mvec.begin();mvec_it!=mvec.end();)mvec_it=mvec.erase(mvec_it);}intmain(void){#if0std::vector>mvec;for(automvec_it=mvec.begin();mvec_it!=mvec.end();)mvec_it=mvec.erase(mvec_it);#endif}当我这样编译时,GCC会生成

c++ - flto 与 gcc7.2 崩溃

我在以下代码文件中遇到getline崩溃。我构建了gcc7.2,因为系统更新不可用。最小的例子:#includeintmain(intargc,char*argv[]){std::stringline;while(std::getline(std::cin,line)){}return0;}下面几行GCC_INSTALL_DIR代表我自己的gcc安装目录输出:./a.outa***Errorin`./a.out':free():invalidpointer:0x0000000000602200***=======Backtrace:=========/lib64/libc.so.6(+

c++ - VS Code 不会构建具有多个 .ccp 源文件的 C++ 程序

请注意,我在Ubuntu17.10上使用VSCode并使用GCC编译器。我在构建一个使用附加.ccp文件的简单程序时遇到了问题。我可能在这里遗漏了一些明显的东西,因为我对编程还很陌生,但我会解释到目前为止我做了什么。这是阻止我继续我正在做的教程的原因。我写了一个非常简单的程序来证明我的观点如下。主.ccp#include#include"Cat.h"usingnamespacestd;intmain(){speak();return0;}目录.h#pragmaoncevoidspeak();猫.ccp#include#include"Cat.h"usingnamespacestd;vo

c++ - 生成具有完整路径的 gcc 依赖项

我有一个看起来像这样的简单项目.├──build│  ├──file1.o│  └──one│  ├──file1.o│  └──file2.o├──.depend├──Makefile└──src  ├──file1.cpp  └──one  ├──file1.cpp  └──file2.cppMakefile是这样的:#GetallofthesourcefilesSRC=$(shellfindsrc/-name"*.cpp")#GetalloftheobjectfilesOBJ=$(substsrc,build,$(SRC:.cpp=.o))$(OBJ):@mkdir-p$(she

c++ - 如何强制编译器显示隐式构造函数

gcc或clang有“-E”选项来运行预处理器并显示所有宏是如何展开的,对于隐式生成的方法我需要这样的东西。有没有办法强制gcc或clang为每个类打印隐式创建和删除的构造函数/析构函数/赋值运算符? 最佳答案 您可以使用模板类型特征作为从某些类型中提取此类信息的变通方法。这无法区分某些内容是被显式删除还是隐式删除,但是您可以肯定地知道您是否没有显式删除,例如#include#includestructA{A(constA&)=delete;};intmain(){std::cout将产生false,true,false,例如,当复

c++ - clang 编译的程序在 std::any_cast 期间抛出 std::bad_any_cast

我正在开发一个使用std::any的应用程序.最近我发现,当我用clang编译它时,我得到了bad_any_caststd::any_cast之一的异常我确定我正在转换为正确的类型。我添加了一些typeid(T).name()的转储至cout确保插入std::any的类型没有区别并输入我正在尝试转换到的内容。我试图编写简单的程序来演示它,但我无法重现它。值得一提的是:我正在传递一包std::any(每个内部包含不同的类型)并且只有一个有问题(它是std::map)。当我切换到boost::any时问题消失了(或者如果我使用gcc构建我的应用程序)。我已经深入了解std::any_cas

c++ - 编译器使用的 double 表示的显式规范

最近遇到visual-c++好像不是IEEE754的问题兼容,而是使用subnormalrepresentation.也就是说,其中的doublefloat没有通常表示的1个符号位、11个指数位和52个显式存储的有效小数位,见下文。由于gcc和clang是兼容的,因此非常需要一致的跨平台行为我想知道是否可以强制visual-c++使用正常表示。或者让gcc和clang使用次正规表示当然也可以解决问题。不同双重表示的问题可以在visual-c++中重现,gcc和clang使用以下代码:#include#includeintmain(){try{std::stod("8.097571188

c++ - 为什么尽管使用了 -isystem,但 clang 在我的标题上报告了警告,而 gcc 没有报告?

与thisquestion稍微相关但不一样。在ArchLinux上使用clang7.0.1。我喜欢干净的代码,所以我想启用所有警告并将它们视为错误。问题是我的构建中有一些自动生成的文件不是没有警告,例如:生成/foo.hinlinevoidfoo(intunused){//warning:unusedparameter'unused'}生成/foo.cc#include"foo.h"//Thereisactualcodehere,butitdoesn'tmatter.由于这些文件是由第三方工具生成的,我不能轻易修改它们,所以我使用-isystem禁止来自generated的所有警告目录

c++ - gcc 与 clang : noexcept parsed in unused template specialization when static casting

我正在尝试将函数指针静态转换为特定函数重载,但似乎clang仍会解析(未使用的)模板特化的noexcept语句,从而生成编译器错误。如果未使用相应的函数重载,GCC似乎并不关心noexcept。templatevoidfun(T)noexcept(T(1)){}voidfun(int){}voidfun(int*){}intmain(){inta;fun(&a);//callingworksfinefun(a);static_cast(&fun);//staticcastingdoesn't}https://godbolt.org/z/ixpl3f这里是哪个编译器出错了?当将函数指针转