草庐IT

c++ - clang vs gcc - 优化包括 operator new

我有一个我正在测试的简单示例,我注意到当涉及operatornew时,gcc优化(-O3)似乎不如clang优化。我想知道可能是什么问题,是否可以强制gcc以某种方式生成更优化的代码?templateT*create(){returnnewT();}intmain(){autoresult=0;for(autoi=0;i()!=nullptr);}returnresult;}#clang3.6++-O3-s--std=c++11test.cpp#sizea.outtextdatabssdechexfilename13246168194879ca.out#time./a.outreal0

ubuntu安装gcc和gcc c++的命令

一、在Ubuntu中安装gcc编译器非常简单。你可以按照以下步骤进行操作:打开终端:你可以按下Ctrl+Alt+T快捷键来打开终端,或者在应用菜单中搜索“终端”并打开它。运行以下命令以更新软件包列表:sudoaptupdate这将检查可用的更新和软件包列表。安装gcc编译器:sudoaptinstallgcc运行此命令后,系统会提示你输入管理员密码,并询问是否要继续安装。键入密码并按下Enter键,然后键入y来继续安装。等待安装完成:系统会下载并安装gcc编译器及其相关依赖项。安装过程可能需要一些时间,具体取决于你的网络速度。安装完成后,你就可以使用gcc编译器来编译和运行C或C++程序。如果

c++ - std::unique_ptr<T[]>::reset 在 gcc 6 中的实现

从C++中的GCC6开始,unique_ptr::reset的声明/定义方法(不是那个,只接受nullptr_t)看起来像这样:template,__and_,is_pointer,is_convertible::type(*)[],element_type(*)[]>>>>>voidreset(_Up__p)noexcept{usingstd::swap;swap(std::get(_M_t),__p);if(__p!=nullptr)get_deleter()(__p);}这在某些时候已更改以实现N4089.根据该文件:Thisfunctionbehavesthesameasthe

c++ - GCC 导致 lambda 捕获的参数包出现段错误

我有以下SSCCE:#include#includevoidfoo(conststd::string&a){std::coutvoidbar(Args&&...args){[&](){[&](){foo(args...);}();}();}intmain(){conststd::stringx("HelloWorld!");bar(x);}在clang++(3.9.1)下编译并发出“HelloWorld”。Gcc6.3在-O3下因段错误而失败。我可以通过引用显式传递指针和包来解决问题,将[&]()替换为[&args...]()。但是,到目前为止,我认为[&]的作用与一一列出所有参数相同

c++ - 为什么 GCC 会在显式指定模板参数时产生奇怪的错误并尝试调用错误的方法?

我有一个函数submitAsync它接受了一个模板化的std::function作为参数:templateFuturesubmitAsync(constfunction&func,Args&&...args);但是,隐式模板参数推导在传递lambda时不起作用(类似于问题here,所以我不得不制作一个更通用的函数,接受该函数作为模板参数,然后将其传递给原始函数:templateautosubmitAsync(Func&&func,Args&&...args)->//Line82,wherethestrangeerroroccursFuture>::value,decltype(func

c++ - 为什么 64 位 GCC 在分配数组时警告将 const int 转换为 long unsigned int?

我有一个如下所示的文件test.cpp:voidf(constintn){unsignedchar*a=newunsignedchar[n];delete[]a;}intmain(){f(4);return0;}使用-Wsign-conversion在64位GCC中编译它标志产生警告:test.cpp:2:39:warning:conversionto‘longunsignedint’from‘constint’maychangethesignoftheresult[-Wsign-conversion](第2行是调用new的行)。我觉得GCC应该发出关于分配数组的警告似乎很奇怪,但下面

具有用户类型的 C++20 模板 <auto> 导致 GCC 9 中的 T/const T 类型不匹配

我正在尝试将非类型模板与自定义类型结合使用。structT{};templatestructU{};templatevoidf(U){}intmain(){constexprTt;f(U{});//OKf(U{});//OKf(U{});//Error}模板参数推导失败,gcctrunkwith-std=c++2agetsyop.cpp:10:5:note:templateargumentdeduction/substitutionfailed:yop.cpp:19:21:note:mismatchedtypes‘T’and‘constT’19|f(U{});//Error|^我是不是

c++ - 除非返回值有名称,否则为什么 GCC 无法优化?

考虑这段代码:#includeclassC{std::arraya{};intb{};};Cslow(){return{};}Cfast(){Cc;returnc;}GCC6到9为slow()生成非常臃肿的代码:slow():xoreax,eaxmovDWORDPTR[rsp-25],0movBYTEPTR[rsp-21],0movedx,DWORDPTR[rsp-24]movDWORDPTR[rsp-32],0movWORDPTR[rsp-28],axmovBYTEPTR[rsp-26],0movrax,QWORDPTR[rsp-32]retfast():xoreax,eaxxore

c++ - constexpr 返回数组,gcc 警告

我编写了一个返回数组的constexpr函数。#includeconstexprautoget_str(void)->constchar(&)[4]{return{'T','E','S','T'};}constexprintsum(constchar(&str)[4]){returnstr[0]+str[1]+str[2]+str[3];}intmain(void){constexprints=sum(get_str());std::coutg++4.8正确编译代码,但发出以下警告:test.cpp:Infunction‘constexprconstchar(&get_str())[4

c++ - gcc-4.9.2 : non-type template parameter

我在gcc-4.9.2上有一个奇怪的编译错误,相同的代码在其他编译器上工作,比如gcc-4.8或我能找到的任何clang。问题与non-typetemplate-arguments有关.所以考虑一下:#include#includeinttemplateParam;templatestructTestTemplate{intvalue(){}};templateintTestTemplate::value(){returntemplateParam;}TestTemplatetestVariable;intmain(){std::cout我在gcc-4.9.2中遇到以下错误:prog.