1. 不可变数组  转变为可变数组 

//声明实例变量的数组  必须记得实现

//对于遍历数组找到对象后 如果还需要查找 记得先结束 再查找(return/break)



NSArray * arr = @[@"人在囧途",@"煎饼侠",@"西游记",];

   

NSMutableArray *  arr = [NSMutableArray arrayWithArray:arr];



//在数组中取数据的时候  需要通过后缀 将数组中的对象转化为数字类

p11.age = [newArr[1]intValue];



2.获取字符串长度 



NSString * str = nameLabel .text;

   

    CGSize size = [str sizeWithAttributes:@{NSFontAttributeName:
[UIFont systemFontOfSize:17]}];

   

    此时即可得到 size .width (字符串的宽  即 字符串长度)



3.将单独的某个视图上的视图控制器的导航条隐藏 



-(void)viewDidAppear:(BOOL)animated

{

    [super viewDidAppear:animated == NO];

   

    [self .navigationController setNavigationBarHidden:YES];





}



4. //边帽法 (拉伸图片) 将某一像素点儿不断地复制  其他像素点不变 拉伸之后不会是图片变形

       

        UIImage * image =[[UIImage imageNamed:@"bubble.png"]stretchableImageWithLeftCapWidth:20 topCapHeight:20];

       

             //再把得到的图片赋给控件

        bubbleImageView .image = image;


//图片拉伸
    UIImage * image =[UIImage imageNamed:@"7.jpg"];
    [image resizableImageWithCapInsets:UIEdgeInsetsMake(0,
image.size.width, 0, 0)];




5. 监听系统发送的通知 

//  监听键盘frame发生变化的通知  并可以通过键盘的属性获得对象

    [[NSNotificationCenter defaultCenter]addObserver:self selector:@selector(KeyboardWillChangeFrame:) name:UIKeyboardWillChangeFrameNotification object:nil];



-(void)KeyboardWillChangeFrame: (NSNotification *)noti

