草庐IT

arm-linux-gnu-gcc

全部标签

c++ - 构造函数上的 SFINAE 在 VC2017 中有效,但在 clang/gcc 中无效

这个问题在这里已经有了答案:std::enable_iftoconditionallycompileamemberfunction(8个答案)关闭4年前。#includetemplatestructS{template>S(){}template>S(int){}};Ss{};//errorinclang/gcc,OKinVC2017Ss{0};//errorinclang/gcc,OKinVC2017在这两种情况下,clang/gcc都尝试实例化由于SFINAE实际上应该丢弃的ctor。错误信息是:error:notypenamed'type'in'std::enable_if';'

c++ - GCC 编译错误 : declaration of ‘strlen’ must be available

我的问题是,当我想制作一个下载的库时,我从GCC得到了一些奇怪的编译错误。编译器要求更正的代码似乎是正确的。报错都是这样的:Catalogue.h:96:error:therearenoargumentsto‘strlen’thatdependonatemplateparameter,soadeclarationof‘strlen’mustbeavailable这是第96行附近的代码:GaCatalogueEntry(constchar*name,T*data){if(name){_nameLength=(int)strlen(name);//LINE96//copyname_name

c++ - 在 Linux 上编程 C++ 时的非法指令

我的程序每次运行时都做完全相同的事情(将一个点Sprite移到远处)将随机失败,并在终端上显示“非法指令”文本。我的谷歌搜索发现人们在编写汇编时遇到了这个问题,这是有道理的,因为汇编会抛出这些类型的错误。但为什么g++会生成这样的非法指令?这不像我在为Windows编译然后在Linux上运行(即便如此,只要两者都在x86上,AFAIK就不应该导致非法指令)。我将在下面发布主要文件。我无法可靠地重现错误。虽然,如果我进行随机更改(在这里添加一个空格,在那里更改一个常量)强制重新编译,我可以获得一个二进制文件,每次运行时都会因非法指令而失败,直到我尝试设置一个断点,这使得非法指令“消失”。

Linux 驱动开发基础知识——设备树的语法驱动开发基础知识(九)

 个人名片:🦁作者简介:学生🐯个人主页:妄北y🐧个人QQ:2061314755🐻个人邮箱:2061314755@qq.com🦉个人WeChat:Vir2021GKBS🐼本文由妄北y原创,首发CSDN🎊🎊🎊🐨座右铭:大多数人想要改造这个世界,但却罕有人想改造自己。专栏导航:妄北y系列专栏导航:C/C++的基础算法:C/C++是一种常用的编程语言,可以用于实现各种算法,这里我们对一些基础算法进行了详细的介绍与分享。🎇🎇🎇QT基础入门学习:对QT的基础图形化页面设计进行了一个简单的学习与认识,利用QT的基础知识进行了翻金币小游戏的制作🤹🤹🤹Linux基础编程:初步认识什么是Linux,为什么学Lin

c++ - 为什么 GCC 在编译时不评估 constexpr?

举个例子:classsomething{public:staticconstexprintseconds(inthour,intmin,intsec){returnhour*3600+min*60+sec;}}然后:printf("Lookatthetime:%d\n",something::seconds(10,0,0));将使用g++编译为对函数的调用,而不是放置常量。为什么g++会那样做?它没有任何好处,而且有点违背了使用constexpr而不是可怕的宏的目的。 最佳答案 Whywouldg++dothat?constexpr

c++ - GCC 链接器找不到标准库?

我一直在用XCode开发一个学校项目。最终产品必须以带有makefile的源代码形式提交,因此我编写了一个makefile并以这种方式开始编译,以确保我有一个工作拷贝。这是我的生成文件:all:main.oStackList.oworld.oFarm.ogccmain.oStackList.oworld.oFarm.o-g-oProject1main.o:gcc-g-cmain.cppStackList.o:gcc-g-cStacklist.cppworld.cpp:gcc-g-cworld.cppFarm.cpp:gcc-g-cFarm.cppclean:rm*.oProject1编

c++ - std::ofstream == NULL 不会为 -std=gnu++11 编译,任何解决方法?

考虑以下代码:std::ostreamfile;if(file==NULL)std::cout它在通过-std=gnu11(GCC5.2的默认值)或仅使用时完美编译gcccode.cpp-oa.out.不过,-std=gnu++11失败了:nomatchfor‘operator==’(operandtypesare‘std::ofstream{akastd::basic_ofstream}’and‘longint’)`最简单的解决方法是什么?详细信息:我必须使用std=gnu++11才能访问shared_ptr定义。此外,我的一些代码是自动生成的,修改生成器会付出合理的努力-所以我想知

c++ - 在 Mac OSX 和 Linux 下使用 printf 语句进行类型转换

我有一些代码在MacOSX和Linux(Ubuntu、Fedora等)下表现不同。这是关于printf语句中算术运算中的类型转换。代码使用gcc/g++编译。以下内容#includeintmain(){floatdays=(float)(153*86400)/86400.0;printf("%f\n",days);floatfoo=days/30.6;printf("%d\n",(int)foo);printf("%d\n",(int)(days/30.6));return0;}在Linux上生成153.00000054在MacOSX上153.00000055为什么?令我惊讶的是,这适

c++ - GCC -Wunused-function 不起作用(但其他警告有效)

我试图通过使用GCC的-Wunused-function标志在我的代码库中找到未使用的函数。如我所料,使用gcc-Wall-Wunused-functionmain.cpp编译以下代码会打印一个unusedvariable警告:warning:unusedvariable‘x’[-Wunused-variable]但是,编译器不会给出unused-function警告。我该怎么做才能让GCC注意到未使用的函数foo()?//main.cppvoidfoo(){}//should(butdoesn't)trigger'unusedfunction'warningintmain(intar

Linux指定python版本&使用指定版本的python的pip

指定Python版本使用python--version查看当前使用的python版本::~$python--versionPython3.7.0因为我需要使用3.8及以上版本的python,因此需要编辑~/.bashrc文件。在这之前,首先需要确认当前电脑上已经安装了哪些版本的python::~$whereispythonpython:/usr/bin/python3.8-config/usr/bin/python3.8/usr/bin/python2.7/usr/lib/python3.9/usr/lib/python3.8/usr/lib/python2.7/etc/python3.8/e