草庐IT

object-reference

全部标签

C++ 引用类型作为 Objective-C++ 中的实例变量

C++引用类型作为实例变量在Objective-C++中是被禁止的。我该如何解决这个问题? 最佳答案 您不能明智地使用引用作为实例变量,因为无法初始化实例变量并且无法重新设置引用。替代方法可能是简单地使用(可能是智能的)指针。让您更接近C++类行为的另一种可能性是为您的C++成员使用PIMPL样式的成员:structCppImpl{SomeClass&ref;CppImpl(SomeClass&ref):ref(ref){}};@interfaceA:NSObject{CppImpl*pimpl;}-(id)initWithRef:

c++ - Vector of pointer to objects,需要vector的深拷贝,但是对象是继承对象的基础

我想要一个包含指向对象指针的vector的深层拷贝,但对象可以是C或B。我知道混淆(我解释它的方式),让我举例说明。classA{A(constA©me){}voidUnableToInstantiateMeBecauseOf()=0;};classB{B(constB©me):A(copyme){}};classC{C(constC©me):A(copyme){}};std::vector*CreateDeepCopy(std::vector&list){std::vector*outList=newstd::vector();for(std::vector:

C++ 初学者 : what is the point of using a variable by reference if using "const"?

我想知道这个函数声明中的逻辑:CMyException(conststd::string&Libelle=std::string(),...按引用使用变量有什么意义?通常,只要变量可能在内部被修改,您就会通过引用传递一个变量...因此,如果您使用关键字const,这意味着它永远不会被修改。这是矛盾的。谁能给我解释一下? 最佳答案 实际上引用是用来避免不必要的对象拷贝。现在,要理解为什么使用const,试试这个:std::string&x=std::string();//error编译会报错。这是因为表达式std::string()创

c++ - 对派生类的 undefined reference

编辑:与c++undefinedreferenceto`vtable有关我正在尝试做一个关于继承的项目,但我遇到了这个错误:/tmp/ccw1aT69.o:Infunction`main':main.cpp:(.text+0x15):undefinedreferenceto`Derived::Derived(int)'/tmp/ccw1aT69.o:Infunction`Derived::~Derived()':main.cpp:(.text._ZN20DerivedD2Ev[_ZN20DerivedD5Ev]+0x13):undefinedreferenceto`vtableforD

c++ - C++ 和 Objective C 中的多态性

我是ObjectiveC的新手,我想更清楚地理解protocol的概念。@protocolprotocolName@optional@required@end我可以将@optional部分与virtualfunction和@required部分与C++的purevirtualfunction相关联吗?@protocol是Objective-C创建接口(interface)和抽象类的方式吗? 最佳答案 Is@protocoliswayofObjective-Ctocreateinterfaceandabstractclass?没错。C

c++ - 由于对具有 std::string 的方法的 undefined reference ,链接 webrtc-native 时出错

我正在尝试构建webrtc版本62,使用以下内容1.gitcheckout-bbranch62refs/remotes/branch-heads/622.gngenout_release_62/x64/Debug--args="rtc_include_tests=falsertc_use_h264=falseuse_rtti=trueis_component_build=falseenable_iterator_debugging=falseenable_nacl=falsetarget_os=\"linux\"target_cpu=\"x64\"is_debug=true"3.nin

c++ - 如何解决出现在 Objective-C++ 而不是 Objective-C 中的链接错误?

我正在将我的AppDelegate文件从.m转换为.mm(Objective-C到Objective-C++),以便我可以访问用Objective-C++编写的第三方库。在Objective-C中,我的应用程序委托(delegate)构建并运行良好。但是当我更改扩展名时,项目构建并且出现链接错误,所有这些都缺少我使用的用C编写的静态库中的符号。这些错误是具有以下格式的经典链接错误:“MyFunction(arguments)”,引用自:-MyAppDelegate.o中的[MyAppDelegatemyMethod]找不到符号所有的问题都在应用委托(delegate)对象中。我知道我已

c++ - 如何在 Objective-C 中包装 C++ 库?

我有一个包含数据结构实现的C++库(仅限.h),我想在我的iPhone应用程序中使用它。首先,我在objective-C++中编写了一个包装器作为一个类,通过组合,它具有C++类的ivar。然后我“不得不”将包装器类扩展名更改为.mm,这看起来不错。但是后来我必须将这个包装的类文件包含到其他几个文件中,所以我也必须更改它们的扩展名(以防止一波编译时错误)。我说的对吗?有没有办法将.mm扩展名“限制”为几个文件?(从而防止名称冲突等)编辑:更多可能有用的信息,我使用LLVM1.5作为编译器(我注意到编译时错误的数量从GCC4.2到LLVM1.5不等,但我不确定这是否意味着什么,因为我没有

c++ - "Provides no initializer for reference member..."

经过一些谷歌搜索后,我找不到这个问题的答案。如何初始化它,为什么需要初始化?#include"CalculatorController.h"CalculatorController::CalculatorController(SimpleCalculator&aModel,ICalculatorView&aView){\\(thisisthebracketinformingmeoftheerror)fModel=aModel;fView=aView;}标题:#pragmaonce#include"ICalculatorView.h"#include"SimpleCalculator.h

C++ 标准 : return by copy to initialize a reference without RVO: is there any copy?

让我们考虑下一个示例:structbig_type{};//Returnbycopyautofactory(){returnbig_type{};}voidany_scope_or_function(){big_type&&lifetime_extended=factory();}假设RVO被禁止或根本不以任何方式存在,big_type()是否会或可以被复制?还是将引用直接绑定(bind)到return语句中构造的临时对象?我想确保big_type析构函数仅在any_scope_or_function结束时被调用一次。我使用C++14,以防某些行为在标准版本之间发生变化。