{

   // NSLog(@"-------%@",noti.userInfo);

    //    UIKeyboardAnimationCurveUserInfoKey = 7;

    //    UIKeyboardAnimationDurationUserInfoKey = "0.25";

    //    UIKeyboardBoundsUserInfoKey = "NSRect: {{0, 0}, {320, 216}}";

    //    UIKeyboardCenterBeginUserInfoKey = "NSPoint: {160, 588}";

    //    UIKeyboardCenterEndUserInfoKey = "NSPoint: {160, 372}";

    //    UIKeyboardFrameBeginUserInfoKey = "NSRect: {{0, 480}, {320, 216}}";

    //    UIKeyboardFrameChangedByUserInteraction = 0;

    //    UIKeyboardFrameEndUserInfoKey = "NSRect: {{0, 264}, {320, 216}}";

   

//一旦键盘发生改变的时候  _inputView  和  _tableView 的坐标都要发生改变

   

    //通过字典 获取对象

   

    NSDictionary * dic = noti .userInfo;

   

    //获取动画时长

   

    float time = [[dic objectForKey:UIKeyboardAnimationDurationUserInfoKey]floatValue];

   

    //获取动画速率

   

    int curve = [[dic objectForKey:UIKeyboardAnimationCurveUserInfoKey]intValue];

   

    //获取键盘坐标

   

    CGRect  rect = [[dic objectForKey:UIKeyboardFrameEndUserInfoKey]CGRectValue];



6.通过字符串绘制矩形  MAXFLOAT 无限



NSString * str = _chatArr[indexPath .row];

       

        CGRect rect = [str  boundingRectWithSize:CGSizeMake(200, MAXFLOAT) options:NSStringDrawingUsesLineFragmentOrigin|NSStringDrawingUsesFontLeading attributes:@{NSFontAttributeName: [UIFont systemFontOfSize:15]} context:nil];



7.视图层级切换 

关键点:

 [self .window exchangeSubviewAtIndex:0 withSubviewAtIndex:1];



1. 如果父视图不可交互  那么放在其上边的子视图也不可交互

2. 如果父视图可以交互  那么放在上边的子视图的可交互性由自己决定



关键词 : userInteractionEnabled



 image .userInteractionEnabled = YES;









8.二进制数据转变类型 



字符串转变为二进制数据:

 NSString * str =@"girls";

 NSData * data =[str dataUsingEncoding:NSUTF8StringEncoding];



二进制数据转变为字符串

NSString * str2 =[[NSString alloc]initWithData:data1 encoding:NSUTF8StringEncoding];



将图片转变为二进制数据

1.需要获得图片路径  调用[ NSBundle main..]path…….



NSString * imageViewPath =[[NSBundle mainBundle]pathForResource:@"18" ofType:@"jpg"];

   

    NSData * data =[[NSData alloc]initWithContentsOfFile:imageViewPath];

2.直接将添加在工程中的图片转化为二进制数据类型

UIImage * image =[UIImage imageNamed:@"20.jpg"];

   

NSData * data =UIImageJPEGRepresentation(image, 1);





将转变为二进制数据的图片转变回图片

方法1   可以直接调用 从路径中取出图片

 UIImage * image = [UIImage imageWithContentsOfFile:dataPath];

方法2 : 先将路径中的二进制数据取出  然后 通过ImageWithData 属性转变为图片类型



NSData * data =[NSData dataWithContentsOfFile:[self getFilePath:@"data.plist"]];

   

    UIImage * image =[UIImage imageWithData:data];



9.如何删除一个视图上的所有子视图  所有代码 :



获取视图上存放的所有子视图  遍历数组 找到所有对象 找到 views



NSArray * arr = _scrollerView.subviews;



    for (UIImageView * imageView  in arr) {

       

        [imageView removeFromSuperview];

       

    }







10.将某个视图放在最前边



 [self .view bringSubviewToFront:_tableView];





11.页面跳转(需要找window)

//找window

  方法1:

UIWindow * window =[[[UIApplication sharedApplication]delegate]window];

   

    window .rootViewController = aViewController;

   

  方法2:

UIApplication * app = [UIApplication sharedApplication];

   

    AppDelegate * delegate = app .delegate;

   

    UIWindow * window = delegate .window ;

   

    window .rootViewController = aViewController;



1. 页面翻转

    [UIView beginAnimations:nil context:nil];

   

    [UIView setAnimationDuration:1];

   

    [UIView setAnimationTransition:UIViewAnimationTransitionCurlUp forView:window cache:YES];

   

    [UIView commitAnimations];



2. 模态弹出  (present  展示     dismiss  消失 )

3. 导航控制器  (push  压栈   pop  出栈 )



//通过导航控制器控制视图切换的时候

1. 返回上一界面:

 [self .navigationController popViewControllerAnimated:YES];

2. 返回根视图控制器:

[self .navigationController popToRootViewControllerAnimated:YES];

3.返回指定视图:

//首先获取目前所有的视图控制器对象

NSArray * arr  =  self .navigationController .viewControllers;

//从数组中找到需要返回的根视图

FirestViewController * first = arr[0];

//返回指定视图:

 [self .navigationController popToViewController:first animated:YES];









12.将数据库文件拷贝到沙盒中 



//首先需要获取数据库文件的路径  还有文件夹路径



NSString * sourePath =  [[NSBundle mainBundle]pathForResource:@"database" ofType:@"sqlite"];

   

    if (![[NSFileManager defaultManager] fileExistsAtPath:[self filePath]])

    {

        NSError * error = nil;

       

        if ( [[NSFileManager defaultManager]copyItemAtPath:sourePath toPath:[self filePath] error:&error]) {

           

            NSLog(@"copy成功");

        }

       

    }

13:直接进入网页 

//网页加载 :



 // 创建url
  NSURL: NSObject    用来表示资源在互联网的位置

    NSURL  * url =  [NSURL URLWithString:@"http://www.baidu.com"];

   

    //创建一个请求

    NSURLRequest *request = [NSURLRequest requestWithURL:url];



    //加载请求

    [webView loadRequest:request];





 [[UIApplication sharedApplication]openURL:[NSURL URLWithString:@"http//www.baidu.com"]];



14:将结构体转换成字符串再输出



 NSLog(@"-------%@",NSStringFromCGRect(rect));



15: 角度转弧度 



可以定义为宏 #define ANGLE_2_HUDU(X) (X)*M_PI/180.0



计算圆形轨迹上控件的中心点坐标时 

                         中心点          圆的半径                               角度转弧度                                      
角度值 

        float x = 160 + 100 * cos(ANGLE_2_HUDU(btn.angle));

       

        float y = 240 + 100 * sin(ANGLE_2_HUDU(btn
.angle));



         //x = 中心点x + 半径 * cos@

        //y = 中心点y + 半径 *sin@



16: 交叉导入 



//为了防止交叉导入  @class 文件

//只是告诉了编译器有这个类  但是该类的.h文件中有什么东西 编译器是不知道的   当真正需要使用这个类的时候 还必须在.m 文件 中导入 #import "TwoViewController.h”这个头文件



17: center + bounds = frame ;



 //center(设置中心点) + bounds( 设置宽.高)
= frame;

    image .center = CGPointMake(160, 120);

     //bounds (x,y ,width ,height ),前两个值 x,y 是无效的

    image .bounds = CGRectMake(0, 0, 160, 120);



18: 查询父视图 



NSLog(@"==%@",image.superview);

  查看view的子视图

 NSLog(@"==%@",self .window .subviews);



19.重新添加 xib 文件

 如果创建的xib 文件的名字不同  需要在入口方法中 调用一下方法



 ViewController * vc = [[ViewController alloc]initWithNibName:@"Empty" bundle:nil];



20.屏幕获取触摸对象 



//调用的方法 :

-(void)touchesMoved:(NSSet *)touches withEvent:(UIEvent *)event

{

   // NSSet 集合(容器)

   

    //获取触摸对象

    UITouch * touch =[touches anyObject];

    //获取触摸对象 在某一视图上的一个点

    CGPoint point = [touch locationInView:self .view];

    //把结构体转换为字符串输出

    NSLog(@"---%@",NSStringFromCGPoint(point));

    //CGRectContainsPoint  作用  : 判断CGRect
  数据是否包含一个点 point 如果包含这个点 函数值就是1

    //类似属性 CGRectIntersectsRect(<#CGRect rect1#>, <#CGRect rect2#>) 判断两个坐标是否有交集

    //NO1. 触摸对象坐标  NO2.结构体

    if (CGRectContainsPoint(_mainPlane .frame,point)) {

       

        _mainPlane.center = point;

    }



21: 判断对象之间联系常用的属性 

 1.判断某个对象坐标时候包含某个点

CGRectContainsPoint(_mainPlane .frame,point)

   2. 判断两个坐标是否有交集

CGRectIntersectsRect(<#CGRect rect1#>, <#CGRect rect2#>)

   3.判断两个对象时候相等的时候

isEqualToString:<#(NSString *)#>

  4. 判断字符串类型数据长度的时候 需要调用 length



22.获取系统当前时间 



NSDate * date = [NSDate date];

   

    NSDateFormatter * formatter  = [[NSDateFormatter alloc]init];

   

    [formatter setDateFormat:@"yy-MM-dd HH-mm-ss"];

   

    NSString *str = [formatter stringFromDate:date];

   

    NSLog(@"-=-=-=-=-=-=-===%@",str);



时间格式 年yyyy 月 MM 日dd 小时
HH 分钟 mm 秒 ss 

-

23. 分割(返回值类型 - 数组)  . 拼接字符串 



//分割:

NSArray * arr =[str componentsSeparatedByString:@" "];



//字符串之间用什么隔开 分割时  在@“” 中就调用什么 (eg: |  空格 等);



//拼接:



[NSString stringWithString:@"<#string#>"]

[NSString stringWithFormat:@"<#string#>"]



去掉字符串中间的空格



return [self stringByReplacingOccurrencesOfString:@" " withString:@""];



去掉字符串的换行符 



str =[str stringByTrimmingCharactersInSet:[NSCharacterSet whitespaceAndNewlineCharacterSet]];





24 .定时器 .延迟加载 

//定时器开启的时候 为防止点击按钮时开启多个定时器造成混乱  所以在开启定时器的时候可以先判断时候有开启定时器



方法1:



static BOOL isOk;

   

    if (isOk == NO) {

        _timer =  [NSTimer scheduledTimerWithTimeInterval:0.1 target:self selector:@selector(onTimer) userInfo:nil repeats:YES];



//开启定时器后 如果想要定时器立即开启 可以调用

  [_timer fire];



        isOk = YES;

    }



方法2 :



 if (_timer) {

       

        return;

    }

    _timer =  [NSTimer scheduledTimerWithTimeInterval:0.1 target:self selector:@selector(onTimer) userInfo:nil repeats:YES];



//关闭定时器时  记得立即将其指为空



[_timer invalidate];

        _timer = nil;



//定时器绑定方法的时候  只能讲自身传过来



_timer =   [NSTimer scheduledTimerWithTimeInterval:0.05 target:self selector:@selector(onTimer:) userInfo:
button repeats:YES];



-(void)onTimer: (NSTimer *)aTimer

{

       //通过userInfo 获取点击的按钮

    ZYButton * clickBtn  = aTimer.userInfo;

   

}



延迟加载 要点  需要调用performSelector



[self performSelector:@selector(参数) withObject:nil afterDelay:5];







25 .文本框结束编辑的时候  让键盘下去 



-(void)touchesBegan:(NSSet *)touches withEvent:(UIEvent *)event

{

    [self .window endEditing:YES]; 



}



26:向相册中保存图片 



UIImageWriteToSavedPhotosAlbum([UIImage imageNamed:@"20.jpg"], self, @selector(image:didFinishSavingWithError:contextInfo:), NULL);



必要实现的协议方法



- (void)image:(UIImage *)image didFinishSavingWithError:(NSError *)error contextInfo:(void *)contextInfo

{



}



27.输出当前所在的方法名:



NSLog(@"-----%s---",__func__);



28.三目运算符



条件 ?(执行操作) : 其它操作



列: number = i <= 8 ?(i + 1) : 0  解释 : 当i 小于等于8 时  执行 i+1 的操作  否则  执行冒号后面的操作  即 i = 0;



29.在数组中随机取出数据



1) 首先先在数组中随机出一个索引

int  random = arc4random()%numberArray .count;

2) 将取出的数据转化为想要的类型

int number = [numberArray [random]intvalue];

3) 将取出的数据在数组中删除   以防止随机重复

