草庐IT

reference-type

全部标签

c++ - 针对 Automake 生成的库进行编译时 undefined reference

我在使用automake的项目中遇到一个非常奇怪的链接错误。从手册上看,我所做的似乎很简单,所以我真的很想知道我做错了什么......我的项目有三个文件夹:src/common,我把一些C++文件编译成一个libube-common.astaticlibsrc/engine,其中我将一些文件编译成一个libube-engine.astaticlibsrc/client,其中...你猜对了,libue-client.a,还有一个文件ube.cpp,它是我的main每个库都使用Makefile.am编译,如下所示:noinst_LIBRARIES=libube-common.alibube

c++ - 神秘的链接器错误 "undefined reference to ` __gxx_personality_v 0'"在 cygwin 中使用 clang

我做了一些搜索,所有答案似乎都建议使用clang++而不是clang(或者更确切地说是g++代替gcc),这就是我最初所做的。尽管如此,问题仍然存在,无论是clang++-Wall-std=c++11-otest.exetest.cppA.cppB.cppetc.cpp或clang++-lstdc++-Wall-std=c++11-otest.exetest.cppA.cppB.cppetc.cpp编译和链接在Cygwin中使用g++工作正常。g++-Wall-std=c++11-otest.exetest.cppA.cppB.cppetc.cpp更新:这是链接期间的信息。clang是

c++ - "enumeral and non-enumeral type in conditional expression"背后的推理

自C++11过渡以来,GCC输出警告“条件表达式中的枚举和非枚举类型”。我想了解此警告背后的原因。比较枚举常量有什么危险?很明显我们可以通过以下方式摆脱这个警告-Wno-enum-compare通过显式转换为整数类型但为什么这么麻烦?就个人而言,我一直努力编写无警告代码,通常默认发出的警告是非常合理的。例如,它认为比较有符号和无符号整数是危险的。但是使用枚举是广泛使用的惯用C++元编程。我不知道有任何替代方案,它同样具有可读性、简明扼要且不需要任何实际存储空间。举一个具体的例子:下面的元函数会出现什么问题,以至于警告就足够了?templatestructMaxSize;template

c++ - 使用模板类型参数列表中的 TYPE

我想使用类模板参数列表中的类型信息。快速解决方法的工作示例:structNoParam{};templatestructTypeList{typedefAT1;typedefBT2;typedefCT3;typedefDT4;typedefET5;typedefFT6;};templateclassApplication{Application(){//theactualcodewillstorethecreatedinstancesinatupleormap..std::make_unique::T1>();std::make_unique::T2>();std::make_uniq

c++ - 模板类型的值,如 std::false_type

如果std::false_type是一个类型,这个类型的有效值是多少?如果我只想实现如下所示的返回类型为std::false_type的函数,我该如何实现?typenamestd::false_typeoperator()(){returndeclval();} 最佳答案 按照评论中的建议尝试returnstd::false_type{};或return{};。 关于c++-模板类型的值,如std::false_type,我们在StackOverflow上找到一个类似的问题:

c++ - 尽管包含 <typeinfo> ,但 Clang 拒绝 type_info 为不完整

我不明白为什么Clang会拒绝以下代码:#include#includeconstchar*get_name(conststd::exception_ptreptr){returneptr.__cxa_exception_type()->name();}intmain(){}GCC没问题,但是Clang提示type_info是一个不完整的类型:$g++-4.7-std=c++0x-O3-Wall-Wextrat.cc-ot$clang++-3.2-std=c++0x-O3-Wall-Wextrat.cc-ott.cc:6:37:error:memberaccessintoincompl

c++ - 休斯顿,我们有一个 undefined reference

MEGAEDIT3000我发现了undefinedreference的原因。我检查了我的.o文件中的符号,它们只是丢失了。只是不在那里。没有明显的原因。我已经检查了危害.o文件的来源,但似乎一切正常。我认为它可能是那些讨厌的#ifdef...#endifblock之一,像熊陷阱一样狡猾地隐藏在代码行中,等待它的受害者。但我找不到任何。将一些函数定义移动到文件的末尾并将它们包含在适用于Linux的#ifdef...#endifblock中后,符号神奇地出现了,一切都很好。感谢您的宝贵时间。Outdated,donotread.Ihavebeenassignedtoonebigprojec

c++ - C2280 : attempting to reference a deleted function (union, 结构体,复制构造函数)

当我尝试在VisualStudio2015中编译以下最小示例时,我遇到了误导性错误消息的问题:classVector{floatx;floaty;public:Vector(floatx,floaty):x(x),y(y){}Vector&operator=(constVector&v){x=v.x;y=v.y;return*this;}//Vector(Vector&&)=default;};classRect{public:union{struct{Vectorp1,p2;};struct{floatp1x,p1y,p2x,p2y;};};Rect():p1(0,0),p2(0,0

C++为什么有类头却有 "Unknown Type"?

这个问题在这里已经有了答案:Resolvebuilderrorsduetocirculardependencyamongstclasses(12个答案)关闭6年前。我有这个头文件,我正在尝试创建Item类型的变量。我已经包含了#include"Item.h",但在编译时我仍然在两个私有(private)变量上遇到unknowntypenameItem错误。#ifndefPLAYER_H#definePLAYER_H#include#include"Item.h"usingstd::vector;classPlayer{public://constructorPlayer(void);/

c++ - C++ 临时对象的生命周期是在什么时候创建的? : expression extended by binding it to a local const reference?

我不清楚是否可以通过将临时对象绑定(bind)到?:表达式中的常量引用来延长临时对象的生命周期:classFoo{...};Foo*someLValue=...;constFoo&=someLValue?*someLValue:Foo();通过调用默认构造函数Foo()创建的临时对象的生命周期是否通过将其绑定(bind)到本地constref来延长,即使绑定(bind)是有条件的?还是因为Foo()的临时值会在?:表达式的末尾被销毁,所以这会创建一个悬空引用? 最佳答案 在此代码中,条件运算符的第二个和第三个操作数具有不同的值类别(