OC零散小知识总结

1,循环引用

@interface ClassB ()
@property (nonatomic, strong) ClassA *classA;
@end

如代码,classA 是ClassB的一个属性,就是说ClassB拥有(也可说引用)classA, 表示为如图关系


jietu.png

理解了这层引用关系,对于delegate 为什么要用weak 修饰符,block可能会出现循环引用的解答就有帮助。

2,属性特质

1)原子性(atomic 和 nonatomic)

默认是atomic,原子的。两者的区别:具有atomic特质的获取方法会通过同步锁机制来确保其操作的原子性。比如,两条线程读写统一属性,如果用atomic,那么不论何时,总能看到有效的属性值。如果不加锁的话(使用nonatomic),那么当其中一个线程正在改写某属性时,另外一个线程也许会突然闯入,把尚未修改好的属性值读取出来,这时,线程读到的属性值可能不对。但是,在iOS程序里,所有属性都是声明为nonatomic。原因:在iOS中使用同步锁的开销比较大,这会带来性能问题。还有“原子的”属性也并不能完全保证线程安全,若要实现线程安全的操作,还需要更为深层的锁定机制才行

2)内存管理语义
  • assign 基本数据类型
  • strong 表明该属性定义了一种"拥有关系"。为该属性设置新值时,设置方法里会保留新值,并释放旧值,然后再将新值设置上去
  • weak 表明该属性定义了一种"非拥有关系"。为该属性设置新值时,设置方法里既不会保留新值,也不会释放旧值,同assign类似,只是使用weak,属性所指的对象遭到摧毁时,属性值会自动清空,置为nil。而assign则不会
  • copy 所属关系与strong类似,只是设置方法里并不是保留新值,而是将新值"copy"一份。
  • unsafe_unretained 与assign相同,但它适用于对象类型
3)读写权限

有readwrite 和 readonly 两种权限。默认是readwrite. 尽量使用不可变对象,即属性尽量用readonly修饰

4)方法名

getter = <name> setter=<name>(少用)

3,类簇与工厂模式

示例如下,EOCEmployee是基类,剩下的类都是其子类

typedef NS_ENUM(NSUInteger, EOCEmployeeType) {
    EOCEmployeeTypeDesigner,
    EOCEmployeeTypeDeveloper,
    EOCEmployeeTypeTester,
    EOCEmployeeTypeFinance
};
@interface EOCEmployee : NSObject
@property (nonatomic, copy) NSString *name;
@property (nonatomic, assign) NSUInteger salary;

+ (EOCEmployee *)employeeWithType:(EOCEmployeeType)type;
- (void)doADaysWork;
@end

@implementation EOCEmployee
+ (EOCEmployee *)employeeWithType:(EOCEmployeeType)type {
    switch (type) {
        case EOCEmployeeTypeDesigner:
            return [[EOCEmployeeDesigner alloc] init];
            break;
        case EOCEmployeeTypeDeveloper:
            return [[EOCEmployeeDeveloper alloc] init];
            break;
        case EOCEmployeeTypeTester:
            return [[EOCEmployeeTester alloc] init];
            break;            
        case EOCEmployeeTypeFinance:
            return [[EOCEmployeeFinance alloc] init];
            break;
    }
    
}
- (void)doADaysWork {
    //子类自己去实现。。。
}

@end

子类继承,实现父类方法

#import "EOCEmployee.h"
@interface EOCEmployeeDeveloper : EOCEmployee
@end
@implementation EOCEmployeeDeveloper

- (void)doADaysWork {
    NSLog(@"i am developer");
}
@end
#import "EOCEmployee.h"
@interface EOCEmployeeDesigner : EOCEmployee
@end

#import "EOCEmployeeDesigner.h"
@implementation EOCEmployeeDesigner
- (void)doADaysWork {
    NSLog(@"i am designer...");
}
@end

接下来test

#import "ViewController.h"
#import "EOCEmployee.h"

@interface ViewController ()
@end
@implementation ViewController

- (void)viewDidLoad {
    [super viewDidLoad];
    
    EOCEmployee *paEmployee = [EOCEmployee employeeWithType:EOCEmployeeTypeDeveloper];
    [paEmployee doADaysWork];
    // Do any additional setup after loading the view, typically from a nib.
}
@end

