JSPM

  • Created
  • Published
  • Downloads 424311
  • Score
    100M100P100Q177628F
  • License MIT

Sizeof of a JavaScript object in bytes

Package Exports

  • object-sizeof

This package does not declare an exports field, so the exports above have been automatically detected and optimized by JSPM instead. If any package subpath is missing, it is recommended to post an issue to the original package (object-sizeof) to support the "exports" field. If that is not possible, create a JSPM override to customize the exports field for this package.

Readme

object-sizeof

Build Status Dependency Status

NPM

Get size of a JavaScript object in bytes

JavaScript does not provide sizeof (like in C), and programmer does not need to care about memory allocation/deallocation.

However, according to ECMAScript Language Specification, each String value is represented by 16-bit unsigned integer, Number uses the double-precision 64-bit format IEEE 754 values including the special "Not-a-Number" (NaN) values, positive infinity, and negative infinity.

Having this knowledge, the module calculates how much memory object will allocate.

Limitations

Please note, that V8 which compiles the JavaScript into native machine code, is not taken into account, as the compiled code is additionally heavily optimized.

Installation

npm install object-sizeof

Examples

  var sizeof = require('object-sizeof');
  
  // 2B per character, 6 chars total => 12B
  console.log(sizeof({abc: 'def'}));
  
  // 8B for Number => 8B
  console.log(sizeof(12345);
  
  var param = { 
    'a': 1, 
    'b': 2, 
    'c': {
      'd': 4
    }
  };
  // 4 one two-bytes char strings and 3 eighth-bytes numbers => 32B
  console.log(sizeof(param));

Licence

The MIT License (MIT)

Copyright (c) 2014, Andrei Karpushonak aka @miktam, http://avrora.io