AFNetWorking涉及的知识点

2018-02-24  本文已影响14人  woniu

这里我们只是向大家简单介绍下AFNetWorking涉及到的知识点,我们在之前以及之后的文章会详细分析这些知识点。

一、Block的写法。

详细地址+Demo:https://www.jianshu.com/p/73e8796942ec

二、FOUNDATION_EXPORT定义与#define定义的区别

#define kMyConstantString @"Hello"
//.h
FOUNDATION_EXPORT NSString * const AFNetworkingReachabilityDidChangeNotification;
FOUNDATION_EXPORT NSString * const AFNetworkingReachabilityNotificationStatusItem;

//.m
NSString * const AFNetworkingReachabilityDidChangeNotification = @"com.alamofire.networking.reachability.change";
NSString * const AFNetworkingReachabilityNotificationStatusItem = @"AFNetworkingReachabilityNotificationStatusItem";

FOUNDATION系列函数
对比资料视图传送门

重点:

1、FOUNDATION_EXPORT NSString * const定义的多个变量,不管它们的值相同或者不同,它们指针指向的内存地址都相同。
2、#define定义的多个变量,如果变量值相同,那么内存地址相同,值不同,内存地址则不同。

为什么内存地址会相同呢?

等找到原因了再补充下。

三、关于使用C语言写私有方法

我个人的意见是一个类中的私有方法写成static void funcName() 这样的c函数比较好。

3.1. 在文件的最前方,比较容易查找

3.2. 可以适当的使用内联函数,提高效率。

四、AFSecurityPolicy

4.1. AFSSLPinningModeNone 代表无条件信任服务器的证书

4.2. AFSSLPinningModePublicKey 代表会对服务器返回的证书中的PublicKey进行验证,通过则通过,否则不通过

4.3. AFSSLPinningModeCertificate 代表会对服务器返回的证书同本地证书全部进行校验,通过则通过,否则不通过

五、私有方法

开发中,使用私有化方法来协助我们达到某种目的或获取某个数据,且方法内部没有使用self,类似于这样的方法,跟我们的业务并没有太大的关系,此时我们可以使用static void这样的私有化方法.

static void AFPostReachabilityStatusChange(SCNetworkReachabilityFlags flags, AFNetworkReachabilityStatusBlock block) {
    AFNetworkReachabilityStatus status = AFNetworkReachabilityStatusForFlags(flags);
    dispatch_async(dispatch_get_main_queue(), ^{
        if (block) {
            block(status);
        }
        NSNotificationCenter *notificationCenter = [NSNotificationCenter defaultCenter];
        NSDictionary *userInfo = @{ AFNetworkingReachabilityNotificationStatusItem: @(status) };
        [notificationCenter postNotificationName:AFNetworkingReachabilityDidChangeNotification object:nil userInfo:userInfo];
    });
}

六、代码思维碰撞

当遇到比较复杂功能的时候,能不能写出一个思路图,先不管思路的实现如何,先一一列出来,最后再一一实现,一一拼接起来。 没有全局观是不行的。

七、NSIndexSet

定义:NSIndexSet是一个有序的,唯一的,无符号整数的集合。

有序的输出数据,从小到大。

应用场景:删除表的区到就会用到indexset 来作为索引,才知道删除第几个区。

https://www.jianshu.com/p/84a1d5296844

八、锁

AFNetworking中我们总共见过三种锁。

- (BOOL)isNetworkActivityOccurring {
    @synchronized(self) {
        return self.activityCount > 0;
    }
}
- (NSArray *)tasksForKeyPath:(NSString *)keyPath {
    __block NSArray *tasks = nil;
    dispatch_semaphore_t semaphore = dispatch_semaphore_create(0);
    [self.session getTasksWithCompletionHandler:^(NSArray *dataTasks, NSArray *uploadTasks, NSArray *downloadTasks) {
        if ([keyPath isEqualToString:NSStringFromSelector(@selector(dataTasks))]) {
            tasks = dataTasks;
        } else if ([keyPath isEqualToString:NSStringFromSelector(@selector(uploadTasks))]) {
            tasks = uploadTasks;
        } else if ([keyPath isEqualToString:NSStringFromSelector(@selector(downloadTasks))]) {
            tasks = downloadTasks;
        } else if ([keyPath isEqualToString:NSStringFromSelector(@selector(tasks))]) {
            tasks = [@[dataTasks, uploadTasks, downloadTasks] valueForKeyPath:@"@unionOfArrays.self"];
        }

        dispatch_semaphore_signal(semaphore);
    }];

    dispatch_semaphore_wait(semaphore, DISPATCH_TIME_FOREVER);

    return tasks;
}
+ (UIImage *)af_safeImageWithData:(NSData *)data {
    UIImage* image = nil;
    static dispatch_once_t onceToken;
    dispatch_once(&onceToken, ^{
        imageLock = [[NSLock alloc] init];
    });
    
    [imageLock lock];
    image = [UIImage imageWithData:data];
    [imageLock unlock];
    return image;
}

九、NSURLCache

NSURLCache为应用的URL提供了内摧毁总以及磁盘上的综合缓存机制。网络缓存减少了向服务器发送请求的次数,通知也提升了离线或在低速网路中使用应用的体验。当一个请求完成了来自服务器的回应,回应将会在本地保存。下一次同一个请求再发起时,本地保存的回一个就会马上返回,不需要链接服务器。

- (BOOL)application:(UIApplication *)application
    didFinishLaunchingWithOptions:(NSDictionary *)launchOptions
{
  NSURLCache *URLCache = [[NSURLCache alloc] initWithMemoryCapacity:4 * 1024 * 1024
                                                       diskCapacity:20 * 1024 * 1024
                                                           diskPath:nil];
  [NSURLCache setSharedURLCache:URLCache];
}

URLRequest 有个 cachePolicy 属性,我们平时最常用的有四个属性:

十、内联函数(inline)

我们在AFNetWorking中经常见到inline(内联函数),心里多多少少会犯嘀咕,这是什么函数?有什么用?用了有什么好处?什么时候用?

static inline NSString * AFContentTypeForPathExtension(NSString *extension) {
#ifdef __UTTYPE__
    NSString *UTI = (__bridge_transfer NSString *)UTTypeCreatePreferredIdentifierForTag(kUTTagClassFilenameExtension, (__bridge CFStringRef)extension, NULL);
    NSString *contentType = (__bridge_transfer NSString *)UTTypeCopyPreferredTagWithClass((__bridge CFStringRef)UTI, kUTTagClassMIMEType);
    if (!contentType) {
        return @"application/octet-stream";
    } else {
        return contentType;
    }
#else
    return @"application/octet-stream";
#endif
}


static inline NSString * AFKeyPathFromOperationState(AFOperationState state) {
    switch (state) {
        case AFOperationReadyState:
            return @"isReady";
        case AFOperationExecutingState:
            return @"isExecuting";
        case AFOperationFinishedState:
            return @"isFinished";
        case AFOperationPausedState:
            return @"isPaused";
        default:
            return @"state";
    }
}

3、由于inline增加体积的特性,所以建议inline函数内的代码应该很短小。
4、inline仅作为一种“请求”,特定情况下编译器将不会理会inline关键字,而强制让函数称为普通函数,这样编译器会输出警告信息。
5、在盗用一个内联函数之前,一定要在函数之前定义或声明inline,如果在前面声明为普通函数,而在调用代码后面才定义为一个inline函数,程序可以通过编译,但该函数没有实现inline。


内联函数参考资料1
内联函数参考资料2

参考资料:http://www.cnblogs.com/machao/p/5768253.html

上一篇 下一篇

猜你喜欢

热点阅读