Instance *instance1=[Instance sharedInstanceByGCD];
Instance *instance2=[Instance sharedInstanceByGCD];
NSLog(@"%@---%@",instance1,instance2);
打印输出instance1=instance2的地址,说明通过线程锁创建成功了单例
Instance *instance3=[Instance sharedInstanceBySynchronized];
Instance *instance4=[Instance sharedInstanceBySynchronized];
NSLog(@"%@---%@",instance3,instance4);
打印输出instance3=instance4的地址,说明通过GCD创建成功了单例
2015-11-01 22:38:04.700 单例测试性能[746:28450] 11<Instance: 0x7f99c35170c0>---<Instance: 0x7f99c35170c0>
2015-11-01 22:38:04.700 单例测试性能[746:28450] 11<Instance: 0x7f99c3630d30>---<Instance: 0x7f99c3630d30>
两个单例的地址相同,创建单例成功
这里我们做一下拓展,测试一下两个单例的性能
代码如下:需要用到单例需导入单例的头文件
可以在本文件调用[self test1],[self test2],看一下时间差,就能知道性能的好坏
- (void)test1
{
long num=1000;
CFAbsoluteTime start=CFAbsoluteTimeGetCurrent();
for (int i=0; i<num; i++) {
Instance *inst=[Instance sharedInstanceByGCD];
}
CFAbsoluteTime end=CFAbsoluteTimeGetCurrent();
NSLog(@"test1:%f",end-start);
}
- (void)test2
{
long num=1000;
CFAbsoluteTime start=CFAbsoluteTimeGetCurrent();
for (int i=0; i<num; i++) {
Instance *ins=[Instance sharedInstanceBySynchronized];
}
CFAbsoluteTime end=CFAbsoluteTimeGetCurrent();
NSLog(@"test2:%f",end-start);
}
2015-11-01 22:38:05.880 单例测试性能[746:28450] test1:0.000168
2015-11-01 22:38:05.880 单例测试性能[746:28450] test2:0.000319
2015-11-01 22:38:08.128 单例测试性能[746:28450] test1:0.000164
2015-11-01 22:38:08.128 单例测试性能[746:28450] test2:0.000327
从打印出来的数字可以看出GCD的单例优于Synchronized的性能