回答:
NSLog(@"%@", [NSThread currentThread]);
name
mainについても空の説明を返し、number
どこにも見つからない
NSString *s = [NSString stringWithFormat:@"%@", [NSThread currentThread]]; int threadNum = -1; sscanf(s.UTF8String, "<NSThread: 0x%*12[0-9a-f]>{number = %d", &threadNum);
#include <pthread.h>
...
mach_port_t machTID = pthread_mach_thread_np(pthread_self());
NSLog(@"current thread: %x", machTID);
[NSThread currentThread]
クラスメソッドは、NSThreadオブジェクトを返します。そのスレッドオブジェクトのアドレスをログに記録できますが、Xcodeデバッガーに表示されるもののように、数値のスレッドIDをどのように取得しますか?(メインスレッドのスレッド1、およびアプリによって作成される追加スレッドごとに増加する番号。)
あなたはこのように何かをハックすることができます(これはきれいに表示されますが、番号を取得するまで先に進んで分割することができます):
+ (NSString *)getPrettyCurrentThreadDescription {
NSString *raw = [NSString stringWithFormat:@"%@", [NSThread currentThread]];
NSArray *firstSplit = [raw componentsSeparatedByCharactersInSet:[NSCharacterSet characterSetWithCharactersInString:@"{"]];
if ([firstSplit count] > 1) {
NSArray *secondSplit = [firstSplit[1] componentsSeparatedByCharactersInSet:[NSCharacterSet characterSetWithCharactersInString:@"}"]];
if ([secondSplit count] > 0) {
NSString *numberAndName = secondSplit[0];
return numberAndName;
}
}
return raw;
}