是否有一个转换的好办法vector<int32_t>
到NSArray
的NSNumber
或循环并添加到NSMutableArray
几乎唯一的办法?
Answer 1:
如果你有对象的载体,你可以做到以下几点:
NSArray *myArray = [NSArray arrayWithObjects:&vector[0] count:vector.size()];
但是,如果你的载体包含基本类型,如NSInteger
, int
, float
等,你必须手动循环向量中的值,并将其转换为一个NSNumber
第一。
Answer 2:
是的,则可以创建一个NSArray
的NSInteger
从A S std::vector<NSInteger>
通过使用以下的方法:
// thrown together as a quick demo. this could be improved.
NSArray * NSIntegerVectorToNSArrayOfNSIntegers(const std::vector<NSInteger>& vec) {
struct MONCallback {
static const void* retain(CFAllocatorRef allocator, const void* value) {
/* nothing to do */
return value;
}
static void release(CFAllocatorRef allocator, const void* value) {
/* nothing to do */
}
static CFStringRef copyDescription(const void* value) {
const NSInteger i(*(NSInteger*)&value);
return CFStringCreateWithFormat(0, 0, CFSTR("MON - %d"), i);
}
static Boolean equal(const void* value1, const void* value2) {
const NSInteger a(*(NSInteger*)&value1);
const NSInteger b(*(NSInteger*)&value2);
return a == b;
}
};
const CFArrayCallBacks callbacks = {
.version = 0,
.retain = MONCallback::retain,
.release = MONCallback::release,
.copyDescription = MONCallback::copyDescription,
.equal = MONCallback::equal
};
const void** p((const void**)&vec.front());
NSArray * result((NSArray*)CFArrayCreate(0, p, vec.size(), &callbacks));
return [result autorelease];
}
void vec_demo() {
static_assert(sizeof(NSInteger) == sizeof(NSInteger*), "you can only use pointer-sized values in a CFArray");
std::vector<NSInteger> vec;
for (NSInteger i(0); i < 117; ++i) {
vec.push_back(i);
}
CFShow(NSIntegerVectorToNSArrayOfNSIntegers(vec));
}
但是,你需要非常谨慎有关使用本集合。 基金会预计元素是NSObject
秒。 如果你将它传递到一个期望的阵列外部API NSObject
S,它可能会导致错误(读: EXC_BAD_ACCESS
在objc_msgSend
)。
通常情况下,一个将它们转换为NSNumber
。 我会用这个NSArray
的NSInteger
在我的计划只有在另外的另一个API 需要它S(苹果有几个) -他们只是不玩很好地结合在一起。
文章来源: convert std:vector to NSArray