代码如下:
运行后的结果贴图:
三个方法执行的顺序不是固定的,每次都不一样。如果按照先入先出的规则,不应该是start1 ,start2,start3的顺序吗?求解。
#import "OperationTest.h"
#define EMPTY_LOOP(count) for (int i =0; i<count; i++) {}
@implementation OperationTest
-(void)operationTest
{
NSInvocationOperation* invocation1 = [[NSInvocationOperation alloc] initWithTarget:self selector:@selector(dosomething1) object:nil];
NSInvocationOperation* invocation2 = [[NSInvocationOperation alloc] initWithTarget:self selector:@selector(dosomething2) object:nil];
NSInvocationOperation* invocation3 = [[NSInvocationOperation alloc] initWithTarget:self selector:@selector(dosomething3) object:nil];
NSOperationQueue* queue =[[NSOperationQueue alloc] init];
[queue setMaxConcurrentOperationCount:3];
[queue addOperation:invocation1];
[queue addOperation:invocation2];
[queue addOperation:invocation3];
}
-(void)dosomething1
{
NSLog(@"do something 1 start");
EMPTY_LOOP(1000);
NSLog(@"do something 1 end");
}
-(void)dosomething2
{
NSLog(@"do something 2 start");
EMPTY_LOOP(1000);
NSLog(@"do something 2 end");
}
-(void)dosomething3
{
NSLog(@"do something 3 start");
EMPTY_LOOP(1000);
NSLog(@"do something 3 end");
}
@end
运行后的结果贴图:
三个方法执行的顺序不是固定的,每次都不一样。如果按照先入先出的规则,不应该是start1 ,start2,start3的顺序吗?求解。