草庐IT

gcc-warning

全部标签

c++ - 编译器检测返回对局部变量的引用

由于返回对局部变量的引用,我刚刚被一种讨厌的未定义行为所困扰。我们知道它是邪恶的,通常编译器会打印一个很好的警告来告诉我们......好吧gcc(3.4.2)似乎并没有将检查推得太远。std::stringget_env_value(std::stringconst&key);std::stringconst&get_phase(){std::stringconst&phase=get_env_value("PHASE");//[1]std::cout这可以顺利编译,但我们陷入了未定义行为的恶劣境界。[1]行是可以的,因为标准指定绑定(bind)到const引用的变量的生命周期应该延长

c++ - 关于gcc O3 optimization flag的疑惑

我有g++4.7.3编译器。我正在尝试遵循优化标志描述http://gcc.gnu.org/onlinedocs/gcc-4.7.3/gcc/Optimize-Options.html下一个问题:我有一个程序,它使用-O2和-O3标志给出不同的时间。-O2比-O3快两倍。O2时间为8毫秒,O3时间为16毫秒。所以我想了解到底是什么造成了差异。在上面的链接中,我看到:“O3优化更多。-O3开启所有由-O2指定的优化,同时开启-finline-functions、-funswitch-loops、-fpredictive-commoning、-fgcse-after-reload、-ftr

c++ - luarocks 'gcc-plugin.h' 构建错误

我正在尝试将torch与hdf5包一起使用。我正在尝试通过luarocksinstallhdf5安装它,但在构建阶段我收到有关gcc-pluginheader的错误。(gcc依赖于clang后端)。完整的错误信息是:luarocksinstall--localhdf5Installinghttps://luarocks.org/hdf5-2.0.0-1.src.rock...Usinghttps://luarocks.org/hdf5-2.0.0-1.src.rock...switchingto'build'modeWarning:variableCFLAGSwasnotpassedi

c++ - 使用 cmake 添加 _CRT_SECURE_NO_WARNINGS 定义

是否可以使用cmake添加_CRT_SECURE_NO_WARNINGS预处理器定义?add_definitions(-CRT_SECURE_NO_WARNINGS)add_definitions(-_CRT_SECURE_NO_WARNINGS)add_definitions(_CRT_SECURE_NO_WARNINGS)这些是我到目前为止尝试过的。这些尝试都没有成功。 最佳答案 使用这个:if(MSVC)add_definitions(-D_CRT_SECURE_NO_WARNINGS)endif()参见here获取官方文档。

c++ - Clang 与 GCC : Single-colon in Enum usage

以下代码使用g++-std=c++11编译,但不使用clang++-std=c++11。问题在此上下文中,单冒号“运算符”的含义是什么?澄清/编辑:GCC如何解释代码?如何让GCC不编译这段代码?(这里假设Clang遵循C++标准。)是否有针对此的标志?代码用g++-std=c++11main.cpp和clang++-std=c++11main.cpp编译。我正在使用GCC4.8和Clang6.0.0(主干)。#include#includeenumDir{LEFT,RIGHT};intmain(intargc,char**argv){//Interestingline:Noticet

c++ - gcc 警告未使用的静态函数,但不是静态内联 : is there a practical distinction?

我的gcc版本(5.4)会警告未使用的static函数,即使在使用-Wall的头文件中也是如此。如果相同的函数定义为staticinline或只是inline,它不会提示。例如,文件unused.h中的以下函数:staticvoidfoo(){}...当包含在test.cpp文件中时,如下所示:#include"unused.h"当使用-Wall编译器时生成以下编译器诊断:Infileincludedfromtest.cpp:11:0:unused.h:Atglobalscope:unused.h:9:13:warning:‘voidfoo()’definedbutnotused[-W

c++ 可以通过引用传递临时 lambda(适用于 msvc/windows 但不适用于 gcc/linux)吗?

假设我有以下代码片段://globalvariablestd::threadworker_thread;//Templatefunctiontemplatevoidstart_work(Functor&worker_fn)//lambdapassedbyref{worker_thread=std::thread([&](){worker_fn();});}这样调用:voiddo_work(intvalue){printf("Hellofromworker\r\n");}intmain(){//Thislambdaisatemporaryvariable...start_work([do

c++ - 是否可以在 C++17 的 GCC 中使用显式寄存器变量?

我正在使用explicitregistervariables使用没有machine-specificconstraints的寄存器将参数传递给原始Linux系统调用(例如x86_64上的r8、r9、r10)按照建议here.#include#ifdef__i386__#define_syscallOper"int$0x80"#define_syscallNumReg"eax"#define_syscallRetReg"eax"#define_syscallReg1"ebx"#define_syscallReg2"ecx"#define_syscallReg3"edx"#define_s

c++ - 创建自定义#warning 标志

我正在构建一个商业应用程序,我们正在使用一些GPL代码来帮助我们。如何添加#warning或#error语句,以便在为调试构建代码时发出警告,但在为发布构建时抛出错误?我能做到:#warningthiscodeisreleasedunderaCCLlicensingscheme,seeSource_Code_License.rtf#warningthiscodeisnotLGPL-compliant#warningthiscodewascopiedverbatimfromaGPLicensedfile在文件的开头,但我可以做得更好吗?如果包含文件,是否有更好的标记文件的方法?我正在使用

c++ - 通过 Visual Studio 运行 GCC

我一直在编写一个应用程序来解析VisualStudio2010解决方案并尝试使用GCC对其进行编译。在我构建应用程序时,我已经让它在标准控制台窗口中运行并且我没有遇到任何问题(前提是您忽略我轻微的GCC不兼容性;))。问题来了,当我在VisualStudio下执行这个应用程序时,它可以正常启动,但是当它生成GCC子进程时,它报告:cc1plus.exe:errorwhileloadingsharedlibraries:?:cannotopensharedobjectfile:Nosuchfileordirectory这非常令人困惑,因为它作为独立的控制台应用程序运行良好。那么有人知道发