Gibt es eine Möglichkeit, die aktuelle Thread-ID auszudrucken, auf der die aktuelle Methode ausgeführt wird?
(Ziel-c bitte)
Gibt es eine Möglichkeit, die aktuelle Thread-ID auszudrucken, auf der die aktuelle Methode ausgeführt wird?
(Ziel-c bitte)
Antworten:
NSLog(@"%@", [NSThread currentThread]);
name
gibt leere Beschreibung auch für main zurück und number
ist nirgends zu finden
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]
Klassenmethode gibt ein NSThread-Objekt zurück. Sie können die Adresse dieses Thread-Objekts protokollieren, aber wie erhalten Sie die numerische Thread-ID, wie sie im Xcode-Debugger angezeigt wird? (Thread 1 für den Haupt-Thread und zunehmende Anzahl für jeden zusätzlichen Thread, der von Ihrer App erstellt wurde.)
In Swift 5
print("Current thread \(Thread.current)")
In Swift
print("Current thread \(NSThread.currentThread())")
Sie können so etwas hacken (dies wird nur hübsch gedruckt, aber Sie können fortfahren und teilen, bis Sie die Nummer erhalten):
+ (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;
}