以上就是类簇的创建模式。类簇模式可以把实现细节隐藏在一套简单的公共接口后面。在系统框架中使用

4,runtime的一些基本知识

1)C语言使用的是"静态绑定",即在编译器就能决定运行时所应调用的函数,而OC采用的是"动态绑定",只有在运行时才能确定。在底层,对象收到消息后,究竟该调用哪个方法完全在运行期决定,甚至可以在程序运行时改变

5,发邮件 MFMailComposeViewController 使用注意

  1. 需要导入MessageUI.framework库(实际上,ios10之后就无需手动导入了,为兼容低版本,最好手动导入)
    2)发邮件前,需要判断 MFMailComposeViewController 是否有发邮件的功能,否则可能会cresh. 报错 Application tried to present a nil modal view controller on target
MFMailComposeViewController *mc = [[MFMailComposeViewController alloc] init];
    if ([MFMailComposeViewController canSendMail]) {
        mc.mailComposeDelegate = self;
        [mc setSubject:emailTitle];
        [mc setMessageBody:messageBody isHTML:NO];
        [mc setToRecipients:toRecipents];
        
        //Present mail view controller on screen
        [self presentViewController:mc animated:YES completion:nil];
    }

6,用storyboard创建tableViewCell或者collectionViewCell 时,当在storyboard里使用了Identifier,并在代码里做了匹配时,如下两图,就不再需要用代码提前注册cell了,否则会出错。

屏幕快照 2017-03-14 16.37.09.png
屏幕快照 2017-03-14 16.37.52.png
needDelete.png

7,哪些场景必须要使用@synthesize?

8,通知NSNotificationCenter的一点认识

  • 我们知道通知是一对多的关系,即一处发通知,多处可接收。假设有这个场景:A-->B-->C-->D, push关系,这4个控制器全部都在同一个栈里。当在C控制器里点击确定按钮push 到D时发送通知,并且在 A,B页面里都接收这个通知,在对应通知方法里做某些处理(比如请求数据,刷新当前页面...)
    之前的认知: C push 到D的时候 发送通知,A,B即使接收了该通知,也不会有相应的处理,因为当前response的页面是D,而不是它们
    经过测试验证,认知是错误的,只要它们在同一个栈里,有一处发通知,其他任何有监听这个通知的地方都会及时响应并处理,如果考虑性能,这点就不太合理,也就是push 到 D 时尽量避免给栈内的其他控制器发送通知。代理delegate 应该也有如此

9,iOS里通用的数据结构有三类:数组,字典,集合(Set)。

有时候脑袋不灵光,把最基本的忘记了,通过看书,把一些基本的知识点记下来。“好记性不如烂笔头”,经常翻翻以巩固记忆

©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 216,125评论 6 498
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 92,293评论 3 392
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 162,054评论 0 351
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 58,077评论 1 291
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 67,096评论 6 388
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 51,062评论 1 295
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,988评论 3 417
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 38,817评论 0 273
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 45,266评论 1 310
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 37,486评论 2 331
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,646评论 1 347
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 35,375评论 5 342
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,974评论 3 325
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,621评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,796评论 1 268
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 47,642评论 2 368
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 44,538评论 2 352

推荐阅读更多精彩内容

  • “第一次打开游戏请允许“使用数据”,否则游戏无法正常运行。” 曾登上首页推荐的最有创意的六边形消消乐游戏,这是一款...
    反射阅读 783评论 0 0
  • 他在我心里,是坚强的代名词,他好像就不知道疼。 2013年清明节,出了车祸,胳膊受伤之后还坚持去拉了一车沙子,回来...
    渠六亿阅读 451评论 7 5
  • 第一次写东西,也不知道写什么东西。希望以后能在简书上写一些技术和自己的生活吧。记录自己美好的一天。2016年新的开...
    c5f8c453b41e阅读 174评论 0 1
  • 2016年2月16日 随笔 互联网时代信息量呈爆炸式增长,而且更多的信息变得更透明、更容易获取。我们要想在大信息量...
    杰逸阅读 904评论 0 0