有没有好的方法将
vector<int32_t>
转换为NSNumber
的NSArray
,或者循环并添加到NSMutableArray
是唯一的方法?vector<int32_t>
转换为NSNumber
的NSArray
,或者循环并添加到NSMutableArray
是唯一的方法?如果你有一个对象向量,你可以执行以下操作:
NSArray *myArray = [NSArray arrayWithObjects:&vector[0] count:vector.size()];
然而,如果您的向量包含原始类型,例如 NSInteger
, int
, float
等,您将不得不手动循环向量中的值并首先将它们转换为 NSNumber
。
vector<int32_t>
,所以不幸的是我必须无论如何循环遍历所有的值。 - N_A是的,你可以使用以下方法从 std::vector<NSInteger>
创建一个 NSArray
:
// 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
。如果你将它传递到期望NSObject
数组的外部API中,它很可能会引发错误(即:objc_msgSend
中的EXC_BAD_ACCESS
)。NSNumber
。我只会在另一个API需要它时才在我的程序中使用这个NSArray
的NSInteger
- Apple有一些这样的API - 它们只是不能很好地配合使用。NSNumber
,但是因为你的精彩回答,我给了你一个赞! - N_A