Commit 1e21ef15 authored by 井庆林's avatar 井庆林

code review

parents 55735550 44220834
...@@ -39,6 +39,8 @@ static NSString *sdkVersion = @"1.3.1"; ...@@ -39,6 +39,8 @@ static NSString *sdkVersion = @"1.3.1";
static dispatch_semaphore_t _immediatelySemaphore; static dispatch_semaphore_t _immediatelySemaphore;
static dispatch_semaphore_t _normalSemaphore; static dispatch_semaphore_t _normalSemaphore;
static dispatch_queue_t _immediatelyQueue;
static dispatch_queue_t _normalQueue;
+ (Phobos *)clientWithAppName:(NSString *)appName channelId:(NSString *)channelId{ + (Phobos *)clientWithAppName:(NSString *)appName channelId:(NSString *)channelId{
Phobos.sharedClient.appName = appName; Phobos.sharedClient.appName = appName;
...@@ -51,6 +53,8 @@ static dispatch_semaphore_t _normalSemaphore; ...@@ -51,6 +53,8 @@ static dispatch_semaphore_t _normalSemaphore;
dispatch_once(&onceToken, ^{ dispatch_once(&onceToken, ^{
_immediatelySemaphore = dispatch_semaphore_create(1); _immediatelySemaphore = dispatch_semaphore_create(1);
_normalSemaphore = dispatch_semaphore_create(1); _normalSemaphore = dispatch_semaphore_create(1);
_immediatelyQueue = dispatch_queue_create("immdiately", DISPATCH_QUEUE_CONCURRENT);
_normalQueue = dispatch_queue_create("normal", DISPATCH_QUEUE_CONCURRENT);
}); });
} }
...@@ -438,7 +442,7 @@ static dispatch_semaphore_t _normalSemaphore; ...@@ -438,7 +442,7 @@ static dispatch_semaphore_t _normalSemaphore;
} }
+ (void)track:(NSString *)eventName{ + (void)track:(NSString *)eventName{
[self track:eventName attributes:@{} sendNow:NO currentAPI:_sharedClient.serverAPI]; [self track:eventName attributes:nil sendNow:NO currentAPI:_sharedClient.serverAPI];
} }
+ (void)track:(NSString *)eventName attributes:(NSDictionary *)attributes{ + (void)track:(NSString *)eventName attributes:(NSDictionary *)attributes{
...@@ -450,7 +454,7 @@ static dispatch_semaphore_t _normalSemaphore; ...@@ -450,7 +454,7 @@ static dispatch_semaphore_t _normalSemaphore;
} }
+ (void)track:(NSString *)eventName currentAPI:(NSString *)currentAPI { + (void)track:(NSString *)eventName currentAPI:(NSString *)currentAPI {
[self track:eventName attributes:@{} sendNow:NO currentAPI:currentAPI]; [self track:eventName attributes:nil sendNow:NO currentAPI:currentAPI];
} }
+ (void)track:(NSString *)eventName attributes:(NSDictionary *)attributes currentAPI:(NSString *)currentAPI { + (void)track:(NSString *)eventName attributes:(NSDictionary *)attributes currentAPI:(NSString *)currentAPI {
...@@ -489,6 +493,7 @@ static dispatch_semaphore_t _normalSemaphore; ...@@ -489,6 +493,7 @@ static dispatch_semaphore_t _normalSemaphore;
} }
- (void)trackPhobosWithURL:(NSString *)url data:(NSDictionary *)data immediate:(BOOL)immediate { - (void)trackPhobosWithURL:(NSString *)url data:(NSDictionary *)data immediate:(BOOL)immediate {
dispatch_async(_normalQueue, ^{
dispatch_semaphore_wait(_normalSemaphore, DISPATCH_TIME_FOREVER); dispatch_semaphore_wait(_normalSemaphore, DISPATCH_TIME_FOREVER);
NSMutableDictionary *dataDict = [[GMCache fetchObjectAtDocumentPathWithkey:PhobosNormalCacheKey] mutableCopy]; NSMutableDictionary *dataDict = [[GMCache fetchObjectAtDocumentPathWithkey:PhobosNormalCacheKey] mutableCopy];
_normalCount++; _normalCount++;
...@@ -505,6 +510,7 @@ static dispatch_semaphore_t _normalSemaphore; ...@@ -505,6 +510,7 @@ static dispatch_semaphore_t _normalSemaphore;
[Phobos removeAllNormalPhobosData]; [Phobos removeAllNormalPhobosData];
} }
dispatch_semaphore_signal(_normalSemaphore); dispatch_semaphore_signal(_normalSemaphore);
});
} }
/** /**
...@@ -513,6 +519,7 @@ static dispatch_semaphore_t _normalSemaphore; ...@@ -513,6 +519,7 @@ static dispatch_semaphore_t _normalSemaphore;
* @param data : 使用id类型是因为直接调用实时埋点传过来的是Dict,而普通埋点过来的则是Array类型 * @param data : 使用id类型是因为直接调用实时埋点传过来的是Dict,而普通埋点过来的则是Array类型
*/ */
- (void)sendImmediatelyPhobosWithURL:(NSString *)url data:(id)data { - (void)sendImmediatelyPhobosWithURL:(NSString *)url data:(id)data {
dispatch_async(_immediatelyQueue, ^{
dispatch_semaphore_wait(_immediatelySemaphore, DISPATCH_TIME_FOREVER); dispatch_semaphore_wait(_immediatelySemaphore, DISPATCH_TIME_FOREVER);
__block NSMutableDictionary *dataDict = [[GMCache fetchObjectAtDocumentPathWithkey:PhobosImmediatelyCacheKey] mutableCopy]; __block NSMutableDictionary *dataDict = [[GMCache fetchObjectAtDocumentPathWithkey:PhobosImmediatelyCacheKey] mutableCopy];
dataDict = [self dataDict:dataDict setObject:data forKey:url]; dataDict = [self dataDict:dataDict setObject:data forKey:url];
...@@ -536,6 +543,7 @@ static dispatch_semaphore_t _normalSemaphore; ...@@ -536,6 +543,7 @@ static dispatch_semaphore_t _normalSemaphore;
phobosLog(@"✈ ---------- ✈ data arrived Mars"); phobosLog(@"✈ ---------- ✈ data arrived Mars");
}]; }];
}]; }];
});
} }
/** /**
...@@ -555,7 +563,13 @@ static dispatch_semaphore_t _normalSemaphore; ...@@ -555,7 +563,13 @@ static dispatch_semaphore_t _normalSemaphore;
// [self verifyPVPhobos:dataArray data:object]; // [self verifyPVPhobos:dataArray data:object];
//#endif //#endif
[dataArray addObjectsFromArray:data]; [dataArray addObjectsFromArray:data];
// 进行数据校验
@try {
NSData *json = [PhobosUtil encodeJSON:dataArray];
[dataDict setValue:dataArray forKey:key]; [dataDict setValue:dataArray forKey:key];
} @catch (NSException *exception) {
NSAssert(NO, @"哎呀呀,VALUE只不能为NSObject ");
}
return dataDict; return dataDict;
} }
......
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment