.. _glossary-n: ============================= Memory Management Glossary: N ============================= .. include:: alphabet.txt .. glossary:: nailing .. see:: :term:`pinning`. natural alignment Natural alignment is an :term:`alignment` constraint such that all :term:`objects` must be aligned to an address that is a multiple of their size. Natural alignment is not usually required for objects larger than a :term:`word` or :term:`grain`, which usually only need to be word- or grain-aligned. .. seealso:: :term:`alignment`, :term:`padding`. .. mps:specific:: The MPS platform interface defines the :term:`C` preprocessor macro :c:macro:`MPS_PF_ALIGN` to be the natural alignment of the platform. nepotism In :term:`generational garbage collection` nepotism is the tendency for :term:`dead` :term:`objects` in old :term:`generations` to preserve younger dead objects that are referenced by them. In other words, dead parents can cause their children to get promoted. This happens when an object gets :term:`promoted ` to an old generation and dies there, but does not get :term:`reclaimed` because the generation it is in does not get considered for garbage collection very often. The old object might refer to objects in younger generations that are also dead; until the old object is reclaimed the younger objects will be preserved by virtue of the :term:`reference` from the older, assumed alive, object. This is a form of :term:`floating garbage` introduced by partitioning the objects into generations. next fit A variant of the :term:`first fit` :term:`allocation mechanism` that uses a *roving pointer* on a circular :term:`free block chain`. The pointer is advanced along the chain when searching for a fit. Thus each allocation begins looking where the previous one finished. The rationale is to avoid creating an accumulation of small fragments at the head of the free block chain, which would have to be examined on every allocation. There are several variants, according to the order of blocks on the free block chain. The most common variant is address-ordered next fit. This has a tendency to spread related objects out in memory, and also gives quite poor :term:`locality ` for the allocator (as the roving pointer rotates around memory, the free blocks touched are those least-recently used). .. seealso:: :term:`allocation mechanism`, :term:`first fit`. .. bibref:: :ref:`Wilson et al. (1995) `. new space newspace .. see:: :term:`tospace`. node In a :term:`graph`, a node is a representation of an :term:`object` at the junction of zero or more :term:`edges`. .. opposite:: :term:`edge`. .. seealso:: :term:`graph`. non-moving garbage collector non-moving memory manager A memory manager is said to be *non-moving* if :term:`allocated` :term:`objects` do not move during their lifetimes. Non-moving memory management techniques include :term:`mark-sweep` collection, :term:`reference counting`, and most kinds of :term:`manual memory management`. .. opposite:: :term:`moving garbage collector`. nursery generation .. see:: :term:`nursery space`. nursery space .. aka:: *nursery generation*. In :term:`generational garbage collection`, the *nursery generation* or *space* is the area used for new :term:`allocation `. The size of the nursery space must be chosen carefully. Often it is related to the size of :term:`physical memory (1)`. .. mps:specific:: By default, a garbage-collected :term:`pool` allocates into the first :term:`generation` in its :term:`generation chain`, but this can be altered by setting the :c:macro:`MPS_KEY_GEN` :term:`keyword argument` when calling :c:func:`mps_pool_create_k`.