CommonAFNUtil 1.0.0

CommonAFNUtil 1.0.0

测试已测试
Lang语言 Obj-CObjective C
许可证 MIT
发布最后发布2015年11月

李超谦维护。



 
依赖
AFNetworking~> 2.6.3
SVProgressHUD~> 1.1.3
CommonDataCacheManager~> 0.0.2
 

  • 作者:
  • dvlproad

AFN基类

CommonAFNInstance需要

import "NetworkManager.h"

import "CommonDataCacheManager.h"

import

import

CommonDataCacheManager需要

import "NSDictionary+Convert.h"

import "NSData+Convert.h"

import "NSString+MD5.h"

基础知识了解

1、单例:dispatch_once(使用dispatch_once时,不需要使用@synchronized)单例是一种用于实现单例的数学概念,即将类的实例化限制成一个对象的模式。或者我的理解是:单例是一种类,该类只能实例化一个对象。

实现单例模式的函数是void dispatch_once( dispatch_once_t *predicate, dispatch_block_t block);该函数接收一个dispatch_once用于检查该代码块是否已经被调度的谓词(是一个长整型,实际上作为BOOL使用)。它还接收一个希望在应用的生命周期内仅被调度一次的代码块,对于本例就用于shared实例的实例化。 dispatch_once不仅意味着代码仅会被运行一次,而且还是线程安全的,这就意味着你不需要使用诸如@synchronized之类的来防止使用多个线程或者队列时不同步的问题。 Apple的GCD文档证实了这一点:如果被多个线程调用,该函数会同步等等直至代码块完成。

示例:在整个应用中访问某个类的共享实例

+ (NetworkManager *)sharedInstance
{
    static NetworkManager *sharedManager;

    static dispatch_once_t onceToken;
    dispatch_once(&onceToken, ^{
        sharedManager = [[NetworkManager alloc] init];
    });

    return sharedManager;
}

就这些,你现在在应用中就有一个共享的实例,该实例只会被创建一次。下次你任何时候访问共享实例,需要做的仅是:NetworkManager *networkManager = [NetworkManager sharedInstance];

2、线程的同步执行@synchronized为了防止多个线程同时执行同一个代码块,OC提供了@synchronized()指令。使用@synchronized()指令可以锁住在线程中执行的某一个代码块。被保护的(即被锁住)的代码块的其他线程,将被阻塞,这也就意味着,他们将在@synchronized()代码块的最后一条语句执行结束后才能继续执行。 @synchronized()指令的唯一参数可以使用任何OC对象,包括self。这个对象就是我们所谓的信号量。