草庐IT

c++ - 对于曾经在 gcc5 中工作的情况,在 gcc6 的部分特化中无法推导出模板参数

此代码在gcc6中导致错误(但在gcc4.8、5.2和clang3.6中工作正常):templatestructouter{templatestructinner{};};templatestructis_inner_for{templatestructpredicate{staticconstexprboolvalue=false;};templatestructpredicate::templateinner>{staticconstexprboolvalue=true;};};static_assert(is_inner_for::templatepredicate::inner

c++ - GCC 错误 - 在 constexpr 中输入/递减数组访问

我在GCC6和7(不在GCC5)中的constexpr函数中发现了一个错误,如果函数在编译时(错误结果)或运行时(正确结果)求值,这会导致不同的结果。#includeconstexprintbar(int*b){inti=0;b[i++]=1;//GCCproducehereanfailure.return0;}constexprintfoo(){inttmp[]={0};bar(tmp);returntmp[0];}constexprintcexprI=foo();intmain(){std::coutLiveExample问题是数组访问内部的递增(也发生递减)操作。常量表达式的编译

c++ - noexcept 运算符和 enable_if_t : do they work together?

考虑以下类:structS{templatestd::enable_if_t::value>f()noexcept{}templatestd::enable_if_t::value>g()noexcept{}};正如预期的那样,编译:s.f();这个不是:s.g();令我困惑的是,下面的main是用GCC(6.2)编译的,而不是用clang(3.9)编译的:intmain(){static_assert(noexcept(&S::f),"!");static_assert(noexcept(&S::g),"!");}我会说第二个断言失败是因为特化无效。两个编译器不同意这一点。哪个是正确

c++ - 使用 Wfloat-equal 选项将 float 与 1 或 0 进行比较

我对在代码中执行浮点相等比较的问题有些熟悉。目前我在(GCC,Clang)上编译的代码库启用了以下选项:-Wfloat-equal在代码库中有以下示例比较:templatevoidfoo(FloatTypev){if(v==FloatType(1)){...}elseif(v==FloatType(0)){....}}foo函数调用如下:doubled=123.98;floatf=123.98f;foo(d);foo(f);考虑到1和0的特殊情况,它们每个都有精确的浮点表示(double,float)并且代码显然在完全相等之后,而不是接近于一些次要的东西区别-有没有一种方法可以重写代码

c++ - 在 AVX 上使用 AVX2/AVX512 内在函数编译 C++ 代码

我的生产代码具有针对各种SIMD指令集(包括AVX、AVX2和AVX512)实现的内核。代码可以在目标机器上为目标机器编译,类似./configure--enable-proc=AVXCXXFLAGS="-mavx"。这在公开AVX内在函数的TravisCI上也很有效。我想至少编译AVX2和AVX512版本,以查看是否所有文件都已checkin。但似乎为不同的ISA编译并不那么容易。一个简单的AVX2测试程序:#includeintmain(intargc,char**argv){__m256da;__m256db;__m256dc;_mm256_fnmadd_pd(a,b,c);}在

c++ - 使用 char[] 作为参数、返回等可以解决任何性能问题吗?

首先是为了让C++代码更具可读性;我是编程编译器,我给了它:varswap=(intx,y)=>{//Assignmethodthatreturnstwoints,andgetstwointsasparametertovariablenamedswap.varNewX=yvarNewY=x}varincrement=(intx)=>{varResult=x+1}注意:函数返回首字母大写的任何变量。swap可以像...=swap(x,y).NewX一样使用,但是increment可以像一样使用。..=增量(x)。经过一些优化后,它生成了:(使swap和increment成为实际函数而不是

c++ - 使用 clang 选择特定的 libstdc++ 版本

我使用clang++来编译C++代码。我链接到gcc标准C++库libstdc++。但是,我在我的Ubuntu机器上安装了几个不同的libstdc++。当我运行clang++时,它使用了libstdc++的4.8安装:andy@andy:~$clang++-3.5-vUbuntuclangversion3.5.0-4ubuntu2~trusty2(tags/RELEASE_350/final)(basedonLLVM3.5.0)Target:i386-pc-linux-gnuThreadmodel:posixFoundcandidateGCCinstallation:/usr/bin/

c++ - 可变参数模板构造函数的推导指南失败

我正在尝试重现视频C++Weekly-Ep48-C++17'sVariadicusing的结果,但失败了。该问题可以简化为以下代码段。假设我有这样的通用结构:templatestructContainer{templateContainer(U...us){}};现在我可以初始化一个Container带有任何参数,例如autod=Container(1,2,3);但是,编译器永远不会知道d是什么类型是。为了解决这个问题,我们应该提供一个推导指南,例如templateContainer(U...)->Container根据视频,编译器现在应该知道d类型为Container.但是,代码没有

c++ - GCC 7,aligned_storage 和 "dereferencing type-punned pointer will break strict-aliasing rules"

我编写的代码在GCC4.9、GCC5和GCC6中没有警告。它在一些较旧的GCC7实验快照(例如7-20170409)中也没有警告。但在最近的快照(包括第一个RC)中,它开始产生关于别名的警告。代码基本上可以归结为:#includestd::aligned_storage::typestorage;intmain(){*reinterpret_cast(&storage)=42;}使用最新的GCC7RC编译:$g++-Wall-O2-cmain.cppmain.cpp:Infunction'intmain()':main.cpp:7:34:warning:dereferencingtyp

c++ - 使用 g++ 和 clang++ 调用 Integral 模板成员函数时出错

这个问题在这里已经有了答案:WhereandwhydoIhavetoputthe"template"and"typename"keywords?(8个答案)关闭7年前。我目前陷入编译错误,我无法真正识别...这是一个最小的工作示例:#includetemplateclassa_type{public:templatedoublesegment(){return42;}};templatedoublefunc(){a_typea;returna.segment();}intmain(intargc,char*argv[]){std::cout()来自GCC的错误信息如下:g++main.