Ruby  3.4.0dev (2024-11-05 revision 348a53415339076afc4a02fcd09f3ae36e9c4c61)
Data Fields
RArray Struct Reference

Ruby's array. More...

#include <rarray.h>

Data Fields

struct RBasic basic
 Basic part, including flags and class. More...
 
union {
   struct {
      long   len
 Number of elements of the array. More...
 
      union {
         long   capa
 Capacity of *ptr. More...
 
         const VALUE   shared_root
 Parent of the array. More...
 
      }   aux
 Auxiliary info. More...
 
      const VALUE *   ptr
 Pointer to the C array that holds the elements of the array. More...
 
   }   heap
 Arrays that use separated memory region for elements use this pattern. More...
 
   const VALUE   ary [1]
 Embedded elements. More...
 
as
 Array's specific fields. More...
 

Detailed Description

Ruby's array.

Definition at line 128 of file rarray.h.

Field Documentation

◆ ary

const VALUE RArray::ary[1]

Embedded elements.

When an array is short enough, it uses this area to store its elements. In this case the length is encoded into the flags.

Definition at line 188 of file rarray.h.

Referenced by rb_ary_aref(), rb_ary_cat(), rb_ary_dup(), rb_ary_each(), rb_ary_entry(), rb_ary_free(), rb_ary_freeze(), rb_ary_hidden_new(), rb_ary_join(), rb_ary_modify(), rb_ary_new_from_args(), rb_ary_pop(), rb_ary_push(), rb_ary_resize(), rb_ary_resurrect(), rb_ary_reverse(), rb_ary_rotate(), rb_ary_shift(), rb_ary_store(), rb_ary_subseq(), rb_ary_to_s(), and rb_ary_unshift().

◆ 

union { ... } RArray::as

Array's specific fields.

◆ 

union { ... } RArray::aux

Auxiliary info.

◆ basic

struct RBasic RArray::basic

Basic part, including flags and class.

Definition at line 386 of file rarray.h.

◆ capa

long RArray::capa

Capacity of *ptr.

A continuous memory region of at least capa elements is expected to exist at *ptr. This can be bigger than len.

Definition at line 153 of file rarray.h.

◆ 

struct { ... } RArray::heap

Arrays that use separated memory region for elements use this pattern.

◆ len

long RArray::len

Number of elements of the array.

Definition at line 143 of file rarray.h.

◆ ptr

const VALUE* RArray::ptr

Pointer to the C array that holds the elements of the array.

In the old days each array had dedicated memory regions. That is no longer true today, but there still are arrays of such properties. This field could be used to point such things.

Definition at line 175 of file rarray.h.

◆ shared_root

const VALUE RArray::shared_root

Parent of the array.

Nowadays arrays can share their backend memory regions each other, constructing gigantic nest of objects. This situation is called "shared", and this is the field to control such properties.

Definition at line 166 of file rarray.h.


The documentation for this struct was generated from the following file: