草庐IT

compiler-specific

全部标签

c++ - 为什么书上说 “the compiler allocates space for variables in memory” ?

为什么书上说“编译器为内存中的变量分配空间”。不是可执行文件吗?我的意思是,例如,如果我编写以下程序,#includeusingnamespacestd;intmain(){intfoo=0;cout并编译它,得到一个可执行文件(让它成为program.exe),现在,如果我运行program.exe,这个可执行文件将自己命令为变量foo分配一些空间。不会吗?请解释为什么书籍一直说,“编译器会做这个......做那个”,而实际上,编译的可执行文件会这样做。在这个问题上添加另一个相关问题,为什么sizeof称为编译时运算符?它实际上不是一个运行时运算符吗? 最

c++ - 内联调用 always_inline 失败 '__m128i _mm_cvtepu8_epi32(__m128i)' : target specific option mismatch _mm_cvtepu8_epi32 (__m128i __X)

这个问题在这里已经有了答案:inliningfailedincalltoalways_inline‘_mm_mullo_epi32’:targetspecificoptionmismatch(2个回答)关闭4年前。我正在编译thisproject来自github,它是用C++实现的,带有SIMD内在函数(SSE4.1)。github中的项目是作为VisualStudio解决方案提供的,但我正在尝试使用cmake将其移植到Qtcreator中。当我尝试编译它时,我收到以下错误:/usr/lib/gcc/x86_64-unknown-linux-gnu/5.3.0/include/smmi

c++ - '/usr/lib/i386-linux-gnu/qt5/bin/lrelease : not found WARNING: TARGET is empty' Error when trying to compile Feathercoin from source

我关注this从源代码安装羽毛币的提示。我已按照所有说明进行操作,直至:qmake'USE_UPNP=-`make这就是我得到以下错误的地方:1:/usr/lib/i386-linux-gnu/qt5/bin/lrelease:notfoundWARNING:TARGETisempty`下面是终端输出:RCC:Errorin'src/qt/bitcoin.qrc':Cannotfindfile'locale/bitcoin_bg.qm'RCC:Errorin'src/qt/bitcoin.qrc':Cannotfindfile'locale/bitcoin_ca_ES.qm'RCC:E

c++ - 是否预计 boost::thread_specific_ptr<>::get() 的使用会很慢?有什么解决办法吗?

我目前正在使用Valgrind的“Callgrind”分析一个存在性能问题的应用程序。在查看分析数据时,似乎有25%的处理时间花在boost::detail::get_tss_data的应用程序中,其主要目的是物理模拟和可视化。get_tss_data显然是由thread_specific_ptr::get调用的有人认为这是预期的吗?它通常是否暗示其他特定的东西?编辑:我的平台是:Linux-2.6.32、x86、GCC4.4.3、libc6-2.11.1/libpthread-2.11.1 最佳答案 thread_specific

c++ - 可变参数模板和函数的指针 : what compiler is right?

我找不到更好的标题,但如果您有正确的想法,请随时修改它。事实上,它还是比GCCvsclang好。我试图找出这段代码有什么问题:templatestructS;templatestructS:S{usingS::f;templatevoidf(){}};templatestructS{voidf();};templatestructR:S{usingS::f;templatevoidg(){this->templatef();}};voidh(constdouble&){}intmain(){Rr;r.g();}它可以用GCC4.9编译(参见here),但它不能用clang3.8.0编译

c++ - target_compile_options() 仅适用于 C++ 文件?

是否可以仅将target_compile_options()用于C++文件?我想将它用于作为其他应用程序依赖项的目标,以便库可以将其编译器标志传播到这些应用程序。但是,如果与C或ObjC文件一起使用,某些标志(例如-std=c++14)会导致构建失败。我读过我应该CXX_FLAGS而不是只将这些标志添加到C++文件中,但这不会(自动)通过cmake的包系统传播。 最佳答案 解决方案您可以使用generatorexpressions来执行此操作:target_compile_options(MyLibPUBLIC$:-std=c++1

c++ - 使用 Visual Studio Compiler 分析内联 C++ 函数

当编译器内联了很多代码时,如何理解Windows上的C++分析数据?IE。我当然想测量实际运行的代码,所以根据定义,我将测量代码的优化构建。但似乎我尝试的所有工具都没有真正设法解决内联函数。我已经尝试了VisualStudio2017Professional和VTune2018中的采样分析器。我尝试启用/Zo,但似乎没有任何影响。我发现以下资源似乎表明只有VisualStudioUltimate或Premium支持内联框架信息-VisualStudio2017是否仍然如此?https://social.msdn.microsoft.com/Forums/en-US/9df15363-5

c++ - 为什么此代码链接到 Intel Compiler 2015 而不是 Intel Compiler 2018?

我的团队最近从2015年英特尔编译器(并行工作室)升级到2018年版本,我们遇到了一个链接器问题,让每个人都焦头烂额。我有以下类(为简洁起见进行了适度编辑),用于处理子进程的包装以及与它们对话的相关文件描述符:classSubprocWrapper{public:staticconstintPASSTHRU_FD=0;staticconstintMAKE_PIPE=-1;typedefstd::mapEnvMapType;staticEnvMapTypegetMyEnv();SubprocWrapper(intstdin_fd_req,intstdout_fd_req,intstder

c++ - 运算符转换、GCC 和 clang : which compiler is right?

考虑以下代码:structS{usingT=int;operatorT(){return42;}};intmain(){Ss;S::Tt=s;//Isthefollowinglinecorrect?t=s.operatorT();}使用GCC(4.9/5.1/6.1)编译,但使用clang(3.8/3.7)编译失败。返回的错误是:error:unknowntypename'T';didyoumean'S::T'?在这种情况下哪个编译器是正确的,为什么?注意解决它是一个合格的问题T:t=s.operatorS::T();问题不在于如何让它发挥作用。 最佳答案

c++ - 自动矢量化 : Convincing the compiler that alias check is not necessary

我正在做一些图像处理,为此我受益于矢量化。我有一个可以矢量化的函数,但是我无法让编译器相信输入和输出缓冲区没有重叠,因此不需要进行别名检查。我应该可以使用__restrict__来做到这一点,但是如果缓冲区在作为函数参数到达时未定义为__restrict__,则无法让编译器相信我是绝对确定2个缓冲区永远不会重叠。这是函数:__attribute__((optimize("tree-vectorize","tree-vectorizer-verbose=6")))voidthreshold(constcv::Mat&inputRoi,cv::Mat&outputRoi,constunsi