Get the size (in bytes) of an object on the heap

前端 未结 2 515
萌比男神i
萌比男神i 2020-12-05 15:34

I\'m aware you can use MemoryLayout.size to get the size of a type T.

For example: MemoryLayout.size // 4

相关标签:
2条回答
  • 2020-12-05 16:11

    One option on Apple platforms, because Swift classes are currently built on top of Objective-C classes there, would be to use the Obj-C runtime function class_getInstanceSize, which gives you the size in bytes of an instance of the class, including any padding.

    // on a 64-bit machine (1 word == 8 bytes)...
    
    import Foundation
    
    class C {}
    print(class_getInstanceSize(C.self)) // 16 bytes metadata for empty class 
                                         // (isa ptr + ref count)
    
    class C1 {
        var i = 0
        var i1 = 0
        var b = false
    }
    
    print(class_getInstanceSize(C1.self)) // 40 bytes
    // (16 metadata + 24 ivars, 8 for i + 8 for i1 + 1 for b + 7 padding)
    
    0 讨论(0)
  • 2020-12-05 16:12

    As far as I tested in the Playground, this function returns seemingly significant value:

    func heapSize(_ obj: AnyObject) -> Int {
        return malloc_size(Unmanaged.passRetained(obj).toOpaque())
    }
    
    class MyClass {
        //no properites...
    }
    let myObj = MyClass()
    print(heapSize(myObj)) //->16
    
    class MyBiggerClass {
        var str: String?
        var i: Int = 0
    }
    let myBiggerObj = MyBiggerClass()
    print(heapSize(myBiggerObj)) //->64
    

    Seems the current Swift runtime uses malloc-compatible something to allocate memory in heap. (malloc gives some padding to fit the allocated size to power to 2, when allocating small chunks. So, the actually needed size for the instance may be smaller than the malloc_size.)

    I haven't tested how far this would work, and undocumented behaviours just depending on the current implementation would change at any time in the future without any notifications.

    But if you actually know that, this can be a good starting point for exploration.

    0 讨论(0)
提交回复
热议问题