vector<int32_t>
aをNSArray
ofに変換する良い方法はありますか、NSNumber
それともループして追加するのがNSMutableArray
ほとんど唯一の方法ですか?
質問する
12747 次
2 に答える
19
オブジェクトのベクトルがある場合は、次のように実行できます。
NSArray *myArray = [NSArray arrayWithObjects:&vector[0] count:vector.size()];
NSInteger
ただし、ベクトルにint
、、、などのプリミティブ型が含まれている場合は、ベクトル内の値を手動でループして、最初float
の値に変換する必要があります。NSNumber
于 2012-04-18T03:27:01.360 に答える
5
はい、次のアプローチを使用して、からのを作成できます。NSArray
NSInteger
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));
}
ただし、このコレクションの使用には十分注意する必要があります。Foundationは、要素がsであることを期待していますNSObject
。の配列を期待する外部APIに渡すと、NSObject
おそらくエラーが発生します(読み取り:EXC_BAD_ACCESS
in objc_msgSend
)。
通常、それらをに変換しますNSNumber
。NSArray
私は自分のプログラムでこれを使用するNSInteger
のは、別の別のAPIがそれを必要とする場合のみです(Appleにはいくつかあります)-それらは一緒にうまく機能しません。
于 2012-04-18T05:29:33.587 に答える