NSClassFromString和NSStringFromClass
NSStringFormClass 這個不用說,看命名都應該知道吧。
NSClassFromString 將NSString轉換成一個Class,如果不存在,返回一個nil。
正常來說,
id myObj = [[NSClassFromString(@"MySpecialClass") alloc] init];
和
id myObj = [[MySpecialClass alloc] init];
是一樣的。但是,如果你的程式中並不存在MySpecialClass這個類,下面的寫法會出錯,而上面的寫法只是返回一個空物件而已。
因此,在某些情況下,可以使用NSClassFromString來進行你不確定的類的初始化。
比如在iPhone中,NSTask可能就會出現這種情況,所以在你需要使用NSTask時,最好使用:
[[NSClassFromString(@"NSTask") .....]]
而不要直接使用[NSTask ...]這種寫法。
NSClassFromString的好處是:
1 弱化連線,因此並不會把沒有的Framework也link到程式中。
2 不需要使用import,因為類是動態載入的,只要存在就可以載入。因此如果你的toolchain中沒有某個類的標頭檔案定義,而你確信這個類是可以用的,那麼也可以用這種方法。
同樣的,還可以透過一個方法名字來得到一個Selector,然後就可以動態的呼叫這個Selector了,在Obj-c裡面,一切都是動態的。
類似的函式如下:
NSClassFromString
NSGetSizeAndAlignment
NSLog
NSLogv
NSSelectorFromString
NSStringFromClass
NSStringFromSelector
NSClassFromString和NSStringFromClass
NSStringFormClass 這個不用說,看命名都應該知道吧。
NSClassFromString 將NSString轉換成一個Class,如果不存在,返回一個nil。
正常來說,
id myObj = [[NSClassFromString(@"MySpecialClass") alloc] init];
和
id myObj = [[MySpecialClass alloc] init];
是一樣的。但是,如果你的程式中並不存在MySpecialClass這個類,下面的寫法會出錯,而上面的寫法只是返回一個空物件而已。
因此,在某些情況下,可以使用NSClassFromString來進行你不確定的類的初始化。
比如在iPhone中,NSTask可能就會出現這種情況,所以在你需要使用NSTask時,最好使用:
[[NSClassFromString(@"NSTask") .....]]
而不要直接使用[NSTask ...]這種寫法。
NSClassFromString的好處是:
1 弱化連線,因此並不會把沒有的Framework也link到程式中。
2 不需要使用import,因為類是動態載入的,只要存在就可以載入。因此如果你的toolchain中沒有某個類的標頭檔案定義,而你確信這個類是可以用的,那麼也可以用這種方法。
同樣的,還可以透過一個方法名字來得到一個Selector,然後就可以動態的呼叫這個Selector了,在Obj-c裡面,一切都是動態的。
類似的函式如下:
NSClassFromString
NSGetSizeAndAlignment
NSLog
NSLogv
NSSelectorFromString
NSStringFromClass
NSStringFromSelector