[英]Using an Objective-C Class in C++
我是Objective-C的新手,我正在为我们的项目构建一个iCloud实用程序库。 我在Objective-C中创建了一个iCloud实用程序类。 我注意到在Objective-C中使用C ++类有很多问题,但反过来却很少。 问题是,我们的项目(以及构建我们项目的引擎)完全用C ++编写,因此,我编写的objective-c icloud类需要可以从我正在编写的C ++接口访问。
这是一个例子:
#import <Foundation/Foundation.h>
@interface iCloudUtil : NSObject
@property(nonatomic, assign, getter=isAvailable) BOOL iCloudIsAvailable;
@property (assign) NSString *urlToFile;
-(bool) init_iCloud;
-(void) loadDocument: (NSString*)fileUrl;
@end
#import "iCloudUtil.h"
@synthesize urlToFile = _urlToFile;
@synthesize iCloudIsAvailable = _iCloudIsAvailable;
//////////////////////////////////////////////////////
@implementation iCloudUtil
-(bool) init_iCloud{
//blah blah
}
-(void) loadDocument: (NSString*)fileUrl{
//more blah blah
}
@end
我尝试使用它的C ++类是这样的:
#ifndef __ICloudInterface__
#define __ICloudInterface__
class ICloudInterface {
static ICloudInterface *_instance;
bool iCloudIsAvailable;
public:
ICloudInterface();
~ICloudInterface();
bool init_iCloud();
};
#endif
我想要做的是能够在我的C ++类中创建一个iCloudUtils实例,但我不能在我的c ++类中#include它,而不会在程序中获得关于“Stray”@'的200多个错误。 我对Objective-C非常缺乏经验,所以将它与C ++混合更是如此,所以有人可以帮我提出如何实现这一目标的建议吗?
编辑:只是为了清除它,我已经尝试将.cpp重命名为.mm但这并没有解决问题。
编辑2:另外,从我通过阅读理解(请纠正我,如果我错了)通过将文件更改为.mm,任何包含它的文件也必须更改为.mm。 我不能这样做,因为它需要更改非常大量的文件以适应单个可选类(提醒这个项目及其引擎是全部c ++,这是一个跨平台的引擎和项目)。
将.cpp文件名切换为.mm - 这将从c ++转换为objective-c ++。 然后你将编译一个理解标题的语言。
您不能在文件扩展名为.cpp的C ++文件中使用Obj.C类对象
您可以在Obj.C类中使用扩展名为.mm的c ++类
要在C ++和Obj.C类之间进行通信,请在.mm文件中编写helper c ++类
说:
interface iCloudUtil : NSObject // in .m file
class ICloudInterface //in cpp file.
您可以使用桥接类帮助将.cpp文件中的cpp类与.m文件中的obj.C类进行通信。
//include iCloudUtil.h only in ICloudBridge.mm file.
class ICloudBridge {
static ICloudBridge *_instance;
public:
ICloudBridge();
~ ICloudBridge();
ICloudBridge *sharedICloudBridge();
void loadDocument();
};
void ICloudBridge:: loadDocument()
{
iCloudUtil *obj = [iCloudUtil alloc] init] autorelese];
[obj loadDocument:@"DocName"];
}
在ICloudInterface.cpp中
ICloudBridge *bridge = ICloudBridge::sharedICloudBridge();
bridge-> loadDocument();
我认为你必须在源代码文件名中使用.mm
扩展名而不是.m
扩展名,或者将文件设置为在Xcode中编译为Objective-C ++。
当然 - 你可以做到这一点。 所需要的主要是将.CPP文件设置为“Objective-C ++ Source” - “。mm”约定是一种自动精确的,但不是必需的。 然后你可以随意混合搭配:
#import <Foundation/Foundation.h>
#include <iostream>
@interface iCloudUtil : NSObject
@property(nonatomic, assign, getter=isAvailable) BOOL iCloudIsAvailable;
@property(assign) NSString *urlToFile;
- (bool) init_iCloud;
- (void) loadDocument:(NSString*)fileUrl;
@end
//////////////////////////////////////////////////////
@implementation iCloudUtil
@synthesize urlToFile = _urlToFile;
@synthesize iCloudIsAvailable = _iCloudIsAvailable;
- (bool) init_iCloud {
NSLog(@"init_iCloud");
std::cout << "i can mix std c++ in here as well\n";
return YES;
}
- (void) loadDocument:(NSString*)fileUrl {
NSLog(@"url is %@",fileUrl);
}
@end
//////////////////////////////////////////////////////
class ICloudInterface {
static ICloudInterface* _instance;
bool iCloudIsAvailable;
iCloudUtil* myCloudUtil;
public:
ICloudInterface();
~ICloudInterface();
bool init_iCloud();
};
ICloudInterface::ICloudInterface() {
std::cout << "ICloudInterface::ctor\n";
myCloudUtil = [[iCloudUtil alloc] init];
[myCloudUtil init_iCloud];
[myCloudUtil loadDocument:@"file://foo/bar/baz"];
}
ICloudInterface::~ICloudInterface() {
[myCloudUtil release], myCloudUtil = nil;
std::cout << "ICloudInterface::dtor\n";
}
int main(int argc, const char * argv[]) {
std::cout << "Test objc/objc++\n";
ICloudInterface iface;
return 0;
}
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.