10

オブジェクトが使用するメモリを計算したい。sys.getsizeof素晴らしいですが、浅いです (たとえば、リストで呼び出された場合、リストの要素によって使用されるメモリは含まれません)。

の一般的な「深い」バージョンを書きたいと思いsys.getsizeofます。「深い」の定義にはあいまいさがあることは理解しています。が続く定義copy.deepcopyに完全に満足しています。

これが私の最初の試みです:

def get_deep_sizeof(x, level=0, processed=None):
    if processed is None:
        # we're here only if this function is called by client code, not recursively
        processed = set()
    processed.add(id(x))
    mem = sys.getsizeof(x)
    if isinstance(x, collections.Iterable) and not isinstance(x, str):
        for xx in x:
            if id(xx) in processed:
                continue
            mem += get_deep_sizeof(xx, level+1, processed)
            if isinstance(x, dict):
                mem += get_deep_sizeof(x[xx], level+1, processed)
    return mem

2 つの既知の問題と、不明な数の未知の問題があります。

  • リンクされたすべてのオブジェクトをキャプチャする方法で汎用コンテナーをトラバースする方法がわかりません。したがって、 を使用して反復しin、辞書の大文字と小文字をハードコーディングしました (キーだけでなく、値を含めるため)。明らかに、これは辞書などの他のクラスでは機能しません。
  • str(反復可能ですが、他のオブジェクトへのリンクはありません)の除外をハードコーディングする必要がありました。繰り返しますが、そのようなオブジェクトがさらにある場合、これは壊れます。

を使用するinのは良い考えではないと思いますが、他に何をすべきかわかりません。

4

1 に答える 1

12

私は、Pymplerがすでにこの点であなたを打ち負かしていると思います.

ドキュメントから:

>>> from pympler.asizeof import asizeof
>>> obj = [1, 2, (3, 4), 'text']
>>> asizeof(obj)
176

ソースコードはここにあります。

于 2013-01-08T05:17:00.423 に答える