iOS: add DoricDevPerfVC

This commit is contained in:
pengfei.zhou
2021-07-21 15:05:41 +08:00
committed by osborn
parent 74e9aa0e38
commit 8f50d2d67c
12 changed files with 387 additions and 290 deletions

View File

@@ -19,8 +19,32 @@
#import "DoricDevPerformanceAnchorHook.h"
@implementation DoricDevAnchorNode
@end
@interface DoricDevPerformanceAnchorHook ()
@property(nonatomic, strong) NSMutableDictionary<NSString *, NSMutableArray <DoricDevAnchorNode *> *> *nodeMap;
@property(nonatomic, copy) NSComparator comparator;
@end
@implementation DoricDevPerformanceAnchorHook
- (instancetype)init {
if (self = [super init]) {
_nodeMap = [NSMutableDictionary new];
_comparator = ^NSComparisonResult(DoricDevAnchorNode *obj1, DoricDevAnchorNode *obj2) {
long ret = obj1.prepare - obj2.prepare;
if (ret > 0) {
return NSOrderedDescending;
} else if (ret < 0) {
return NSOrderedAscending;
} else {
return NSOrderedSame;
}
};
}
return self;
}
- (void)onAnchorName:(NSString *)name prepare:(NSNumber *)prepare start:(NSNumber *)start end:(NSNumber *)end in:(DoricPerformanceProfile *)profile {
NSLog(@"[DoricPerformance] %@: %@ prepared %@ms, cost %@ms",
profile.name,
@@ -28,10 +52,28 @@ - (void)onAnchorName:(NSString *)name prepare:(NSNumber *)prepare start:(NSNumbe
@(start.integerValue - prepare.integerValue),
@(end.integerValue - start.integerValue)
);
NSMutableArray<DoricDevAnchorNode *> *array = self.nodeMap[profile.name];
if (!array) {
array = [NSMutableArray new];
self.nodeMap[profile.name] = array;
}
[array addObject:[[DoricDevAnchorNode new] also:^(DoricDevAnchorNode *it) {
it.name = name;
it.prepare = prepare.longValue;
it.start = start.longValue;
it.end = end.longValue;
}]];
[array sortUsingComparator:self.comparator];
if ([name isEqualToString:@"Destroy"]) {
[self.nodeMap removeObjectForKey:profile.name];
}
}
- (void)onAnchorName:(NSString *)name prepare:(NSNumber *)prepare start:(NSNumber *)start end:(NSNumber *)end {
//Do nothing
}
- (NSArray <DoricDevAnchorNode *> *)getAnchorNodeList:(NSString *)name {
return [self.nodeMap[name] copy];
}
@end