iOS:Block寫遞迴

來源:互聯網
上載者:User

標籤:

首先來一個 oc 的遞迴: 

 

- (int)sum:(int)num {    if (num == 0) {        return num;    }    return num + [self sum:num - 1];}

 

寫遞迴演算法只需要記住兩點即可:

 

1. 有一個明確的出口

2. 不滿足條件出口時,自己調用自己

 

按照以上思路用 block 改寫一下:

static int (^sumBlock)(int) = ^ (int num) {    if (num == 0) {        return num;    }    return num + sumBlock(num - 1);}; 

 

 

注意,要做到自己調用自己,需要能夠準確的在記憶體中找到 `block` 的函數入口,因此需要使用 `static` 修飾符號,其他就沒啥了

 

另外,面試中如果被問到,一定要說下:

 

1. 每調用一次自己,系統都會開闢一個棧楨記錄臨時變數和參數

2. 遞迴次數過多,會出現棧溢出錯誤

3. 移動開發中不建議使用遞迴演算法,現在主線程棧區只有 512K

 

上面的測試代碼調用 NSLog(@"%d", sumBlock(1024 * 128)); 就會出現棧溢出錯誤

iOS:Block寫遞迴

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.