GCD一個(gè)面試題
// main thread
NSLog(@"a");
dispatch_async(dispatch_get_main_queue(), ^{
NSLog(@"b");
});
dispatch_async(dispatch_get_global_queue(0, 0), ^{
NSLog(@“c”);
});
結(jié)果:
用xcode打印應(yīng)該是a, c, b
但是真實(shí)的結(jié)果應(yīng)該是a, b, c 或者 a, c, b
由于b在主線程中打印,由于主線程可能有其他耗時(shí)的任務(wù)在,所以b的打印再c之后了
答案可見下面的實(shí)例中,這個(gè)打印結(jié)果b在100個(gè)c中間某個(gè)位置打印出來的
// main thread
NSLog(@"a");
dispatch_async(dispatch_get_main_queue(), ^{
NSLog(@"b");
});
dispatch_async(dispatch_get_global_queue(0, 0), ^{
for (int i = 0; i < 100; i++) {
NSLog(@"c");
}
});