これは正しい方法ですか?
// convert
const void *buffer = NULL;
size_t size = 0;
dispatch_data_t new_data_file = dispatch_data_create_map(data, &buffer, &size);
if(new_data_file){ /* to avoid warning really - since dispatch_data_create_map demands we care about the return arg */}
NSData *nsdata = [[NSData alloc] initWithBytes:buffer length:size];
// use the nsdata... code removed for general purpose
// clean up
[nsdata release];
free(buffer); // warning: passing const void * to parameter of type void *
正常に動作しています。私の主な懸念はメモリリークです。データ バッファのリークは楽しいものではありません。NSData、バッファ、dispatch_data_t new_data_file はすべて正常ですか?
http://opensource.apple.com/source/libdispatch/libdispatch-187.7/dispatch/data.cで読めるものから、バッファは DISPATCH_DATA_DESSTRUCTOR_FREE のようです。つまり、バッファを解放するのは私の責任ですか?