N_A*_*N_A 19 c++ vector objective-c++ nsarray
是否有一个转换的好方法vector<int32_t>到NSArray的NSNumber或循环,并增加了NSMutableArray相当多的唯一途径?
Ric*_*III 16
如果您有对象矢量,则可以执行以下操作:
NSArray *myArray = [NSArray arrayWithObjects:&vector[0] count:vector.size()];
Run Code Online (Sandbox Code Playgroud)
但是,如果你的载体包含基本类型,如NSInteger,int,float等等,你必须手动循环向量中的值,并将其转换为一个NSNumber第一.
是的,你可以创建一个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));
}
Run Code Online (Sandbox Code Playgroud)
但是,您对此系列的使用需要非常谨慎.基金会期望元素是NSObjects.如果将它传递给需要NSObjects 数组的外部API ,则可能会导致错误(读取:EXC_BAD_ACCESSin objc_msgSend).
通常,人们会将它们转换为NSNumber.我会用这个NSArray的NSInteger在我的计划只有在另外的另一个API会需要它(苹果有几个) -他们只是不玩很好地结合在一起.
| 归档时间: |
|
| 查看次数: |
10180 次 |
| 最近记录: |