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;
}