相關面試題1

1、UIView 和 CALayer 的區別
1. UIView可以響應事件,Layer不可以,因為UIView繼承自UIResponder類,而 CALayer直接繼承 NSObject
2. UIView自身不能設置圓角等效果, 而CALayer可設置邊框, 圓角, 陰影和變換變形等
3. UIView主要是對顯示內容的管理, 而CALayer主要是顯示內容的繪制
4. CALayer默認修改屬性支持隱式動畫
2、RunLoop和多線程的關系
1. 每條線程都有唯一的一個 RunLoop 對象與之對應的
2. 主線程的 RunLoop 是自動創建并啟動,UIApplicationMain()函數,這個方法會為main thread設置一個NSRunLoop對象。
   這就解釋了:為什么我們的應用可以在無人操作的時候休息,需要讓它干活的時候又能立馬響應。
3. 子線程的 RunLoop 需要手動創建,run loop默認是沒有啟動的,如果你需要更多的線程交互則可以手動配置和啟動
4. 在任何一個 Cocoa 程序的線程中,都可以通過以下代碼來獲取到當前線程的 run loop 。
   NSRunLoop *runloop = [NSRunLoop currentRunLoop];
3、__block 和 __weak 的區別
1. __weak 本身是可以避免循環引用的問題的,但是其會導致外部對象釋放了之后,block 內部也訪問不到這個對象的問題,
我們可以通過在 block 內部聲明一個 __strong 的變量來指向 weakObj,使外部對象既能在 block 內部保持住,又能避免循環引用的問題。
2. __block 本身無法避免循環引用的問題,但是我們可以通過在 block 內部手動把 blockObj 賦值為 nil 的方式來避免循環引用的問題。
3. __block 修飾的變量在 block 內外都是唯一的,要注意這個特性可能帶來的隱患。
4. __block在ARC環境下,無法避免循環引用的問題。在非arc下,__block是可以避免引用循環的

4、Runtime 怎樣實現 weak 屬性的
通過關聯屬性來實現
//聲明一個weak屬性,以delegate為例
@property (nonatomic, weak) id delegate;
//重寫getter、setter方法
- (id)delegate {
      return objc_getAssociatedObject(self, @"__delegate__key"); 
}
//指定使用OBJC_ASSOCIATION_ASSIGN
- (void)setDelegate:(id)delegate {
    objc_setAssociatedObject(self, @"__delegate__key", delegate, OBJC_ASSOCIATION_ASSIGN);
}
5、筆試題:
寫出打印結果,并說明為什么
//全民快樂筆試題
- (void)gcdTest {
    dispatch_after(dispatch_time(DISPATCH_TIME_NOW, (int64_t)(0 * NSEC_PER_SEC)), dispatch_get_main_queue(), ^{
        NSLog(@"4");
    });
    dispatch_async(dispatch_get_main_queue(), ^{
        NSLog(@"5");
    });
    [self performSelector:@selector(test2)];
    [self performSelector:@selector(test3) withObject:nil afterDelay:0];
    dispatch_async(dispatch_get_global_queue(0, 0), ^{
        NSLog(@"6");
    });
    [self test1];
}

- (void)test1 {
    NSLog(@"1");
}
- (void)test2 {
    NSLog(@"2");
}
- (void)test3 {
    NSLog(@"3");
}

(!!!!運行結果是:216453 )

# 解決思路
1. 搞清楚下面兩者區別
 dispatch_async
 dispatch_sync
 
 2.
 dispatch_after(dispatch_time(DISPATCH_TIME_NOW, (int64_t)(0 * NSEC_PER_SEC)), dispatch_get_main_queue(), ^{
 NSLog(@"4");
 });
等價于
 dispatch_async(dispatch_get_main_queue(), ^{
 NSLog(@"4");
 });
 
 3. [self performSelector:@selector(test2)];
 等價于
 [self test2];

 4. 
 [self performSelector:@selector(test3) withObject:nil afterDelay:0];
 等價于
 dispatch_async(dispatch_get_main_queue(), ^{
 [self test3];
 });
 
 5. 要知道在主線程上運行以下兩句話, 這里查文檔好好理解一下吧
 dispatch_async(dispatch_get_main_queue(), ^{
 NSLog(@"A");
 });
 NSLog(@"B");
 打印結果是 BA
 6.
 dispatch_async(dispatch_get_global_queue(0, 0), ^{
 NSLog(@"6");
 });
這個數字出現比較隨機,所以不用太在意
 
 所以上面代碼簡化為,(忽略6)
 dispatch_async(dispatch_get_main_queue(), ^{
 NSLog(@"4");
 });
 dispatch_async(dispatch_get_main_queue(), ^{
 NSLog(@"5");
 });
 
 [self test2];
 
 dispatch_async(dispatch_get_main_queue(), ^{
 [self test3];
 });
 
 [self test1];

 結果: 21453 (6出現的位置比較隨機)
?著作權歸作者所有,轉載或內容合作請聯系作者
平臺聲明:文章內容(如有圖片或視頻亦包括在內)由作者上傳并發布,文章內容僅代表作者本人觀點,簡書系信息發布平臺,僅提供信息存儲服務。

推薦閱讀更多精彩內容

  • *面試心聲:其實這些題本人都沒怎么背,但是在上海 兩周半 面了大約10家 收到差不多3個offer,總結起來就是把...
    Dove_iOS閱讀 27,205評論 30 471
  • ? 深拷貝同淺拷貝的區別:淺拷貝是指針拷貝,對一個對象進行淺拷貝,相當于對指向對象的指針進行復制,產生一個新的指向...
    WSGNSLog閱讀 1,284評論 0 1
  • 1. 父類實現深拷貝時,子類如何實現深度拷貝。父類沒有實現深拷貝時,子類如何實現深度拷貝。 1.1 深拷貝同淺拷貝...
    iYeso閱讀 1,906評論 0 13
  • 把網上的一些結合自己面試時遇到的面試題總結了一下,以后有新的還會再加進來。 1. OC 的理解與特性 OC 作為一...
    AlaricMurray閱讀 2,592評論 0 20
  • 1,NSObject中description屬性的意義,它可以重寫嗎?答案:每當 NSLog(@"")函數中出現 ...
    eightzg閱讀 4,185評論 2 19