-
NSString
常量定义:正确:
NSString * const name = @"value";
错误:
const NSString * name = @"value"; NSString const * name = @"value";
总结:
const
在*
前 代表*name
不可变, 在*
后代表name
不可变. 我们一般都 是想让name
的值不变, 所以应该把const
放在*
后; -
格式化日期输出星期的不同表示:
NSDateFormatter * dateFormatter = [[NSDateFormatter alloc] init]; dateFormatter.dateFormat = @"E EE EEE EEEE EEEEE EEEEEE EEEEEEE"; NSString * dateStr = [dateFormatter stringFromDate:[NSDate date]]; NSLog(@"%@", dateStr); //输出: 周六 周六 周六 星期六 六 周六 周六
UICollectionView
更新数据源 和 更新界面一定要一对一. (备忘, 有空补充代码)-
URL
编码 (先备忘, 有空补说明):C方法:
str = (NSString *)CFBridgingRelease(CFURLCreateStringByAddingPercentEscapes(kCFAllocatorDefault,(CFStringRef)str,NULL,CFSTR("%+ /?#&="),kCFStringEncodingUTF8));
OC方法:
urlStr = [urlStr stringByAddingPercentEscapesUsingEncoding:NSUTF8StringEncoding];
OC新方法:
- (nullable NSString *)stringByAddingPercentEncodingWithAllowedCharacters:(NSCharacterSet *)allowedCharacters NS_AVAILABLE(10_9, 7_0);
-
<a name="UITableViewStyle"></a>
UITableView
不同style
的区别 :iOS7 之后, 不同
UITableViewStyle
的外观基本上相同了, 那它们还有什么不易见的区别呢:-
UITableViewStylePlain
:-
Section
的Header
和Footer
的高度默认为 0 ; - 并且
Section
的头脚视图会悬停在最上方和最下方;
-
-
UITableViewStyleGrouped
:- 同上相反,
Section
的头脚高度必须不能为 0 . 为 0 设置无效, 系统会默认一个高度, 如果不需要可以设置一个很小的小数; -
Section
的 头脚视图不会悬停在上面和下面, 会随着表格一起滑动;
- 同上相反,
-
-
git
不能跟踪文件名大小写的改变, 造成一些问题怎么办?(如: 图片名称改了大小写, 但是
git
没有提交这一改变, 造成下次检出代码运行APP时读取不到图片)-
把
git
设置为大小写敏感:-
命令行:
git config core.ignorecase false
-
直接修改
.git
文件夹的config
文件中ignorecase = false
-
如果已经出问题, 可以 先删除文件,再添加进去
-
-
导致
JSON
不能正确解析的字符 :-
经过测试: 遍历所有Unicode字符 (UCS-2标准
0 - 65536
), 循环放入json中解析, 发现有34个字符出现解析失败, 前32个字符为ASCII码为0 - 31
的控制字符 , 另外两个为"
和\
.(ASCII码:实际字符) ( "0:", "1:�", "2:�", "3:�", "4:�", "5:�", "6:�", "7:\a", "8:\b", "9:\t", "10:\n", "11:\v", "12:\f", "13:\r”, "14:�", "15:�", "16:�", "17:�", "18:�", "19:�", "20:�", "21:�", "22:�", "23:�", "24:�", "25:�", "26:�", "27:�", "28:�", "29:�", "30:�", "31:�", "34:\"", "92:\\" )
-
解决方法: 在解析JSON之前替换掉或去掉这些字符:
-
使用循环替换为空的办法 , 性能消耗0.01秒以内 且大部分json在0.001秒以内:
/** * 删除特殊字符 */ +(NSString *)deleteSpecialCharacters:(NSString *)str{ //删除影响 JSON 解析的字符 : [ASCII码:0~31 以及 " \ ] 共34个字符 , " \ 一般不能直接去掉,需要单独处理. for (int i = 0; i <= 31; i++) { NSString *value = [NSString stringWithFormat:@"%C",(unichar)i]; str = [str stringByReplacingOccurrencesOfString:value withString:@""]; } return str; }
-
优化特殊字符的替换方式, 现在效率比以前高10倍, json串替换基本都在0.001秒以内:
/** * 删除特殊字符 */ +(NSString *)deleteSpecialCharacters:(NSString *)str{ //使用此方法效率比上面快5-10倍, 用 NSString -componentsSeparatedByCharactersInSet: 在控制字符处将字符串分割成一个 NSArray;再用一个 NSPredicate 去除空串;最后,用 NSArray -componentsJoinedByString: 用单个空格符将数组重新拼成字符串 //[NSCharacterSet controlCharacterSet] 控制字符集 ASCII码(0~31 and 127) NSArray<NSString *> *components = [str componentsSeparatedByCharactersInSet:[NSCharacterSet controlCharacterSet]]; components = [components filteredArrayUsingPredicate:[NSPredicate predicateWithFormat:@"self <> ''"]]; str = [components componentsJoinedByString:@" "]; return str; }
-
-
-
int a; //a不一定等于0
//错误 int a; a++; //正确 int a = 0; a++;
-
取一个int型变量的绝对值, 用
abs()
函数有风险. (当值为-2147483648
的时候)//首先我们来看int的范围: NSLog(@"%i", INT_MIN); //输出 -2147483648 NSLog(@"%i", INT_MAX); //输出 2147483647 //我们知道int的范围是: -2147483648 ~ 2147483647 //然后我们用 abs() 函数取 -2147483648 的绝对值: NSLog(@"%i",abs(-2147483648)); //输出 -2147483648, 并且Xcode报警告 //为什么呢? -2147483648 的绝对值不应该是 2147483648 吗? 这是因为 2147483648 超过int的最大值(2147483647)了, 所以最高位被截断了 //所以不能用 abs() 函数来取 -2147483648 的绝对值, 这个函数的参数和返回值都是int型; //我们应该使用 labs() 函数, 这个函数的参数和返回值都是long型 NSLog(@"%li",labs(-2147483648)); //输出 2147483648 //好了, 这下结果正确了, 当然这只是极端的情况, 一般情况还是可以放心使用 abs() 函数
iOS开发备忘笔记 (持续更新中)
最后编辑于 :
©著作权归作者所有,转载或内容合作请联系作者
- 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
- 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
- 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...