草庐IT

c++ - gcc 的 asm volatile 是否等同于递归的 gfortran 默认设置?

我只是在研究C++和Fortran中的递归函数,我意识到Fortran中的一个简单递归函数几乎是与其等效的C++函数一样快。现在,在进入这个之前,我知道这里有类似的问题,特别是:Whydoesaddingassemblycommentscausesuchradicalchangeingeneratedcode?Workingofasmvolatile(“”:::“memory”)Equivalenttoasmvolatileingfortran但是,我有一点更具体和困惑,因为Fortran编译器似乎正在做你可以用gcc中的asmvolatile实现的事情。为了给您一些上下文,让我们考虑

c++ - clang 中明确指定的参数无效,但在 gcc 中编译成功——谁错了?

以下代码在g++中编译没有问题:#include#include#includetemplatevoidtest(constT&value){std::tuplex;std::cout(x);}intmain(){test(std::integral_constant());}我使用了这个命令:g++test.cpp-otest-std=c++14-pedantic-Wall-Wextra但是,当我将g++切换到clang++(使用g++5.1.0和clang++3.6.0)时,出现以下错误:test.cpp:9:18:error:nomatchingfunctionforcallto

c++ - 为什么 libcxx 应用 __forceinline 或 GCC 等效于它已经隐藏的内联函数?

我想确切地理解为什么内联函数的libc++可见性宏使用__forceinline或__attribute__((__always_inline__))作为它关联的属性的一部分内联函数。背景见:ThelibcxxvisibilitydesigndocumentThedefinitionofINLINE_VISIBILITY如果这些内联函数无论如何都将被标记为__visibility__("hidden"),为什么还需要额外强制编译器将它们内联?我想了一下,我有一些假设,但似乎没有一个让我完全满意:这是为了确保符号不会意外成为ABI的一部分。如果在构建库时,编译器选择不内联函数,它可能会成

c++ - gcc 和 class 关键字

我知道typename和class关键字在模板参数中可以互换,但我认为嵌套类规范只允许使用typename。有一次我不小心将嵌套类的“typename”写错了“class”。我发现gcc也接受class,所以你可以这样写:classstd::vector::iteratorit;insteadoftypenamestd::vector::iteratorit;在您的模板中。这是一个gcc错误还是标准真的允许这种语法?更新:代码示例:templatevoidtest(){classstd::vector::iteratorit;} 最佳答案

c++ - 为什么 gcc 警告使用 std::tuple 和虚拟继承调用非平凡的移动赋值运算符?

在下面的例子中,gcc7给出了警告:defaultedmoveassignmentfor'B'callsanon-trivialmoveassignmentoperatorforvirtualbase'A'[-Wvirtual-move-assign]如果我创建一个std::tuple目的。Clang5没有报告任何问题。如果vector,问题也会消失从Base中删除.Example.#include#includeclassBase{public:virtual~Base();std::vectorv;};classA:publicBase{};classB:publicvirtual

c++ - 用于 gcc 或 clang 的 LTO 是否可以跨 C 和 C++ 方法进行优化

如果链接时优化(LTO)与gcc一起使用或clang,是否可以跨C和C++语言边界优化代码?例如,C函数是否可以内联到C++调用程序中? 最佳答案 是的!链接时优化通常适用于“胖”目标文件中存在的中间表示(IR),它可以包含用于传统链接的机器代码和用于LTO链接的IR。在此阶段,不再有高级语言结构,因此链接时优化与语言无关。海合会海湾合作委员会的link-timeoptimization(LTO)在GIMPLE上工作,GIMPLE是GCC的中间表示之一。IR始终与语言无关,因此任何链接时优化都适用于从任何语言生成的代码。来自GCCO

c++ - gcc 无法编译带有前缀命名空间的运算符定义

我在命名空间my_namespace中为类my_type声明了运算符。namespacemy_namespace{classmy_type{friendstd::ostream&operator我试图在实现文件中定义这些运算符,但是当我写这样的东西时std::ostream&my_namespace::operator我收到错误信息错误:...运算符应该在“my_namespace”中声明当我把它改成namespacemy_namespace{std::ostream&operator然后它编译了,但我不明白这个问题。为什么编译失败?一切都对吗?我希望能链接到标准,因为我真的不知道要搜

c++ - 为什么我不能在 gcc 的初始值设定项中访问默认参数?

这在clang中编译但不在gcc:voidf(intx=decltype(x){});gcc中的错误表明x未在此范围内声明,但根据3.3.2/1变量x应该在范围内:Thepointofdeclarationforanameisimmediatelyafteritscompletedeclarator(Clause8)andbeforeitsinitializer(ifany),exceptasnotedbelow.[Example:intx=12;{intx=x;}Herethesecondxisinitializedwithitsown(indeterminate)value.—en

c++ - GCC 使用 __stdcall 编译一个 dll

当我们在visualstudio2008中使用__stdcall编译dll时,dll中编译的函数名称是。函数名虽然当我们使用GCC使用wx-dev-cpp编译相同的dll时,GCC会附加函数具有的参数数量,因此使用Dependencywalker的函数名称看起来像。FunctionName@numberOfParameters或==FunctionName@8如何告诉GCC编译器从dll中导出的符号中删除@nn? 最佳答案 __stdcall修饰函数名,开头加下划线,结尾加参数字节数(@分隔)。所以,一个函数:void__stdca

C++ - 是否值得在 Windows 上使用 GCC 而不是 MSVC?

关闭。这个问题是opinion-based.它目前不接受答案。想要改进这个问题?更新问题,以便editingthispost可以用事实和引用来回答它.关闭7年前。Improvethisquestion我已经阅读了一些关于GCC与MSVC以及这些编译器的开发的问题,例如GCCworthusingonWindowstoreplaceMSVC?,VisualStudioorGCC?和GCCvsMSC++compilerformaintainingAPIbackwardsbinarycompatibility.但这些都是非常过时的问题(2011年)。随着新的c++14特性的出现,两个编译器之间