[numberArray removeObjectAtIndex : random];



30.视图修剪 .透明度  隐藏视图 移除视图 :



clip  修剪  bounds 边界



1.是否对视图修剪



bigView .clipsToBounds = YES;



2.设置圆角半径



bigView .layer .cornerRadius =
90;

bigView.layer .masksToBounds = YES;



3.透明度:



_view .alpha = 0;



4.移除视图 :



[_view removeFromSuperview];



31: 字符串拼接输出控件属性值 



NSLog(@" = %@",NSStringFromCGRect(nav.navigationBar.frame));



32:第一响应 :



1.打开程序时  文本框处于编辑状态 即  第一响应

成为第一响应 [_textfield becomeFirstResponder ];

失去第一响应 [_textfield resignFirstResponder];



2.在tocubegin协议方法中调用



self .window ending



33 .导航控制器相关控件内容 



1.设置导航条的背景颜色



错误做法:  nav .navigationBar .backgroundColor =
[UIColor grayColor];



正确做法:nav .navigationBar .barTintColor =
[UIColor grayColor];



2.设置导航条标题



  self .title =@"导航条";



3. 设置左右栏按钮项 (记得按钮绑定方法的实现)



UIBarButtonItem * lifeItem = [[UIBarButtonItem alloc]initWithTitle:@"保存" style:UIBarButtonItemStylePlain target:self  action:(@selector(baoCunBtnClick:))];

  

    self .navigationItem .leftBarButtonItem =
lifeItem;



   

    UIBarButtonItem * rightItem = [[UIBarButtonItem alloc]initWithTitle:@"添加分组" style:UIBarButtonItemStylePlain target:self 
action:(@selector(addGrounpBtnClick:))];

   

    self .navigationItem .rightBarButtonItem =
rightItem;



4.隐藏导航条 :



//注意: 隐藏导航条的时候 不能混着用 怎么让导航条隐藏的 就怎么让导航条出现 :



方法1:



[self .navigationController setNavigationBarHidden:YES];

   

    [self .navigationController setNavigationBarHidden:YES animated:YES];



方法2:



  self .navigationController .navigationBarHidden = YES;

  

    self .navigationController .navigationBarHidden = NO;



补充 :  在视图将要显示的时候  隐藏导航条 :



-(void)viewWillAppear:(BOOL)animated

{

    [super viewWillAppear:animated];

   

    [self .navigationController setNavigationBarHidden:YES];

}



5.设置导航条按钮项时候添加图片  (图片渲染)



