小知识点#2

1、FMDB

FMDatabase:是一个提供 SQLite 数据库的类,用于执行 SQL 语句。
FMResultSet:用在 FMDatabase 中执行查询的结果的类。
FMDatabaseQueue:在多线程下查询和更新数据库用到的类。

/* 创建队列,打开数据库
 * dbFilepath:数据库路径
 * dbQueue:类实例
 */
FMDatabaseQueue *dbQueue = [FMDatabaseQueue databaseQueueWithPath:dbFilepath];

/* 操作数据库
 * sql:SQLite语法
 * FMResultSet:返回查询的结果
 * -executeUpdate: 方法的参数都必须是对象 eg:[NSNumber numberWithInt:42]
 */

[dbQueue inDatabase:^(FMDatabase *db) {
    // 查询数据库
    FMResultSet *rs = [db executeQuery:sql];
    if([rs next]){ // 查询到数据
         
        // 更新数据库(是否成功)
        BOOL bool =  [db executeUpdate:sql];
    }
 }];
// 关闭数据库
[dbQueue close];

FMDatabase 这个类是线程不安全的,在多线程中使用 FMDatabase 单例是极其错误的想法。不能在多线程的环境中对数据库 FMDatabase 进行读写,会出现奔溃或者异常,因为你不能保证你读数据的同时另外一条线程不在写数据,FMDatabaseQueue 跨线程使用是同步的


2、dispatch_group

// 1、创建一个group
dispatch_group_t dispatchGroup = dispatch_group_create();
// 2、把一个异步操作加入到group中
dispatch_group_enter(dispatchGroup);
dispatch_async(dispatch_get_global_queue(DISPATCH_QUEUE_PRIORITY_DEFAULT, 0), ^{
  
    NSLog(@"startLocationCity");
    // 2、把这个异步操作从group中移出
    dispatch_group_leave(dispatchGroup);
});

// 3、阻碍线程。等待任务执行在设置时间内完成,或者超时,就会继续执行后面的操作
dispatch_group_wait(dispatchGroup, dispatch_time(DISPATCH_TIME_NOW, 10 * NSEC_PER_SEC));

/* 4、等待dispatchGroup完成所有异步操作,但不会阻碍线程
 * 适用与多个异步操作,得到多个结果,然后在一个地方完成操作
 * eg:A,B异步操作,不分顺序,但需要得到A,B的结果后再执行C
 */ 
dispatch_group_notify(group, dispatch_get_main_queue(), ^{

});

  • dispatch_group_enter与dispatch_group_leave必须成对出现
  • dispatch_group_enter:增加当前group执行block数
  • dispatch_group_leave:减少当前group执行block数
dispatch_group_notify与dispatch_barrier_sync效果类似,区别在于一个异步,一个同步。

3、 NSCondition

NSCondition 的对象实际上作为一个锁和一个线程检查器:锁主要为了当检测条件时保护数据源,执行条件引发的任务;线程检查器主要是根据条件决定是否继续运行线程,即线程是否被阻塞。

// 实现多线程的同步,即,可实现生产者消费者问题

NSConditon *condition =[ [NSCondition alloc]]init;

[condition lock];// 加锁

[condition unlock];//与lock 同时使用,释放锁

[condition wait];//让当前线程处于等待状态

[condition signal];//CPU发信号告诉线程不用在等待,可以继续执行,与wait对应使用

4、 NSArray的排序

var array = ["M","O","H","R","L","W"]
        
// 1、倒叙
array = array.reversed()    // ["W", "L", "R", "H", "O", "M"]
同oc:[[array reverseObjectEnumerator] allObjects];       
 
// 2、升序
array = array.sorted()      // ["H", "L", "M", "O", "R", "W"]
同oc:[array sortedArrayUsingSelector:@selector(compare:)];
        
// 3、降序(先sorted,再reversed,就等于降序)
array = array.reversed()    // ["W", "R", "O", "M", "L", "H"]

注意:因为NSDictionary没有排序,网络请求有时候需要我们对其排序,我们可以通过NSArray的排序来完成

- (NSString *)transformedParams:(NSDictionary *)params
{
    if ([params count]==0) {
        return nil;
    }
    
    NSArray *keys = [params allKeys];
    NSArray *sortedKeys = [keys sortedArrayUsingSelector:@selector(compare:)];
    NSMutableString *paramString = [[NSMutableString alloc] init];
    [sortedKeys enumerateObjectsUsingBlock:^(id key, NSUInteger idx, BOOL *stop) {
        
        // value转字符串
        id value = [params objectForKey:key];
        if (![value isKindOfClass:[NSString class]]) {
            value = [NSString stringWithFormat:@"%@", value];
        }
        
        if ([value length] > 0) {
            // 拼接字符串
            if (idx==0) {
                [paramString appendFormat:@"%@=%@",key,value];
            }else{
                [paramString appendFormat:@"&%@=%@",key,value];
            }
        }
    }];
    return paramString;
}

你可能感兴趣的:(小知识点#2)