草庐IT

GCC_NO_COMMON_BLOCKS

全部标签

c++ - 使用 enable_if 选择特征 - 适用于 clang,但不适用于 gcc

我正在编写一段通用的(C++11)代码,它应该与boost::multi_array、Eigen::Matrix一起工作,并且可能其他类型的n维数组。在几个点上,我需要访问给定数组类型的元素类型。boost数组包含一个名为Element的typedef,而Eigen数组包含一个名为Scalar的typedef。我想要的是一个返回给定数组类型的元素类型的类型特征。不幸的是,我不能只为所有可能的数组类型模板专门化特征类,因为Eigen使用表达式模板,因此,有无限多种类型的Eigen矩阵。因此,我将SFINAE与enable_if一起使用来实现我的特征。enable_if应该选择的标准是,一

c++ - x86、C++、gcc 和内存对齐

我有这个简单的C++代码:inttestFunction(int*input,longlength){intsum=0;for(longi=0;i#includeusingnamespacestd;intmain(){union{int*input;char*cinput;};size_tlength=1024;input=newint[length];//cinput++;cout如果我用带有-O3的g++4.9.2编译它,它运行良好。我预计,如果我取消对倒数第二行的注释,它会运行得更慢,但它会因SIGSEGV而彻底崩溃。ProgramreceivedsignalSIGSEGV,Se

c++ - 警告 : second/third operand of conditional has no effect [-Wunused-value]

std::cout我想检查给定值是否可以创建三角形。我收到警告:secondoperandofconditionalexpressionhasnoeffect[-Wunused-value]thirdoperandofconditionalexpressionhasnoeffect[-Wunused-value]怎么了? 最佳答案 您的代码转换为:((std::cout首先,operator有更高的operatorprecedence比operator&&.只有abs(b-c)的值将被打印并且(a部分将与std::ostream::

c++ - caffe 安装 : gcc error namespace "std" has no member "isnan"

我正在尝试安装(py)caffe在ubuntu17.10上然而,当我执行makeall时,出现以下错误:./include/caffe/common.hpp(84):error:namespace"std"hasnomember"isnan"./include/caffe/common.hpp(85):error:namespace"std"hasnomember"isinf"2errorsdetectedinthecompilationof"/tmp/tmpxft_00004921_00000000-19_nesterov_solver.compute_61.cpp1.ii".Mak

c++ - 有没有办法在 GCC 中禁用内联汇编程序?

我正在为LeetCode、Codeforces等编程竞赛开发一个在线评委系统。对于大多数编程竞赛,C/C++中不允许使用内联汇编程序,因此我想在我的系统中添加相同的限制。我想让GCC和G++在编译包含内联汇编的C/C++程序时产生错误,这样任何包含内联汇编的代码都会导致编译错误。有办法实现吗?我应该将一些命令行参数传递给GCC/G++吗?注意:禁用内联汇编只是为了遵守规则,而不是出于安全考虑。 最佳答案 有没有办法在GCC中禁用内联汇编程序?是的,有几种方法。在编译器中关闭汇编要在编译阶段执行此操作,请使用参数-fno-asm。但是

c++ - 为什么简单的内联汇编函数不能在 GCC 中正常工作?

我有一个简单的内联汇编函数,它在MSVC中运行良好,但由于某种原因拒绝在AppleGCC4.2.1下运行(i386arch,强制32位模式)。幸运的是,更复杂的汇编函数可以正常工作,但是我不明白为什么这个函数不起作用...不幸的是,我无法调试它-从外观上看,XCode中没有寄存器窗口4.0.2(它是3.2版本)。我很肯定这个问题与英特尔风格的汇编无关。intConvert(doublevalue){_asm{fldvaluepusheaxfistpdwordptr[esp]popeax}//Thereturnedvalueisinsane} 最佳答案

c++ - GCC 汇编代码生成错误和解决方法

GCC4.5.2(在Ubuntu11.10x64上,但编译为32位)生成无效的汇编代码,我很好奇是否可以在不更改代码的情况下修复,只需应用选项或类似的东西。请注意,优化已经是-O0。我有两个功能:inlinelongClass::Get(){longv=*(long*)(m_p);m_p+=4;returnv;}inlinevoidClass::Command(){m_p+=Get();}GCC4.5.2生成此汇编代码:9840m_p+=Get();f689eff5:mov0x8(%ebp),%eaxf689eff8:mov0xd4(%eax),%eaxf689effe:mov%eax

c++ - GCC 中 cmath 的 pow() 的正确性

代码[GCC,使用-O2标志编译]intmain(){vector>matrixa(8);intff=5;ints=pow(ff,matrixa.size());intss=pow(double(ff),int(matrixa.size()));vector>comb(s);cout输出5^8=390624390625我想知道为什么s=390624而它应该是390625。如果我在没有-O2标志的情况下编译代码,则s=390625。此外,ss的转换似乎可以解决此问题。这是怎么回事?我的操作系统是Windows7Ultimatex64。不确定GCC版本,它带有Code::Blocks10.

C++ STL : Why is there no upper_bound equivalent that retrieves the greatest element smaller then a specific key?

通常,STL是为提高速度而构建的。然而,在map和set数据结构上只有upper_bound和lower_bound并且没有操作来检索具有小于输入键的最大键的条目k.为什么是这样?我知道我可以简单地做一个lower_bound并做一个--it检索它,但根据数据结构,立即搜索正确的条目可能比搜索另一个条目然后返回一步更有效。例如,std::map使用红黑树,即二叉搜索树。如果upper_bound返回的元素是大于根的最小元素,则--it必须回到根,查询O(logn)的额外成本。如果这是Java,我会接受设计决定。然而,STL是为实现最高速度而构建的,那么为什么要省略此操作?澄清:我不是在

c++ - 如何关闭 Code::Blocks 的自动完成

当我在Code::Blocks中输入代码时,我更愿意直接输入代码,而无需让编辑器插入右括号和方括号。我在“设置”>“编辑器”>“代码完成”中选择了禁用代码完成,但此功能不会禁用带有结束字符的自动完成功能。在Code::Blocks中关闭此功能的正确设置是什么?(请注意代词审查员可能会发生这种情况:https://www.theregister.co.uk/2019/10/08/stack_overflow_apology/) 最佳答案 “设置->编辑器...->常规设置->缩进选项->大括号补全”