課程
/移動開發
/iOS
/玩兒轉Swift
這塊的值為什么可以保存下來,函數調用,函數變量是無法保存的,每次調用都會重新在棧上開辟空間,然后賦值使用,而閉包跟函數具有相同的功能,不同的是它的變量是從外界傳入的,難道它實在靜態代碼段被生成的嗎?
2014-12-04
源自:玩兒轉Swift 8-4
正在回答
javascript高級開發一本書也有說到這個問題,,語言之間好多都相同
你的意思是說,引用計數的機制來標記內存使用情況,以此來決定是否進行內存回收?
那你是說這個函數調用的過程是在堆上建立的嗎?
忽然想了一下,可以在調用calcTotalMiles的時候打印一下當前變量Total的值,測試一下。
因為之前沒接觸過ios產品開發,所以對它的內存結構但還是不是很明白(是否在??臻g分配內存)。寫了下面一段代碼,希望給個解釋,另外,有沒有像GDB之類的比較給力的Debug工具推薦一下,謝謝
func calcTotalMile(todayMiles:Int) -> () -> Int {
? ? var totalMiles: Int = 0
? ? println("in calcTotalMile: tatalMiles: \( totalMiles )")
? ? return {
? ? ? ? println("in closure: totalMiles: \(totalMiles)")
? ? ? ? totalMiles += todayMiles
? ? ? ? return totalMiles
? ? }
}
var dailyTowMiles = calcTotalMile(2)
dailyTowMiles()
var dailyThreeMails = calcTotalMile(3)
dailyThreeMails()
這是一個很深入的話題。我正在策劃后續做swift的高級課程時或許會涉及。
這里的關鍵是:calcTotalMiles返回了一個函數,這個函數以閉包的形式返回,我們沒有給他起名,這里姑且叫他resultFunction。要注意,這個resultFunction和calcTotalMiles不是一個東西,resultFunction是calcTotalMiles的一個結果!
仔細看這個resultFunction函數體內,涉及的兩個變量:totalMiles和todayMiles,都沒有在resultFunction里定義。那resultFunction是怎么拿到這個值的呢?這個過程是swift使用一種稱為Capturing Values的方式感知到的。與此同時,一點兒沒有錯,這將產生內存方面的問題。在這里,你可以理解成,我們給calcTotalMiles傳入一個參數,返回了一個函數resultFunction,之后執行calcTotalMiles所使用的??臻g并沒有被釋放,因為產生的resultFunction還在使用(或者是擁有)調用者calcTotalMiles的內容。
那么現在問題來了:什么時候calcTotalMiles的空間會被真正釋放?在這個例子里,swift的ARC(Auto Reference Counting)機制會幫我們自動處理。我們不需要處理內存的問題。但是,這樣的一種機制確實會產生循環引用的問題。這就是我說的,我策劃在后續介紹的swift高級課程里要涉及的內存管理相關內容:。
舉報
這套教程比任何的Swift中文教程深入,并且演示示例更豐富
2 回答驗證閉包是引用類型時舉例的疑問
2 回答高階函數、closure閉包、curry柯里化
2 回答totalMiles在閉包中被解析為靜態變量么還是全局變量,為什么每次調用func都會自動添加
3 回答請問下面報錯如何解決
1 回答貌似substringWithRange 現在是閉區間了
Copyright ? 2025 imooc.com All Rights Reserved | 京ICP備12003892號-11 京公網安備11010802030151號
購課補貼聯系客服咨詢優惠詳情
慕課網APP您的移動學習伙伴
掃描二維碼關注慕課網微信公眾號
2014-12-17
javascript高級開發一本書也有說到這個問題,,語言之間好多都相同
2014-12-04
你的意思是說,引用計數的機制來標記內存使用情況,以此來決定是否進行內存回收?
那你是說這個函數調用的過程是在堆上建立的嗎?
忽然想了一下,可以在調用calcTotalMiles的時候打印一下當前變量Total的值,測試一下。
因為之前沒接觸過ios產品開發,所以對它的內存結構但還是不是很明白(是否在??臻g分配內存)。寫了下面一段代碼,希望給個解釋,另外,有沒有像GDB之類的比較給力的Debug工具推薦一下,謝謝
func calcTotalMile(todayMiles:Int) -> () -> Int {
? ? var totalMiles: Int = 0
? ? println("in calcTotalMile: tatalMiles: \( totalMiles )")
? ? return {
? ? ? ? println("in closure: totalMiles: \(totalMiles)")
? ? ? ? totalMiles += todayMiles
? ? ? ? return totalMiles
? ? }
}
var dailyTowMiles = calcTotalMile(2)
dailyTowMiles()
dailyTowMiles()
var dailyThreeMails = calcTotalMile(3)
dailyThreeMails()
dailyThreeMails()
dailyTowMiles()
2014-12-04
這是一個很深入的話題。我正在策劃后續做swift的高級課程時或許會涉及。
這里的關鍵是:calcTotalMiles返回了一個函數,這個函數以閉包的形式返回,我們沒有給他起名,這里姑且叫他resultFunction。要注意,這個resultFunction和calcTotalMiles不是一個東西,resultFunction是calcTotalMiles的一個結果!
仔細看這個resultFunction函數體內,涉及的兩個變量:totalMiles和todayMiles,都沒有在resultFunction里定義。那resultFunction是怎么拿到這個值的呢?這個過程是swift使用一種稱為Capturing Values的方式感知到的。與此同時,一點兒沒有錯,這將產生內存方面的問題。在這里,你可以理解成,我們給calcTotalMiles傳入一個參數,返回了一個函數resultFunction,之后執行calcTotalMiles所使用的??臻g并沒有被釋放,因為產生的resultFunction還在使用(或者是擁有)調用者calcTotalMiles的內容。
那么現在問題來了:什么時候calcTotalMiles的空間會被真正釋放?在這個例子里,swift的ARC(Auto Reference Counting)機制會幫我們自動處理。我們不需要處理內存的問題。但是,這樣的一種機制確實會產生循環引用的問題。這就是我說的,我策劃在后續介紹的swift高級課程里要涉及的內存管理相關內容:。