iOS开发备忘笔记 (持续更新中)

  1. NSString常量定义:

    正确:

     NSString * const name = @"value";
    

    错误:

     const NSString * name = @"value"; 
     NSString const * name = @"value";
    

    总结: const* 前 代表 *name 不可变, 在 * 后代表 name不可变. 我们一般都 是想让 name 的值不变, 所以应该把 const 放在 * 后;

  2. 格式化日期输出星期的不同表示:

     NSDateFormatter * dateFormatter = [[NSDateFormatter alloc] init];
     dateFormatter.dateFormat = @"E EE EEE EEEE EEEEE EEEEEE EEEEEEE";
     NSString * dateStr = [dateFormatter stringFromDate:[NSDate date]];
     NSLog(@"%@", dateStr);
     //输出:    周六 周六 周六 星期六 六 周六 周六
    
  3. UICollectionView 更新数据源 和 更新界面一定要一对一. (备忘, 有空补充代码)

  4. 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);
    
  5. UITableView 不同 style 的区别 :

    iOS7 之后, 不同 UITableViewStyle 的外观基本上相同了, 那它们还有什么不易见的区别呢:

    • UITableViewStylePlain :

      1. SectionHeaderFooter 的高度默认为 0 ;
      2. 并且 Section 的头脚视图会悬停在最上方和最下方;
    • UITableViewStyleGrouped :

      1. 同上相反, Section的头脚高度必须不能为 0 . 为 0 设置无效, 系统会默认一个高度, 如果不需要可以设置一个很小的小数;
      2. Section 的 头脚视图不会悬停在上面和下面, 会随着表格一起滑动;
  6. git 不能跟踪文件名大小写的改变, 造成一些问题怎么办?

    (如: 图片名称改了大小写, 但是git没有提交这一改变, 造成下次检出代码运行APP时读取不到图片)

    1. git设置为大小写敏感:

      • 命令行:

          git config core.ignorecase false
        
      • 直接修改.git文件夹的config文件中

          ignorecase = false
        
    2. 如果已经出问题, 可以 先删除文件,再添加进去

  7. 导致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之前替换掉或去掉这些字符:

      1. 使用循环替换为空的办法 , 性能消耗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;
        }
        
      2. 优化特殊字符的替换方式, 现在效率比以前高10倍, json串替换基本都在0.001秒以内:

        /**
          *  删除特殊字符
          */
        +(NSString *)deleteSpecialCharacters:(NSString *)str{
        
            //使用此方法效率比上面快5-10倍, 用 NSString -componentsSeparatedByCharactersInSet: 在控制字符处将字符串分割成一个 NSArray;再用一个 NSPredicate 去除空串;最后,用 NSArray -componentsJoinedByString: 用单个空格符将数组重新拼成字符串
            //[NSCharacterSet controlCharacterSet] 控制字符集 ASCII码(0~31 and 127)
            NSArray *components = [str componentsSeparatedByCharactersInSet:[NSCharacterSet controlCharacterSet]];
            components = [components filteredArrayUsingPredicate:[NSPredicate predicateWithFormat:@"self <> ''"]];
            str = [components componentsJoinedByString:@" "];
            
            return str;
        }
        
        
  8. int a; //a不一定等于0

    //错误
    int a;
    a++;
    
    //正确
    int a = 0;
    a++;
    
  9. 取一个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开发备忘笔记 (持续更新中))