IOS是否在项目中存在,所使用的反射那点事

NSClassFromString,NSSelectorFromString,isKingOfClass

1. NSClassFromString

  这种方法推断类是否存在,假设存在就动态载入的,不存为就返回一个空对象;

  id myObj = [[NSClassFromString(@"MySpecialClass") alloc] init];

  正常情况下等价于:id myObj = [[MySpecialClass alloc] init];

  长处:

1, 弱化连接,因此并不会把没有的Framework也link到程序中。

2,不须要使用import。由于类是动态载入的,仅仅要存在就能够载入。因此假设你的toolchain中没有某个类的头文件定义。而你确信这个类是能够用的。那么也能够用这样的方法。

2. NSSelectorFromString

  这种方法是上个方法的补充,也是动态载入实例方法。

  SEL sel = NSSelectorFromString(@"doSomethingMethod:")//注意这个冒号,说明方法带有參数

  if([object respondsToSelector:sel]) {

      [object performSelector:sel withObject:color]; //注意假设有两个參数,使用两个withObject:參数;

  }

3. isKindOfClass

  isKindOfClass 我们也能够使用isKindOfClass来检查一个对象是否是一个类的成员


4. isMemberOfClass

  isMemberOfClass方法是来确定对象是否是某一个类的成员

  

5. initWithCoder和initWithFrame的差别  initWithCoder是一个类在IB中创建但在xocdde中被实例化时被调用的.比方,通过IB创建一个controller的nib文件,然后在xocde中通过initWithNibName来实例化这个controller,那么这个controller的initWithCoder会被调用.

  initWithFrame是由用户创建的UIView子类,实例时被调用

6. UIView autoresizingMask

  假设视图的autoresizesSubviews属性声明被设置为YES。则其子视图会依据autoresizingMask属性的值自己主动进行尺寸调整。简单配置一下视图的自己主动尺寸调整掩码经常就能使应用程序得到合适的行为;否则。应用程序就必须通过重载layoutSubviews方法来提供自己的实现。

  self.autoresizingMask = UIViewAutoresizingFlexibleWidth;//这个常量假设被设置,视图的宽度将和父视图的宽度一起成比例变化。否则,视图的宽度将保持不变。

  

UIViewAutoresizingNone

这个常量假设被设置,视图将不进行自己主动尺寸调整。

UIViewAutoresizingFlexibleHeight

这个常量假设被设置。视图的高度将和父视图的高度一起成比例变化。否则。视图的高度将保持不变。

UIViewAutoresizingFlexibleWidth

这个常量假设被设置。视图的宽度将和父视图的宽度一起成比例变化。否则,视图的宽度将保持不变。

UIViewAutoresizingFlexibleLeftMargin

这个常量假设被设置,视图的左边界将随着父视图宽度的变化而按比例进行调整。否则,视图和其父视图的左边界的相对位置将保持不变。

UIViewAutoresizingFlexibleRightMargin

这个常量假设被设置。视图的右边界将随着父视图宽度的变化而按比例进行调整。否则,视图和其父视图的右边界的相对位置将保持不变。

UIViewAutoresizingFlexibleBottomMargin

这个常量假设被设置,视图的底边界将随着父视图高度的变化而按比例进行调整。

否则,视图和其父视图的底边界的相对位置将保持不变。

UIViewAutoresizingFlexibleTopMargin

这个常量假设被设置。视图的上边界将随着父视图高度的变化而按比例进行调整。否则。视图和其父视图的上边界的相对位置将保持不变。


原文地址:https://www.cnblogs.com/cynchanpin/p/7284109.html