If you have Java basic students, you can review the “Talk about Java data structure again – analysis of the underlying implementation and application notes” : Java memory is divided into two types: one is stack memory, the other is heap memory. Basic types (int, short, long, byte, float, double, Boolean, char) in the stack area allocated space, all objects on the Heap (Heap) distribution in space. Let’s talk about JavaScript along those lines.
The latest ECMAScript standard defines seven data types:
-
6 Primitive types – Basic data types (access by value)
-
Null (data stored in js is stored in binary, if the first three digits are 0, then the object is determined, Null all 0)
-
Undefined
-
Basic wrapper type (automatically created objects of basic wrapper type – non-Boolean,Number, String from the built-in function new, objects that only hold the moment of execution of the code)
-
Number(double precision 64-bit binary format based on IEEE 754 standard — Number, ±Infinity, NaN)
-
String
-
Boolean
-
Symbol (new in ECMAScript 6, instances are unique and immutable)
-
Reference types: Object (including Object/Array/RegExp/Date/null)
Any JavaScript logo, constant, variable and parameter is only one of the types, I/O, NULL, bool, Number, String,symbol, Object or function, as indicated by the return value of the Typeof. The Seven Data Types of JavaScript in Detail
Js basic type data are directly stored in the stack by value (Undefined, Null, Boolean not out of new, numbers and strings), each type of data occupy memory space size is determined, and the system automatically allocated and released. The benefit of this is that the memory can be reclaimed in a timely manner and it is easier to manage the memory space than the heap. Java a total of eight basic data types, namely int, short, long, float, double, Boolean, byte, char (note that is not the basic types of String)
Js reference type data is stored in the heap (objects, arrays, functions, etc., which are copied and new). In fact, it is not quite accurate to say that the address pointer of the reference type is stored in the stack. When we want to access the value of the reference type, we need to get the address pointer of the object from the stack, and then use the address pointer to find the data in the heap. We’ll talk about that later, but first let’s be clear
The memory structure of data, the physical structure, is divided into two types: sequential and chained.
-
Sequential storage structure: data elements are stored in storage units with contiguous addresses, and the logical and physical relationships between the data are consistent. An array is a typical example of a sequential storage structure.
-
Chain storage structure: the data elements are stored in any storage unit in memory, that is, data can be stored in various locations in memory. The addresses of these data in memory can be contiguous or discontiguous. A linked list is a typical example of a sequential storage structure.
Unlike the sequential storage structure, the data elements in the chained storage structure are connected by Pointers. We can use Pointers to find the location of a data element and then perform some operations on the data element.
Both arrays and queues can implement stacks and linked lists.
For example, consider the difference between a sequential storage structure and a chain storage structure:
For example, when you go to the bank to withdraw money, the sequential storage structure is equivalent to all the customers sitting on the chairs in the lobby in the order of first come, first served.
The chain storage structure is equivalent to that, as soon as all the customers arrive at the bank, the lobby manager will give them a number, and then they can sit on any chair (sit freely, do not need to sit in any order), just wait for the staff to announce the call number.
And the number in each customer’s hand is the equivalent of a pointer, the current pointer to the next storage space, so that all discontinuous space can be sequentially and linearly connected together.
What is a heap and stack?
The principles of stack handling are similar across languages.
-
The heap is dynamically allocated memory, which varies in size and is not automatically freed
-
The stack automatically allocates a relatively fixed size of memory space and is automatically released by the system. Stack first in first out (LIFO), queue first in first out (FIFO).
-
An array data structure is a data structure composed of a collection of elements of the same type, allocated to a contiguous block of memory for storage. The index of the element can be used to calculate the corresponding storage address of the element. Arrays are easy to address and difficult to insert and delete, while lists are easy to add and delete and difficult to find. Stacks can be implemented as arrays or lists.
-
A set represents a distinct set of elements (elements that do not repeat).
-
Dictionaries store pairs of keys and values, where key names are used to query specific elements.
There are only a few classic data structures: list, stack, queue, linkedList, dictionary, hash, set, tree, and graph……
JavaScript data structures
Provided by ES5: Array and Object
Es6 built-in: Set map, Weakset WeakMap (strong reference, weak reference, set and map data structure,)
Es None: Dictionary list LinkedList DoublelinkedList Quene Hash Stack
In JavaScript, data and code, no matter how complex, can be organized into objects in the form of Objects
C/C++/Java, etc. (C is the mother of all things, C does not have such a data type), must be implemented in some way, how on earth to implement it? This problem is the first to see “from Chrome source code to see the implementation of JS Object”, and then review the “JavaScript Object properties underlying principle”, in accordance with the series of consistent style
Objects are mostly Dictionary: {a: ‘foo’, b: ‘bar’}
-
The storage structure can be an array or a HashMap
-
Has additional auxiliary information (stored in the descriptor array) — the array index property
Array index attribute (element):
For example, the array [‘foo’, ‘bar’] has two array index properties: 0, with the value ‘foo’; 1, the value is ‘bar’.
-
The storage structure is usually a simple array structure. In some cases, however, you switch to a Hash structure to save memory.
-
You can use keys to infer their position in the property array
Array indexed properties and named properties are stored in two separate data structures:
The root superclass of all data types in V8 is Object. Object is derived from HeapObject, which provides basic storage functions. JSReceiver is used for prototype lookup, and JSObject is Object in JS. Array/Function/Date inherit from JSObject. The FixedArray on the left is where the actual data is stored. Javascript Object implementation from Chrome source code
Before creating a JSObject, we serialize the text properties of the Object we read to constant_properties, as follows:
var data = {
name: "yin",
age: 18,
"-school-": "high school"
};Copy the code
Will be sequenced as:
. /.. V8 / SRC/runtime/http://runtime-literals.cc / 72 constant_properties: 0 xdf9ed2aed19: [FixedArray] - length: 6 [0] : 0x1b5ec69833d1 [1]: 0xdf9ed2aec51 [2]: 0xdf9ed2aec71 [3]: 18 [4]: 0xdf9ed2aec91 [5]: 0xdf9ed2aecb1Copy the code
It’s a FixedArray, and FixedArray is an array-like class implemented by V8 that represents a contiguous chunk of memory.
So how do you restore this contiguous memory to a JSON structured object?
FixedArray is primarily used to indicate where the data is stored, with a Map above it that represents the structure of the data. The Map here doesn’t mean hash, it’s more like a Map, to manipulate the memory represented by the FixedArray, and you can quickly get the key-value by index with descriptors
for (int index = 0; index get(index + 0));
Handle value(constant_properties->get(index + 1));
Handle name = Handle::cast(key);
JSObject::SetOwnPropertyIgnoreAttributes(boilerplate, name, value, NONE);
}Copy the code
// Most object types in the V8 JavaScript are described in this file.
//
// Inheritance hierarchy:
// - Object
// - Smi (immediate small integer)
// - HeapObject (superclass for everything allocated in the heap)
// - JSReceiver (suitable forproperty access) // - JSObject // - JSArray // - JSArrayBuffer // - JSArrayBufferView // - JSTypedArray // - JSDataView // - JSBoundFunction // - JSCollection // - JSSet // - JSMap // - JSStringIterator // - JSSetIterator // - JSMapIterator // - JSWeakCollection // - JSWeakMap // - JSWeakSet // - JSRegExp // - JSFunction // - JSGeneratorObject // - JSGlobalObject // - JSGlobalProxy // - JSValue // - JSDate // - JSMessageObject // - JSModuleNamespace // - JSV8BreakIterator // If V8_INTL_SUPPORT enabled. // - JSCollator // If V8_INTL_SUPPORT enabled. // - JSDateTimeFormat // If V8_INTL_SUPPORT enabled. // - JSListFormat // If V8_INTL_SUPPORT enabled. // - JSLocale // If V8_INTL_SUPPORT enabled. // - JSNumberFormat // If V8_INTL_SUPPORT enabled. // - JSPluralRules // If V8_INTL_SUPPORT enabled. // - JSRelativeTimeFormat // If V8_INTL_SUPPORT enabled. // - JSSegmentIterator // If V8_INTL_SUPPORT enabled. // - JSSegmenter // If V8_INTL_SUPPORT enabled. // - WasmExceptionObject // - WasmGlobalObject // - WasmInstanceObject // - WasmMemoryObject // - WasmModuleObject // - WasmTableObject // - JSProxy // - FixedArrayBase // - ByteArray // - BytecodeArray // - FixedArray // - FrameArray // - HashTable // - Dictionary // - StringTable // - StringSet // - CompilationCacheTable // - MapCache // - OrderedHashTable // - OrderedHashSet // - OrderedHashMap // - FeedbackMetadata // - TemplateList // - TransitionArray // - ScopeInfo // - ModuleInfo // - ScriptContextTable // - ClosureFeedbackCellArray // - FixedDoubleArray // - Name // - String // - SeqString // - SeqOneByteString // - SeqTwoByteString // - SlicedString // - ConsString // - ThinString // - ExternalString // - ExternalOneByteString // - ExternalTwoByteString // - InternalizedString // - SeqInternalizedString // - SeqOneByteInternalizedString // - SeqTwoByteInternalizedString // - ConsInternalizedString // - ExternalInternalizedString // - ExternalOneByteInternalizedString // - ExternalTwoByteInternalizedString // - Symbol // - Context // - NativeContext // - HeapNumber // - BigInt // - Cell // - DescriptorArray // - PropertyCell // - PropertyArray // - Code // - AbstractCode, a wrapper around Code or BytecodeArray // - Map // - Oddball // - Foreign // - SmallOrderedHashTable // - SmallOrderedHashMap // - SmallOrderedHashSet // - SharedFunctionInfo // - Struct // - AccessorInfo // - AsmWasmData // - PromiseReaction // - PromiseCapability // - AccessorPair // - AccessCheckInfo // - InterceptorInfo // - CallHandlerInfo // - EnumCache // - TemplateInfo // - FunctionTemplateInfo // - ObjectTemplateInfo // - Script // - DebugInfo // - BreakPoint // - BreakPointInfo // - StackFrameInfo // - StackTraceFrame // - SourcePositionTableWithFrameCache // - CodeCache // - PrototypeInfo // - Microtask // - CallbackTask // - CallableTask // - PromiseReactionJobTask // - PromiseFulfillReactionJobTask // - PromiseRejectReactionJobTask // - PromiseResolveThenableJobTask // - Module // - ModuleInfoEntry // - FeedbackCell // - FeedbackVector // - PreparseData // - UncompiledData // - UncompiledDataWithoutPreparseData // - UncompiledDataWithPreparseData // // Formats of Object::ptr_: // Smi: [31 bit signed int] 0 // HeapObject: [32 bit direct pointer] (4 byte aligned) | 01Copy the code
Each heap object has a map to record information about it.
// All heap objects have a Map that describes their structure.
// A Map contains information about:
// - Size information about the object
// - How to iterate over an object (for garbage collection)
//
// Map layout:
// +---------------+---------------------------------------------+
// | _ Type _ | _ Description _ |
// +---------------+---------------------------------------------+
// | TaggedPointer | map - Always a pointer to the MetaMap root |
// +---------------+---------------------------------------------+
// | Int | The first int field |
// `---+----------+---------------------------------------------+
// | Byte | [instance_size] |
// +----------+---------------------------------------------+
// | Byte | If Map for a primitive type: |
// | | native context index for constructor fn |
// | | If Map for an Object type: |
// | | inobject properties start offset in words |
// +----------+---------------------------------------------+
// | Byte | [used_or_unused_instance_size_in_words] |
// | | For JSObject in fast mode this byte encodes |
// | | the size of the object that includes only |
// | | the used property fields or the slack size |
// | | inproperties backing store. | // +----------+---------------------------------------------+ // | Byte | [visitor_id] | // +----+----------+---------------------------------------------+ // | Int | The second int field | // `---+----------+---------------------------------------------+ // | Short | [instance_type] | // +----------+---------------------------------------------+ // | Byte | [bit_field] | // | | - has_non_instance_prototype (bit 0) | // | | - is_callable (bit 1) | // | | - has_named_interceptor (bit 2) | // | | - has_indexed_interceptor (bit 3) | // | | - is_undetectable (bit 4) | // | | - is_access_check_needed (bit 5) | // | | - is_constructor (bit 6) | // | | - has_prototype_slot (bit 7) | // +----------+---------------------------------------------+ // | Byte | [bit_field2] | // | | - is_extensible (bit 0) | // | | - is_prototype_map (bit 1) | // | | - is_in_retained_map_list (bit 2) | // | | - elements_kind (bits 3.. 7) | // +----+----------+---------------------------------------------+ // | Int | [bit_field3] | // | | - enum_length (bit 0.. 9) | // | | - number_of_own_descriptors (bit 10.. 19) | // | | - is_dictionary_map (bit 20) | // | | - owns_descriptors (bit 21) | // | | - has_hidden_prototype (bit 22) | // | | - is_deprecated (bit 23) | // | | - is_unstable (bit 24) | // | | - is_migration_target (bit 25) | // | | - is_immutable_proto (bit 26) | // | | - new_target_is_base (bit 27) | // | | - may_have_interesting_symbols (bit 28) | // | | - construction_counter (bit 29.. 31) | // | | | // +*************************************************************+ // | Int | On systems with 64bit pointer types, there | // | | is an unused 32bits after bit_field3 | // +*************************************************************+ // | TaggedPointer | [prototype] | // +---------------+---------------------------------------------+ // | TaggedPointer | [constructor_or_backpointer] | // +---------------+---------------------------------------------+ // | TaggedPointer | If Map is a prototype map: | // | | [prototype_info] | // | | Else: | // | | [raw_transitions] | // +---------------+---------------------------------------------+ // | TaggedPointer | [instance_descriptors] | // +*************************************************************+ // ! TaggedPointer ! [layout_descriptors] ! / /! ! Field is only presentif compile-time flag !
// ! ! FLAG_unbox_double_fields is enabled !
// ! ! (basically on 64 bit architectures) !
// +*************************************************************+
// | TaggedPointer | [dependent_code] |
// +---------------+---------------------------------------------+Copy the code
Reference article:
Basic data structure of image interpretation at https://blog.csdn.net/qq_23864697/article/details/79727950
Data structure and algorithm, graph adjacency list (thought and implementation) www.cnblogs.com/cmusketeer/p/10331450.html
Who says the front end doesn’t need to learn data structures? We talk a js https://www.jianshu.com/p/5e0e8d183102 data structure
JavaScript: the new keyword to create objects of the underlying principles of https://www.jianshu.com/p/265144a810b7
Data structures and algorithms www.cnblogs.com/wsnb/p/5172…