一、OC和swift的相互调用
两者是基于两种不同的方式来实现的,例如OC在运行时决定对象的类型,而swift为了提高效率要求在编译时就必须确定对象类型。所以,要无缝兼容就需要做大量的工作。
swift兼容大部分OC(通过对应的关系)还是有些地方没有考虑到兼容OC,比如:
1、swift中无法使用预处理指令(宏定义,swift中推举使用常量定义)。
2、swift中无法使用performSelector来执行一个方法,因为swift认为这样是不安全的的。
3、swift汇总一个类集成NSObject,那么它会自动兼容OC。但是如果没有继承,就需要用关键字“@objc”进行标注,
二、反射
所谓反射就是可以动态获取类型、成员信息,在运行时可以调用方法,属性等行为的特性。
OC的runtime要比其他语言的反射机制强大得多。在OC中可以很简单的实现字符串和类型的转换、实现动态方法的调用、动态赋值(KVC)等等。
但是,在swift中不提倡使用runtime,而是向其他语言一样使用反射(reflect),即使目前的swift中的反射还没有其他语言的反射功能强大。
通过反射可以获取到变量(常量)的信息,并且能够读取其成员的值,但是swift原生并不支持给有某个成员动态设值。如果想要进行动态设置,可以利用前面介绍的swift和OC兼容的只是来实现,只要这个类是继承自NSObject就会有对应的setValue:forkey:方法来使用KVC。注意:这仅限于类。如果是结构体就不行了。
三、内存管理
swift使用ARC来管理内存,大多数情况下不需要开发者手动管理内存,但在使用OC开发时大家都会遇到循环引用的问题,所以在swift中也是无法避免的。
主要出现的场景为在闭包最好能够,因为闭包会持有其内部引用的元素。解决办法为在闭包中使用[unowned self] in即可
四、指针和内存
除了循环引用的问题,swift之所以将指针类型标识为”unsafe”,是因为之真没法像其他类型一样自动管理内存,因此有必要了解一下指针和内存的关系。如果需要对一个变量进行指针操作可以借助于Swift中提供的一个方法withUnsafePointer。
五、命名空间
命名空间:通俗的说,每个名字空间都是一个名字空间域,存放在名字空间域中的全局实体只在本空间域内有效。名字空间对全局实体加以域的限制,从而合理的解决命名冲突。
OC没有命名空间,所以如果两个类或者文件命名相同会有冲突。
六:使用 mutating 关键字的作用是什么?
使用 mutating 关键字修饰方法是为了能在该方法中修改 struct 或是 enum 的变量,在设计接口的时候,也要考虑到使用者程序的扩展性。所以要多考虑使用mutating来修饰方法。
网址:https://www.jianshu.com/p/14cc9d30770a
七、访问权限
1、private
private访问级别所修饰的属性或者方法只能在当前类里访问。
2、fileprivate
fileprivate访问级别所修饰的属性或者方法在当前的Swift源文件里可以访问。
3、internal(默认访问级别,internal修饰符可写可不写)
internal访问级别所修饰的属性或方法在源代码所在的整个模块都可以访问。
如果是框架或者库代码,则在整个框架内部都可以访问,框架由外部代码所引用时,则不可以访问。
如果是App代码,也是在整个App代码,也是在整个App内部可以访问。
4、public
可以被任何人访问。但其他module中不可以被override和继承,而在module内可以被override和继承。
5、open
可以被任何人使用,包括override和继承。
访问顺序:
现在的访问权限则依次为:open>public>internal>fileprivate>private。