草庐IT

c++ - rate++a,a++,a=a+1 和 a+=1 在 C 中的执行效率。假设 gcc 是编译器

这个问题在这里已经有了答案:关闭12年前。PossibleDuplicate:Isthereaperformancedifferencebetweeni++and++iinC++?对于以下的使用,请以C语言的执行时间来评价。在一些采访中,我被问到我应该使用这些变体中的哪个以及为什么。a++++aa=a+1a+=1

c++ - 如何在编译时测试 libstdc++ 的版本,而不是 GCC?

我正在尝试测试libstdc++的版本,因为std::regexisimplemented,butlargelybroken,在版本4.9.0之前随GCC分发的libstdc++版本中。注意:我需要测试libstdc++的版本,而不是GCC,因为Clang也支持使用libstdc++作为标准库。这排除了testingthe__GNUC_PATCHLEVEL__,__GNUC__,and__GNUC_MINOR__macros.__GLIBCXX__宏是日期,不是版本号和doesnotincreasemonotonically.例如,GCC4.8.4附带#define__GLIBCXX_

c++ - VC++允许/##/作为宏的值——如何在eclipse/mingw-gcc中处理它?

我正在尝试在eclipse/mingw-gcc中编译一个真正的win32应用程序,直到现在都没有成功(参见https://stackoverflow.com/questions/9162976/how-to-compile-a-win32-application-in-eclipse-using-the-mingw-gcc-toolchain)无论如何,在解决另一个错误时,文件c:\ProgramFiles(x86)\MicrosoftSDKs\Windows\v7.0A\Include\WTypes.h中的以下行引起了我的注意好奇心:#define_VARIANT_BOOL/##/它

java - 如何使用 gcc 编译器或其他编译器生成 64 位 .dll。无法在 AMD 64 位平台上加载 IA 32 位 .dll

您好,我没有找到如何创建64位dll的解决方案。并使用它的原生C++方法。我使用Java代码metodynatywne.java:classmetodynatywne{static{System.loadLibrary("metodynatywne");}nativepublicvoidsayHello();publicstaticvoidmain(Stringargv[]){newmetodynatywne().sayHello();}}然后生成metodynatywne.h使用javah-jnimetodynatywne我写了metodynatywne.cpp代码:#include

c++ - 如何使用带有 "-fomp"和 "-pg -fprofile-create"的 gcc/gprof 分析 c++?

我很困惑是否可以使用启用了OpenMP的gcc为gprof编译/链接分析构建。据我的谷歌搜索显示,gcc文档似乎对此事保持沉默。根据实验,仅添加-fomp开关会导致启动时出现SIGPROF错误。我也不清楚http://projekt17.pub.lab.nm.ifi.lmu.de/ompp/downloads/$pkgname-$pkgver.tgz是否属于任何帮助,因为包含的文档仅引用带有简单文件的icc。如果可能的话,如何将它添加到现有的构建系统中?[注意:我是一个自学成才的新手,正在从事一个业余项目,请明确说明。谢谢。] 最佳答案

使用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++ Armadillo : GCC vs VC++2013: Operator () and overloading

我正在尝试使用ArmadilloC++库开发Linux/Win64应用程序。以下代码在GCC-4.7中编译,但在使用Armadillo提供的VS项目文件的VisualStudio2013中编译失败。#include#include"armadillo"usingnamespacearma;usingnamespacestd;//worksinGCC-4.7//VC++2013:compileerror:C3066voidfoo1(vec::fixed&bar){bar(1)=1.;}//worksvoidfoo2(vec::fixed&bar){bar.at(2)=1.;}//work

c++ - 当模板template-parameter的模板参数为pack expansion时,gcc失败,clang成功

templatestructS{templatestructA{};templatestructB{};templateclass>structC{};};S::C::B>s1;S::C::A>s2;//gcc5.1.0fails,clang3.6.0succeedsintmain(){}你可以在这里测试http://melpon.org/wandbox/permlink/hhy70gO9LMjLq9nU哪个是正确的,gcc还是clang? 最佳答案 这个问题在gcc6.0中已经解决 关

c++ - 使用 GCC 时 std::put_money 不输出零值

当货币值为零时,std::put_money不会按预期输出“0”字符。我找不到任何解释此行为的内容。例子:#include#includeusingnamespacestd;intmain(){cout.imbue(locale(""));cout我希望输出为“£0.00”(取决于语言环境)但我得到的是“£.00”最终,为零值添加一个特例并不太麻烦,但这种行为对我来说仍然没有意义。这是什么原因(假设是故意的),除了单独处理零之外,是否有任何简单的解决方法?更新这似乎是特定于编译器的,我有报告说它在clang和VS中按预期工作,所以可能是gcc/g++特定的(准确地说是4.9版,但其他版

c++ - 为什么 GCC 允许在 C++ 中使用 round() 即使带有 ansi 和 pedantic 标志?

即使使用-ansi和-pedantic标志,这个程序在GCC下编译是否有充分的理由?#includeintmain(intargc,char*argv[]){doublex=0.5;returnstatic_cast(round(x));}使用g++-ansi-pedantic-Walltest.cpp-otest编译干净(甚至没有警告)。我看到两个问题:round()不应该在符合ISO的模式下对C++可用(因为它来自C99)即使round()在这种情况下可用,它也只能在std命名空间中可用我错了吗? 最佳答案 Thisisabug