排序
根据对象某一int类型属性排序
- (NSArray *)sortingMethod:(NSArray *)stringsToSort
{
NSArray *resultArray = [stringsToSort sortedArrayUsingComparator:^NSComparisonResult(HWSegment *obj1, HWSegment *obj2) {
return [@(obj1.segmentNo) compare:@(obj2.segmentNo)];
}];
return resultArray;
}
注意compare比较NSNumber对象,使用@()封装Int类型
注意一个object1一个object2,不要再干写成两个一样的傻事了。
判断两个字典是否相同
NSDictionary *dataDict1 = dict[@"data"];
NSDictionary *dataDict2 = dict[@"data2"];
NSArray *array = @[dataDict1];
if ([array containsObject:dataDict]) {
NSLog(@"两字典相同");
} else {
NSLog(@"两字典不相同");
}
补充:
Objective-C中的字典NSDictionary底层其实是一个哈希表,实际上绝大多数语言中字典都通过哈希表实现.
兼容iOS15
#if __IPHONE_OS_VERSION_MAX_ALLOWED >= 150000
if (@available(iOS 15.0, *)) {
_tableView.sectionHeaderTopPadding = 0;
}
#endif
用__IPHONE_OS_VERSION_MAX_ALLOWED
的宏,可以保证在不支持iOS15的Xcode版本(xcode13)以下,可以正常编译。
用if (@available(iOS 15.0, *))
可以保证根据手机版本,在iOS15以下手机,在运行时,不会执行。
关闭页面时候的pop方法
- (void)backAction
{
if (self.navigationController.presentingViewController) {
[self.navigationController dismissViewControllerAnimated:YES completion:nil];
}
else {
for (UIViewController *controller in self.navigationController.viewControllers) {
if ([controller isKindOfClass:[HWYoungMainViewController class]]) {
HWYoungMainViewController *revise = (HWYoungMainViewController *)controller;
[self.navigationController popToViewController:revise animated:YES];
}
}
}
}
计算一个耗时时间所需时间
willFinishLaunching
方法中willLaunch = CFAbsoluteTimeGetCurrent();
didFinishLaunching
方法中CFAbsoluteTime launch = CFAbsoluteTimeGetCurrent();
打印一个耗时操作所需时间。NSLog(@"time: didFinishLaunchingWithOptions - willFinishLaunchingWithOptions %f", launch - willLaunch);
宏定义
宏定义注意边际效应。
#define MAX(a,b) ((a)>(b)?(a):(b))
宏定义的使用只是单纯的的替换,书写要加入括号,注意边际效应。
result = MAX(i, j) + 2 ;
//将被预处理器解释为
//result = (i) > (j) ? (i) : (j) + 2 ;
//由于运算符‘+’比运算符‘:’的优先级高,所以上述语句并不等价于期望的
//result = ( (i) > (j) ? (i) : (j) ) + 2 ;
如果把宏代码改写为
#define MAX(a, b) ( (a) > (b) ? (a) : (b) )
则可以解决由优先级引起的错误。但是即使使用修改后的宏代码也不是万无一失的,例如语句
result = MAX(i++, j);
//将被预处理器解释为
//result = (i++) > (j) ? (i++) : (j);
如果是普通函数,则MAX(a,"HellO")会受到函数调用的检查,但此处不会因为两个参数类型不同而被编译拒之门外。
NS_INLINE 内联函数
解决宏定义存在问题的方式,内联函数 NS_INLINE.
inline int MAX(int a,int b) {
return a>b?a:b;
}
内联能提高函数的执行效率,内联是以代码膨胀(复制)为代价,仅仅省去了函数调用的开销,从而提高函数的执行效率。如果执行函数体内代码的时间,相比于函数调用的开销较大,那么效率的收获会很少。另一方面,每一处内联函数的调用都要复制代码,将使程序的总代码量增大,消耗更多的内存空间。
总结:将简单短小的函数定义为内联函数,并加上static修饰,将会提高效率。iOS开发中可以直接使用NS_INLINE宏定义,编译器将保留是否需要将函数作为内敛函数的权利。
NS_INLINE void tipWithMessage(NSString *message){
dispatch_async(dispatch_get_main_queue(), ^{
UIAlertView *alerView = [[UIAlertView alloc] initWithTitle:@"提示" message:message delegate:nil cancelButtonTitle:nil otherButtonTitles:nil, nil];
[alerView show];
[alerView performSelector:@selector(dismissWithClickedButtonIndex:animated:) withObject:@[@0, @1] afterDelay:0.9];
});
}
-(void)touchesBegan:(NSSet<UITouch *> *)touches withEvent:(UIEvent *)event{
tipWithMessage(@"世界,你好!");
}
NS_INLINE TCThemeHelper * ThemeHelper(){
return [TCThemeHelper sharedGTThemeHelper];
}
self.view.backgroundColor = [ThemeHelper() getAppMainBg];
NS_INLINE
约等于static inline
static inline bool isOrientationIsLandscape() {
return UIInterfaceOrientationIsLandscape([[UIApplication sharedApplication] statusBarOrientation]);
}
#pragma clang diagnostic
处理编译警告。
#pragma clang diagnostic push //插入
#pragma clang diagnostic ignored "-相关命令"
// 需要处理的警告代码
#pragma clang diagnostic pop //结束
-
-Wdeprecated-declarations
方法弃用 -
-Wincompatible-pointer-types
不兼容指针 -
-Warc-retain-cycles
循环引用 -
-Wunused-variable
未使用变量 -
-Wundeclared-selector
未声明选择器 -
-Warc-performSelector-leaks
内存泄漏
字典去空
+ (id) processDictionaryIsNSNull:(id)obj{
if ([obj isKindOfClass:[NSNull class]]) {
return nil;
}
if ([obj isKindOfClass:[NSDictionary class]]) {
NSMutableDictionary *dt = [(NSMutableDictionary*)obj mutableCopy];
for(NSString *key in [dt allKeys]) {
id object = [dt objectForKey:key];
if([object isKindOfClass:[NSNull class]]) {
[dt setObject:gnet_blank
forKey:key];
}
else if ([object isKindOfClass:[NSString class]]){
NSString *strobj = (NSString*)object;
if ([strobj isEqualToString:@"<null>"]) {
[dt setObject:gnet_blank
forKey:key];
}
}
else if ([object isKindOfClass:[NSArray class]]){
NSArray *da = (NSArray*)object;
da = [self processDictionaryIsNSNull:da];
[dt setObject:da
forKey:key];
}
else if ([object isKindOfClass:[NSDictionary class]]){
NSDictionary *ddc = (NSDictionary*)object;
ddc = [self processDictionaryIsNSNull:object];
[dt setObject:ddc forKey:key];
}
}
return [dt copy];
}
else if ([obj isKindOfClass:[NSArray class]]){
NSMutableArray *da = [(NSMutableArray*)obj mutableCopy];
for (int i=0; i<[da count]; i++) {
NSDictionary *dc = [obj objectAtIndex:i];
dc = [self processDictionaryIsNSNull:dc];
[da replaceObjectAtIndex:i withObject:dc];
}
return [da copy];
}
else{
return obj;
}
}
ViewController高度
viewController.view的高度变矮,导致后续布局出现问题。
self.navigationController.navigationBar.translucent = YES;
self.edgesForExtendedLayout = UIRectEdgeTop;