代码如下:
#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的顺序吗?求解。NSOperationQueue

解决方案 »

  1.   

    [queue setMaxConcurrentOperationCount:3];
    这句不是让并发数为3吗?
    要让顺序执行应该是这样吧:
    [queue setMaxConcurrentOperationCount:1];
      

  2.   

    是的,我没理解这句话,一直以为是这个queue中最多只能放得operation的个数。现在明白了,我可以在queue中放10个operation,然后设置最大并发数为2,那么开始执行最前面的两个opration,这两个不按顺序随机执行,如果其中一个执行完成,或同时执行完成,都会开始执行接下来的两个中的一个,第三个或第四个,或同时执行第3,4个。一次类推,直到10个执行完毕。
      

  3.   

    上结果为证。共6个operation,并发数为2.