UIImage * image = [[UIImage imageNamed:@"back"]imageWithRenderingMode:UIImageRenderingModeAlwaysOriginal];

   

    UIBarButtonItem * backBar = [[UIBarButtonItem alloc]initWithImage:image style:UIBarButtonItemStylePlain target:self action:@selector(backClick)];

   
    self .navigationItem .leftBarButtonItem =
backBar;

  tImgView.contentMode =UIViewContentModeScaleAspectFit;//设置内容样式,通过保持长宽比缩放内容适应视图的大小,任何剩余的区域的视图的界限是透明的

 ///按钮设置背景图片时 设置背景图片大小 防止图片变形

UIImage *btnImg =[UIImage imageNamed:[NSString stringWithFormat:@"button_table_%d",i]];
        UIImage *
bbImg =[btnImg stretchableImageWithLeftCapWidth:100 topCapHeight:100];

6. 隐藏导航条自定义的返回按钮 :


 self .navigationItem .hidesBackButton = YES;

7.导航条上添加控件
    self..navigationItem..titleView
=控件对象=filed;
34.弹框



样式1: UIAlertView



UIAlertView *alertView =[[UIAlertView alloc]initWithTitle:@"提示"
message:@"新建联系人" delegate:self cancelButtonTitle:@"取消"
otherButtonTitles:@"确定", nil];



 //弹框样式 :(带输入框)

    alertView.alertViewStyle =UIAlertViewStyleLoginAndPasswordInput;



    UITextField *field1 =[alertView textFieldAtIndex:0];

    UITextField *field2 =[alertView textFieldAtIndex:1];

    field1.placeholder =@"请输入姓名";

    field2.placeholder =@"请输入电话";

    field2.secureTextEntry=NO;

    [alertView show];



//实现 alertView  首先在.h文件中 实现协议 <UIAlertViewDelegate>



实现协议方法:



-(void)alertView:(UIAlertView *)alertView clickedButtonAtIndex:(NSInteger)buttonIndex;



//通过buttonIndex 的索引值 判断点击的是哪个按钮  0 ,1



样式2: ActionSheet 



//ActionSheet 不可以在viewDidLoad 方法中创建  这是因为 ActionSheet 是在self .view 上展示的  此时我们的viewDidLoad 方法还没有走完   我们的self.view 就不能展示出来 self.view 还没有展示  那么我们放在self.view上的actionsheet 也就无法展示



 UIActionSheet * actionSheet = [[UIActionSheet alloc]initWithTitle:@"提示" delegate:self cancelButtonTitle:@"取消" destructiveButtonTitle:@"确定" otherButtonTitles:nil, nil];

   

    [actionSheet showInView:self .view];

7.设置cell的背景颜色 
-(void)tableView:(UITableView *)tableView
willDisplayCell:(UITableViewCell *)cell forRowAtIndexPath:(NSIndexPath *)indexPath

{

    [cell setBackgroundColor:[UIColor blackColor]];


}

35. 九宫格 



//九宫格

方法1: 嵌套for 循环

    for (int a = 0 ; a <2; a ++) {

        for (int b = 0 ; b < 3 ; b++) {

            UIButton * btn = [UIButton buttonWithType:UIButtonTypeSystem];

           

            btn .backgroundColor = [UIColor redColor];

           

            btn .frame = CGRectMake(30 + (320-70)*a, 80 + (60 + 40) * b, 40, 40);

           

            [self .view addSubview:btn];

        }

    }



 //方法2
