一些iOS心得

时间:2023-03-08 15:58:19

ARC
 1,arc是什么? automatic referece counting   mrc mannual
iOS5 之后出来的技术
// 2,arc的原理是什么?
//   在程序编译的时候,系统帮我们在合适的地方加上retain,release等
// 3,不能在使用retain,release,autorelease,retaincount
 4,使用__strong,__weak,__unsafe_unretained这些修饰符来对变量进行描述
4.1,如果一个对象没有强引用的指针指向它,就会被立刻释放
// 用法:全局变量用__strong,并且全局的__strong指针会在当前类的对象被释放的时候被赋值为nil
//      局部变量用__strong,并且局部的指针 会在超出作用域之后被赋值为nil
// 属性描述  如果是对象类型  用strong,如果是基本数据类型 unsafe_unretaind 或者 assign
// 5,autorelease不能使用,如果需要使用,__autoreleasing(方法内部创建对象,把对象返回到外面使用)
// 6,连线 用__weak
// 7,解决block中的循环引用使用__weak
// 8,属性名字不能以new开头,如果需要以new开头,那么就自己指定get方法的方法名
// 9,arc下 使用自动释放池  @autoreleasepool{}
// arc下  retain 就是strong  assign就是unsafe_unretained
// 10, coreFoundation  和 foundation相互转化  交换对象所有权
// 11,arc下结构体中不能使用oc对象
// 12,arc和非arc混编的时候
//    arc下某些类使用mrc编译  -fno-objc-arc
//    mrc下某些类使用arc编译  -fobjc-arc
// 13,让某些类必须在arc下使用,如果不是arc的环境,就报错
/*
#if !__has_feature(objc_arc)
#error  必须使用arc编译
#endif
 */

// coreFoundation框架中提供很多常用的类型,但是语法是基于c的
    // arc 只会帮你管理Foundation框架中的对象,不会帮你管理core Foundation框架中的对象
   
    // CFBridgingRetain 把foundation框架中对象的所有权,交给corefoundation框架来处理
    NSString *str = @"str";
    CFStringRef cfstr = (CFStringRef)CFBridgingRetain(str);
    CFRelease(cfstr);
   
   
    // 创建了一个core Foundation框架中的对象
    CFStringRef cfstr2 = CFStringCreateWithCString(kCFAllocatorDefault, "str2", kCFStringEncodingUTF8);
    NSString *str2 = (__bridge_transfer  NSString *)cfstr2;
深浅COPY
// 浅拷贝:指针的拷贝
    // 深拷贝:对象的拷贝
    // 完全拷贝:对象,包括对象中的对象都是拷贝
    // (编码 解码的方式 实现了完全拷贝)

// 小结!!!!!!
 对非容器类的不可变对象做的测试
对非容器类的可变的对象做测试
    // 调用copy方法 得到的对象都是不可变的对象
    // 调用mutableCopy方法 得到的都是可变的对象
   
可变的对象 无论是调用copy,或者mutableCopy都是深拷贝
   
    // 结论:只有不可变对象调用copy方法是浅拷贝,其他所有的都是深拷贝

/*
    // 实现完全拷贝
    NSMutableArray *array1 = [[NSMutableArray alloc] initWithObjects:@"1",@"2", nil];
   
    // 把数组编码成data
    NSMutableData *data = [[NSMutableData alloc] init];
    NSKeyedArchiver *archiver = [[NSKeyedArchiver alloc] initForWritingWithMutableData:data];
    [archiver encodeObject:array1];
    [archiver finishEncoding];
   
   
    // 把data解码成数组
    NSKeyedUnarchiver *unarhiver = [[NSKeyedUnarchiver alloc] initForReadingWithData:data];
    NSMutableArray *array4 = [unarhiver decodeObject];
    [unarhiver finishDecoding];
   
    NSLog(@"%p   %p  ",array1,array4);
    NSLog(@"%p    %p   ",[array1 objectAtIndex:0],[array4 objectAtIndex:0]);
     */

map
// 创建一个定位管理器(一定要写成全局的)
    _manager = [[CLLocationManager alloc] init];
    _manager.delegate = self;
   
    // 在iOS8 以前不需要请求授权
    // 也不需要在info.plist文件中配置信息
    // 在软件使用的过程中去获取位置信息
    // NSLocationWhenInUseUsageDescription
    // 不仅在使用的过程中 还可以在程序进入后台的时候也可以定位
    // NSLocationAlwaysUsageDescription
   
   
    // 判断系统的版本号,根据不同的版本执行不同的代码
#define SystemVersion  [[[UIDevice currentDevice] systemVersion] floatValue]
    if (SystemVersion >= 8.0)
    {
        // 请求权限的
        //[_manager requestAlwaysAuthorization];
    }
   
    if ([CLLocationManager locationServicesEnabled])
    {
        NSLog(@"可以使用定位功能");