草庐IT

c++ - g++-4.8 C++ stdlib 动态库

我用gcc48(通过Homebrew软件安装)编译了一个“Helloworld”C++文件,当我检查链接的动态库时,我看到:otool-L测试Test:/usr/local/Cellar/gcc48/4.8.1/gcc/lib/libstdc++.6.dylib(compatibilityversion7.0.0,currentversion7.18.0)/usr/lib/libSystem.B.dylib(compatibilityversion1.0.0,currentversion169.3.0)/usr/local/Cellar/gcc48/4.8.1/gcc/lib/libg

使用gcc/g++查看C语言预处理,编译,汇编,连接,以及动静态库的区分

文章目录使用gcc/g++gcc如何完成编译后生成可执行文件?预处理(进行宏替换)编译(生成汇编)汇编(生成机器可识别代码)连接(生成可执行文件或库文件)最后记忆小技巧在这里涉及到一个重要的概念:函数库静态库和动态库两种区分win和linux的动静态库后缀动态链接的优缺点安装C语言的静态库gcc的选项使用gcc/g++首先检查自己的linux机器有没有安装gcc--version没有安装的话执行下面命令以安装gcc和g++sudoyuminstall-ygcc-c++CentOS7默认匹配的gcc版本是4.8gcc是一个专门用来编译链接C语言的编译器,而g++是一个专门用来编译链接C++的编译

c++ - 确定所有由 g++ 内联的函数调用

这个问题在这里已经有了答案:Howwilliknowwhetherinlinefunctionisactuallyreplacedattheplacewhereitiscalledornot?(10个答案)关闭8年前。我正在尝试诊断一个奇怪的性能问题,我认为它与GCC未能在C++中内联某些函数调用有关,但我不确定是哪个函数调用。GCC是否有一个标志来列出执行内联的所有行号?

c++ - g++ 将返回的字符串文字视为 const char 指针而不是 const char 数组

当从应该使用g++(版本4.7.3)执行隐式转换的函数返回字符串文字时,我看到了一些奇怪的行为。任何人都可以解释为什么以下代码:#includeclassTest{public:templateTest(constchar(&foo)[N]){printf("Templateconstchararrayconstructor\n");}Test(char*foo){printf("char*constructor\n");}};Testfn(){return"foo";}intmain(){Testt("bar");Testu=fn();return0;}产生结果:Templateco

c++ - 将负文字作为无符号参数传递时,g++ 会发出警告吗?

考虑:unsignedfoo(unsignedu){returnu;}intmain(){foo(-1);return0;}在这里,函数foo被调用时u等于4294967295(或类似的大值)。如果程序员不注意,这可能相当出乎意料。例如,也许您正在实现pow以将Polynomial类提升为幂。因为只有正幂是可能的,所以你决定签名Polynomialpow(constPolynomial&p,unsignedexp);然后一个粗心的程序员调用pow(p,-1)得到一个逆函数,而不是一个警告或错误,它似乎可以工作,但可能会使用大量的内存和时间产生一个完全错误的答案。g++5.3.0和gcc

c++ - g++ 和 clang++ 变量模板和 SFINAE 的不同行为

另一个类型的问题“g++和clang++之间谁是正确的?”适用于C++标准专家。假设我们想将SFINAE应用于变量模板,以便仅当模板类型满足特定条件时才启用该变量。例如:当(且仅当)模板类型具有具有给定签名的foo()方法时,启用bar。通过具有默认值的附加模板类型使用SFINAEtemplatestaticconstexprintbar=1;适用于g++和clang++但有一个问题:可以劫持解释第二个模板类型所以inti=bar;给出一个编译错误inti=bar;编译没有问题。因此,出于对SFINAE的无知,我尝试启用/禁用同一变量的类型:templatestaticconstexp

c++ - g++ : Is there a way to access compile flags inside the code that is being compiled?

有没有一种方法(例如,定义的常量)来访问正在编译的代码中运行编译器的编译标志。例如,我想要一个程序来写入编译时使用的标志。intmain(){std::coutgcc/g++是否存在这样的常量?或者更好:是否有在gcc和clang中都定义的常量?我对检查优化级别和-march标志的值特别感兴趣。那么,如果没有显示所有标志的常量,是否至少有显示这些值的常量? 最佳答案 以下命令打印出所有预定义的宏:g++-dM-E-这适用于gcc和g++。您可以自行检查-不幸的是,没有宏可让您轻松访问完整的gcc/g++命令行。幸运的是,大多数-m.

c++ - 如何找到在 g++ 代码中调用给定成员函数或 ctor 的所有位置?

我试图在一个庞大而陈旧的代码库中找到所有调用了某些构造函数或函数的地方。具体来说,这些是std::string中的某些构造函数和成员函数。类(即basic_string)。例如,假设有一行代码:std::stringfoo(fiddle->faddle(k,9).snark);在这个例子中,看这个并不明显snark可能是char*,这是我感兴趣的。目前尝试解决这个问题我研究了gcc的一些转储功能,并生成了其中一些功能,但我没能找到任何告诉我给定代码行将生成对string的调用的信息。构造函数采用constchar*.我还使用-s编译了一些代码以保存生成的等效汇编代码。但这有两个问题:函

c++ - 使用 g++ 和 specs 文件进行预处理

问题涉及arm-none-eabi-g++6.2和针对newlib-nano的链接。当我使用-specs=nano.specs预处理C源代码时,文件newlib.h来自目录newlib-nano包括:echo'#include'|\/opt/gcc-arm-none-eabi-6_2-2016q4/bin/arm-none-eabi-gcc-specs=nano.specs-xc-E-|\grep'^#1.*newlib\.h'输出#1"/opt/gcc-arm-none-eabi-6_2-2016q4/arm-none-eabi/include/newlib-nano/newlib.

c++ - g++ 无法解析模板函数重载

对于以下代码,g++失败:templateinlinevoidfunc(constT&,R...){}templatestructS{};templateinlinevoidfunc(constS&,R...){}intmain(){func(42);func(S());//OKfunc(S(),1);//NOKfunc(S(),1);//NOK}与::Infunction'intmain()'::13:21:error:callofoverloaded'func(S,int)'isambiguousfunc(S(),1);//NOK^:13:21:note:candidatesare