.单个for循环

    // 三行三列

   

    for (int a = 0;  a < 9 ; a ++) {

       

        float jiange = (320 - 40 *3)/4;

        int x = a%3;

        int y = a/3;

       

        UIButton * btn = [UIButton buttonWithType:UIButtonTypeSystem];

      

                btn .backgroundColor = [UIColor redColor];

       

        btn .frame =CGRectMake(jiange + (40 + jiange) *x, jiange + (40 + jiange) * y, 40, 40);



36.直接在输出中判断布尔类型 

 n.sex?@"男鸟":@"女鸟"



37.服务器 - 去掉out.println -- 句中的ln换行符



str =[str stringByTrimmingCharactersInSet:[NSCharacterSet whitespaceAndNewlineCharacterSet]];



38.如果URL中路径的字符串拼接的时候
有中文 需要编码 



NSString *encodingString = [path stringByAddingPercentEscapesUsingEncoding:NSUTF8StringEncoding]; 

39.获取沙盒文件中某个文件夹下的所有内容 contentsOfDirectoryAtPath 

NSString *filePath =[NSHomeDirectory() stringByAppendingPathComponent:@"Documents"];

   

//返回值类型是数组

    NSArray *arr =  [F_M contentsOfDirectoryAtPath:filePath error:nil];

   

    NSLog(@"arr===%@",arr);



40 .获取沙盒文件中某个文件的属性 

NSString *filePath =[NSHomeDirectory() stringByAppendingPathComponent:@"Documents/str.plist"];

   

//返回值类型是字典  所以我们可以通过字典内的键值  取出我们想要的数据

  NSDictionary *dic = [F_M attributesOfItemAtPath:filePath error:nil];

    unsigned long long size=
[dic fileSize];

   

    NSLog(@"----%llu",size);

   

   // NSLog(@"dic====%@",dic);



41: 输出对象的时候 设置输出字符串格式 调用的方法 

//输出对象的时候 会调用该对象的description 方法

-(NSString *)description

{

    return [NSString stringWithFormat:@"IP-----%p
  name----%@   age-----%d",self,self .name,self .age];



}



42: 沙盒文件中路径查找的便捷方式 

1.获取根目录文件路径 

NSLog(@"-----%@",NSHomeDirectory());

2.获取临时文件路径  方法类似于获取根目录文件 路径

NSString * temp = NSTemporaryDirectory();

3.获取资源包路径

NSString  *appPath =    [[NSBundle mainBundle]bundlePath];

4.获取某图片或文件夹路径 

NSString * imageViewPath =[[NSBundle mainBundle]pathForResource:@"18" ofType:@"jpg"];

5. 获取某目录下的文件 —> 文件路径

 NSDictionary * dic =[[NSFileManager defaultManager]attributesOfItemAtPath:[self getPath] error:nil];



43: 对象序列化 归档 

步骤 :



1. 创建可变的data (相当于一个空的袋子 )



NSMutableData * data= [[NSMutableData alloc]initWithCapacity:0];



2.归档  关键词 : archiver 



 NSKeyedArchiver * archiver
= [[NSKeyedArchiver alloc]initForWritingWithMutableData:data];



3.编码 : (就是将对象类转变为二进制数据的过程)



 [archiver encodeObject:_arr];



//如果有多个对象的时候 通过 设置 key值来区分



[archiver encodeObject:_arr forKey:@"arr"];

 [archiver encodeObject:_view forKey:@"view"];





4.结束编码的时候  必须调用 接收方法 (完成编码)



[archiver finishEncoding];



5.可以将转变为二进制数据类型的 对象类写入沙盒中



[data writeToFile:  [self getFilePath] atomically:YES];





反序列化 (将二进制数据类型 转换为对象类)



1. 在沙盒中取出data数据



NSData * data = [[NSData alloc]initWithContentsOfFile:[self getFilePath]];



2.将取出的数据交给反序列化来读



NSKeyedUnarchiver * unarchiver = [[NSKeyedUnarchiver alloc]initForReadingWithData:data];



3.解码



NSArray * arr =  [unarchiver decodeObject];



//如果有多个对象 (如上)



 NSArray * arr = [unarchiver decodeObjectForKey:@"arr"];



4.结束解码 :



 [unarchiver finishDecoding];



补充 :  为了调取路径方法方便  可以将获取路径封装成方法 便于调用



-(NSString *)getFilePath

{

    return [NSHomeDirectory()stringByAppendingPathComponent:@"Documents/arr.plist"];



2.自定义对象转码的时候 

1. 需要在.h文件中必须实现的协议 <NSCoding>



2. 在.m 文件中必须实现的两个方法



//将people类中的属性进行编码

//aCoder 编码器

//当用序列化器编码对象的时候 , 该方法就会被调用

-(void)encodeWithCoder:(NSCoder *)aCoder

{

    NSLog(@"3333333333");

   

    [aCoder encodeObject:_name forKey:@"name"];

   

    [aCoder encodeInt:_age forKey:@"age"];



}



//解码

//aDecoder 解码器



//反序列化时 将NSData 解码成对象类型调用的方法



-(id)initWithCoder:(NSCoder *)aDecoder

{

    //任意类型  初始化[super init] 方法

   

    self = [super init];

   

    if (self)
{

       

//需要 self.属性   接收

  self .name =
[aDecoder decodeObjectForKey:@"name"];

       

  self .age =
    [aDecoder decodeIntForKey:@"age"];

       

       

              }



    return self;



}

补充 :  如果再创建一个类  继承与自定义people类时 



实现第二个协议方法时 (返回值为id 的协议方法  ) 需要先继承父类方法 即:

-(id)initWithCoder:(NSCoder *)aDecoder

{

    self = [super initWithCoder:aDecoder];

   

    if (self)
{

       

        [aDecoder decodeObjectForKey:@"huzi"];

       

       

    }

    return self;

}

快速转码  :



1.直接将对象放在沙盒中



 [NSKeyedArchiver archiveRootObject:_arr toFile:[self getFilePath]];





2. 在反序列化中直接取出对象



NSArray * arr =    [NSKeyedUnarchiver unarchiveObjectWithFile:[self getFilePath]];



44:  NSUserDefaults储存数据 (储存轻量级的数据(账号 密码  是否登录))

//1.NSUserDefaults 可以存储的数据类型 : NSString  字典  数组  NSNumber BOOL NSData(二进制数据) NSDate(时间) int(integer)  Double   float    URL(网址)

//2.强制数据及时存储到沙盒

//userDefaults 向沙盒中储存数据  是按照一定的时间戳定时储存数据  如果数据还没来得及存储 而此时程序出现问题 那么数据就会丢失  所以 我们可以同步一下强制数据及时存储到沙盒



    //synchronize 同步  保证数据及时的储存到沙盒中

    [userDefaults synchronize];

 

45: NSUserDefaults  实战中存取文件

存数据: 

[[NSUserDefaults standardUserDefaults]setObject:_nameField.text forKey:@"name"];

        [[NSUserDefaults standardUserDefaults]setObject:_pswField.text forKey:@"psw"];

       

        //同步数据

        [[NSUserDefaults standardUserDefaults]synchronize];



取数据:

NSString * nameString =  [[NSUserDefaults standardUserDefaults]objectForKey:@"name"];



  NSString * pswString  =[[NSUserDefaults standardUserDefaults]objectForKey:@"psw"];



46:判断某路径下是否存在文件
是不是文件夹    关键词 :fileExistsAtPath



 NSString *filePath1 =[NSHomeDirectory() stringByAppendingPathComponent:@"Documents/str.plist"];

   

    NSString *filePath2 =[NSHomeDirectory() stringByAppendingPathComponent:@"Documents/ABC"];

   

    BOOL isDirectory ;

    BOOL isExist= [F_M fileExistsAtPath:filePath2 isDirectory:&isDirectory];

    if (isExist==YES)
{

        NSLog(@"存在文件");

        if (isDirectory==YES)
{

            NSLog(@"是个文件夹");

        }else{

            NSLog(@"不是文件夹");

        }

       

    }else{

        NSLog(@"不存在文件");

    }



47 .网络请求中网络超时设置 

request .timeoutInterval = 10;



48. 单元格关键控件摘要 

1.分割线颜色 样式 :

tableVew .separatorColor =[UIColor redColor];

   

    tableVew .separatorStyle =UITableViewCellSeparatorStyleNone;

2.单元格背景View  可以设置图片 下拉的时候显示

tableVew .backgroundView =imageView;

3.单元格表头背景View 可以设置图片 因为需要设置坐标 可以通过封装方法  然后在ViewDidLoad
方法中调用

tableVew.tableHeaderView =imageView;

4.视图修剪

cell.imageView.layer.cornerRadius = 50;

    cell.imageView.layer.masksToBounds = YES;



5.cell小挂件 

cell .accessoryType =UITableViewCellAccessoryDetailButton;

6.点击单元格时候的样式:

cell .selectionStyle = UITableViewCellSelectionStyleNone;

7.如果想把单元格的白色背景去掉的话 需要将tableView 和cell 上的背景颜色都设置为clearColor 



8.点击单元格上的按钮时候 在按钮绑定的方法中找到点击的是哪一行上的按钮  需要通过按钮 找到cell 
再通过cell 找到IndexPath

eg:

UITableViewCell * cell =(UITableViewCell *)btn.superview.superview;



NSIndexPath * indexPath =[_tableView indexPathForCell:cell];



9.区头区尾相关内容

//也需要重用

区头和区尾的设置中 相关的控件设置和添加需要放在 view .contentView 

e.g:

1.view .contentView .backgroundColor =
[UIColor grayColor];

2.[view.contentView addSubview:img];



10.单元格索引 :

将索引标示放在数组中

eg:

self . arr =
@[@"A",@"B",@"C",@"D",@"E",@"F",@"G",@"H",@"I",@"J",@"K",@"L",@"M",@"N",@"O",@"P",@"Q",@"R",@"S",@"T",@"U",@"V",@"W",@"X",@"Y",@"Z",@"#",];



区索引调用的方法:

-(NSArray *)sectionIndexTitlesForTableView:(UITableView *)tableView

{

    return _arr;

}



49. btn 按钮的失去响应

btn .enabled = NO;

//默认值 YES

btn.enabled = YES;



50.在为URL添加字符串时 包含特殊字符或中文的
需要编码转换

string =[string stringByAddingPercentEscapesUsingEncoding:NSUTF8StringEncoding];



51.图片转化为二进制数据 

//一下的两种方法都可以 但是 PNG的返回的图片量与原图大小差不多 而jpg 的 会压缩参数 

// NSData * data =UIImagePNGRepresentation(self.imageView.image);

   

//NSData * data =UIImageJPEGRepresentation(self.imageView.image, 0.00001);



52.断点下载个别属性摘要 

1. 获取已经下载文件的大小 文件较大的时候 可以用long long 创建实例变量

_receiveSize =[dic fileSize];



2.通过Range
头 —> 可以指定每次从网上下载数据包的大小

[request addValue:[NSString stringWithFormat:@"bytes=%lld-",_receiveSize] forHTTPHeaderField:@"Range"];



3.期望从服务器中返回的剩余的数据 expectedContentLength

long long lastSize = response.expectedContentLength;



4.受到响应的时候 需要创建对象 并给对象一个写文件的路径

_fileHandle =  [NSFileHandle fileHandleForWritingAtPath:[self getPath]];



//找到已经下载文件的结尾数据

    [_fileHandle seekToEndOfFile];

//写入数据 

[_fileHandle writeData:data];

//开始在接受数据的协议方法中不断的追加数据 

 _receiveSize +=[data length];



5.下载进度  赋值到进度条



    //当前下载比例 = 接收数据 / 总数据

    float progress =(float) _receiveSize /_totalSize;



    self.weak.progress = progress;

   

    self .persentLabel.text = [NSString stringWithFormat:@"%.2f%%",progress*100];



6.暂停数据绑定的方法中 暂停请求数据 同时将请求数据指为空 (类似于定时器)



[_connection cancel];

 _connection = nil;



53.OC中对用户名和密码编码 和加密常用的方法 
base64 MD5 



//在需要加密内容的后面添加后缀

eg:     _nameField.text base64EncodedString 编码 

    _nameField.text base64DecodedString 解码

  

          _pswField.text MD5 加密



54.在web请求体重  截取某个字段



eg:@"https://api.weibo.com/oauth2/authorize?client_id=1950801855&response_type=code &redirect_uri=http://www.baidu.com" 该请求体中的 code 



 NSRange range =[request.URL .absoluteString rangeOfString:@"code="];



NSString * code =[[request.URL.absoluteString componentsSeparatedByString:@"="]lastObject];


55.判断授权token
和 过期时间的两种方式 : 



//方式1:

 NSString *
token =[[NSUserDefaults standardUserDefaults]objectForKey:@"token"];

    NSDate * time =[[NSUserDefaults standardUserDefaults]objectForKey:@"time"];

   

    if (token == nil ||[token isEqualToString:@""])
{

       

        return NO;

    }

    if ([[NSDate date]compare:time]!=NSOrderedAscending)
{

       

        return NO;

    }

   



    return YES;



//方式2:



NSString * token = [[NSUserDefaults standardUserDefaults]objectForKey:@"token"];

   

    //过期时间

  NSDate * date = [[NSUserDefaults standardUserDefaults]objectForKey:@"date"];

   

    if (token == nil ||[token isEqualToString:@""])
{

       

        return NO;

    }

   

    //当前时间

    NSDate * currentDate =[NSDate date];

   

    //当前时间和过期时间 对比

    if ([[currentDate laterDate:date]isEqualToDate:currentDate])
{

       

       

        return NO;

    }



    return YES;







56.如果需要设置多个tag值时

//一般设置tag值 只需要设置为数字进行区分的话
就可以 但是如果接口较多 需要区分的话 单独的设置为数字 时间久的话 不好辨认 所以我们可以模仿系统  来写出一个枚举来



eg:// NSInteger 指的是枚举中值的类型 RequestType 总的请求类型

typedef NS_ENUM(NSInteger,
RequestType)

{

    GetTokenRequestTag = 0,

    GetStatusListRequestTag

  

需要再往下写的时候  不需要设置数字就可以 因为系统会自动递增 

};



调用时 :

      对象.tag = GetTokenRequestTag;



57.向上取整



//首先可以先获取矩形高度 然后向上取整 eg:



CGRect rect =[string boundingRectWithSize:CGSizeMake(310, MAXFLOAT) options:NSStringDrawingUsesLineFragmentOrigin|NSStringDrawingUsesFontLeading attributes:@{NSFontAttributeName:
[UIFont systemFontOfSize:17]} context:nil];



    //向上取整

    return ceilf(rect.size.height);

    

       

58.查找某个具体文件(eg:图片)路径的方法



NSString * directoryPath =[NSHomeDirectory()stringByAppendingPathComponent:@"Documents/ImageCache"];

   

    //保证沙盒中的Documents 中一定有一个ImageCache 文件夹

   

    if (![[NSFileManager defaultManager]fileExistsAtPath:directoryPath])
{

       

        [[NSFileManager defaultManager]createDirectoryAtPath:directoryPath withIntermediateDirectories:YES attributes:nil error:nil];

       

    }

   

     //把图片的地址字符串分割 最后一个/ 之后的那段就是图片的名字

    NSString * fileName =[[urlString componentsSeparatedByString:@"/"]lastObject];

   

    NSString * filePath =[NSString stringWithFormat:@"%@/%@",directoryPath,fileName];

   

    return filePath;


59.在导航条上添加UI控件 
self.navigationItem.titleView =segment;

60.视图留白
self.automaticallyAdjustsScrollViewInsets = NO;

61.汉字转为拼音相关内容
 //城市列表  通讯录  右边索引 字母或者拼音如何的到

   

    NSMutableString * hanzi =[[NSMutableString alloc]initWithString:@"中华人民共和国 重庆 长城 单家庄"];



    CFMutableStringRef hanziRef =(__bridge CFMutableStringRef)hanzi;

   

    //CFStringTransform 字符串转化

    //kCFStringTransformMandarinLatin 汉字转拼音

    //kCFStringTransformStripDiacritics 拼音去音标

    CFStringTransform(hanziRef, 0, kCFStringTransformMandarinLatin, NO);

    NSLog(@"---%@",hanziRef);

   

    CFStringTransform(hanziRef, 0, kCFStringTransformStripDiacritics, NO);

    NSLog(@"111---%@",hanziRef);

62.设备宽高宏定义

#define  DEVICE_WIDTH  [UIScreen mainScreen].bounds.size.width
#define  DEVICE_HEIGHT  [UIScreen mainScreen].bounds.size.height

63: 给button 按钮设置背景图片时 设置背景图片大小 防止图片变形

UIImage *btnImg =[UIImage imageNamed:[NSString stringWithFormat:@"button_table_%d",i]];

        UIImage * bbImg =[btnImg stretchableImageWithLeftCapWidth:100 topCapHeight:100];
        [btn setBackgroundImage:bbImg forState:UIControlStateNormal];

64: 异常处理 


 AppDelegate .m 文件




- (BOOL)application:(UIApplication *)application
didFinishLaunchingWithOptions:(NSDictionary *)launchOptions {



    //输出模拟器类型

    NSLog(@"%@",[[UIDevice currentDevice]model]);

   

    //绑定扑捉异常的函数 当程序崩溃时 会先调用这个函数

    NSSetUncaughtExceptionHandler(&getException);

   

    return YES;

}



void getException(NSException *exception){

    //遇到特殊情况时 需要把异常的具体信息获取并储存

   

    NSLog(@"名字----%@",exception.name);

    NSLog(@"原因----%@",exception.reason);

    NSLog(@"用户信息----%@",exception.userInfo);

    NSLog(@"栈内存地址----%@",exception.callStackReturnAddresses);

    NSLog(@"栈描述----%@",exception.callStackSymbols);



    NSString *string = [NSString stringWithFormat:@"名字%@,原因%@,信息%@,栈内存地址%@,栈描述%@",exception.name,exception.reason,exception.userInfo,exception.callStackReturnAddresses,exception.callStackSymbols];

   

    NSLog(@"%@",string);

    NSDate *date = [NSDate date];





    //当前的系统版本号

    NSString * verSion =[[UIDevice currentDevice]systemVersion];

   

    //当前设备型号

    [[UIDevice currentDevice]model];

   

    //储存崩溃信息

   

    NSString * path =[NSHomeDirectory()stringByAppendingPathComponent:@"Library/exception.txt"];

    [string writeToFile:path atomically:YES encoding:NSUTF8StringEncoding error:nil];



    //当程序再次启动时 把崩溃信息发送给服务器
}
65: 去除掉首尾的空白字符和换行字符

NSString* headerData=***;
headerData = [headerData stringByTrimmingCharactersInSet:[NSCharacterSet whitespaceAndNewlineCharacterSet]]; 
//去除掉首尾的空白字符和换行字符
       headerData = [headerData stringByReplacingOccurrencesOfString:@"\r" withString:@""];
       headerData = [headerData stringByReplacingOccurrencesOfString:@"\n" withString:@""];

66:为视图view自定义矩形大小

self.edgesForExtendedLayout = UIRectEdgeNone;

    CGRect viewBounds = self.view.bounds;

    float navBarHeight = self.navigationController.navigationBar.frame.size.height +
20;

    viewBounds.size.height =
([[UIScreen mainScreen] bounds].size.height)
- navBarHeight;
    self.view.bounds =
viewBounds;



文章来源:http://blog.csdn.net/one_person_one_life/article/details/51751022,感谢整理!

iOS基础常用细节问题处理65条的更多相关文章

  1. IOS开发常用设计模式

    IOS开发常用设计模式 说起设计模式,感觉自己把握不了笔头,所以单拿出iOS开发中的几种常用设计模式谈一下. 单例模式(Singleton) 概念:整个应用或系统只能有该类的一个实例 在iOS开发我们 ...

  2. iOS开发-常用第三方开源框架介绍

    iOS开发-常用第三方开源框架介绍 图像: 1.图片浏览控件MWPhotoBrowser        实现了一个照片浏览器类似 iOS 自带的相册应用,可显示来自手机的图片或者是网络图片,可自动从网 ...

  3. iOS基础UI控件介绍-Swift版

    iOS基础UI控件总结 iOS基础控件包括以下几类: 1.继承自NSObject:(暂列为控件) UIColor //颜色 UIImage //图像 2.继承自UIView: 只能相应手势UIGest ...

  4. IOS基础学习-2: UIButton

    IOS基础学习-2: UIButton   UIButton是一个标准的UIControl控件,UIKit提供了一组控件:UISwitch开关.UIButton按钮.UISegmentedContro ...

  5. iOS基础问答面试

    <简书社区 — Timhbw>iOS基础问答面试题连载(一)-附答案:http://www.jianshu.com/p/1ebf7333808d <简书社区 — Timhbw> ...

  6. 2017 Android 面试题 [ 基础与细节 ]

    2017 Android 面试题 [ 基础与细节 ] 感谢@chuyao抛出的这些问题,平时业务代码写多了,很多基础的东西变得含糊不清了,这次裸辞出来找工作确实没有之前顺利,顺便求上海Android开 ...

  7. Git 基础 —— 常用命令

    Git 基础学习系列 Git 基础 -- 安装 配置 别名 对象 Git 基础 -- 常用命令 Git 基础 -- 常见使用场景 Git基础 -- Github 的使用 git init 创建 Git ...

  8. 基础常用JS函数和语法

    100多个基础常用JS函数和语法集合大全  来源:http://www.cnblogs.com/hnyei/p/4605103.html 网站特效离不开脚本,javascript是最常用的脚本语言,我 ...

  9. amazeui学习笔记--css(常用组件13)--进度条Progress

    amazeui学习笔记--css(常用组件13)--进度条Progress 一.总结 1.进度条基本使用:进度条组件,.am-progress 为容器,.am-progress-bar 为进度显示信息 ...

随机推荐

  1. Appium--swipe滑动方法

    最近公司要求对APP模块自动化,以Android 自动化为例,把appium滑动的方法swipe()再小结下.滑动的目的,一方面是为了更好的查找元素,一方面就是为了滑屏操作.代码如下: package ...

  2. Java中next()和nextLine()

    next()读取到有效字符后才可以结束输入,对输入有效字符之前遇到的空格键.Tab键或Enter键等结束符,next()方法会自动将其去掉,只有在输入有效字符之后,next()方法才将其后输入的空格键 ...

  3. Docker常见仓库Nginx

    Nginx 基本信息 Nginx 是开源的高效的 Web 服务器实现,支持 HTTP.HTTPS.SMTP.POP3.IMAP 等协议. 该仓库提供了 Nginx 1.0 ~ 1.7 各个版本的镜像. ...

  4. 【java集合系列】--- LinkedList

    开篇前言--LinkedList中的基本用法 在前面的博文中,小编介绍List接口中的ArrayList集合,List这个接口,有两个实现类,一个就是ArrayList另一个是LinkedList(链 ...

  5. Linux SWAP 交换分区配置说明

    一.SWAP 说明1.1 SWAP 概述        当系统的物理内存不够用的时候,就需要将物理内存中的一部分空间释放出来,以供当前运行的程序使用.那些被释放的空间可能来自一些很长时间没有什么操作的 ...

  6. spark运算结果写入hbase及优化

    在Spark中利用map-reduce或者spark sql分析了数据之后,我们需要将结果写入外部文件系统. 本文,以向Hbase中写数据,为例,说一下,Spark怎么向Hbase中写数据. 首先,需 ...

  7. 安卓开发:简单的登陆跳转_APK实现直接跳转到本CSDN博客

    最近在开始接触Android APP开发,有了一点java基础之后,安卓代码确实看起来就没有那么难了,可以跟着书上把例程敲一遍,然后熟能生巧可以应用起来,现在写了一个简单的APP,实现的是Edit编辑 ...

  8. JAVA进阶之旅(二)——认识Class类,反射的概念,Constructor,Field,Method,反射Main方法,数组的反射和实践

    JAVA进阶之旅(二)--认识Class类,反射的概念,Constructor,Field,Method,反射Main方法,数组的反射和实践 我们继续聊JAVA,这次比较有意思,那就是反射了 一.认识 ...

  9. x264源代码简单分析:x264_slice_write()

    ===================================================== H.264源代码分析文章列表: [编码 - x264] x264源代码简单分析:概述 x26 ...

  10. Unity插件 - MeshEditor(七)变形动画骨骼及蒙皮

    MeshAnimation在物体的顶点比较多的情况下,悲剧是显而可见的,我一个一个的点选顶点肯定得累死,而且对于形态的调控不是很方便,应该说是很麻烦,要知道,骨骼动画因为有了骨骼以及蒙皮信息而有了灵魂 ...