SPVM::LongList − Dynamic long Arrays
The LongList class in SPVM has methods to manipulate dynamic long arrays.
use LongList;
# Create a long list
my $list = LongList−>new;
my $list = LongList−>new([(long)1, 2, 3]);
# Create a long list with array length
my $list = LongList−>new_len(10);
# Get list length
my $length = $list−>length;
# Push value
$list−>push((long)3);
# Pop value.
my $element = $list−>pop;
# Unshift value.
$list−>unshift((long)3);
# Shift value.
my $element = $list−>shift;
# Set value.
$list−>set(2, (long)3);
# Get value.
my $element = $list−>get(2);
# Insert value
$list−>insert(1, 3);
# Remove value
my $element = $list−>remove(1);
# Convert list to array.
my $array = $list−>to_array;
The "array" stored in a LongList object always starts at index 0.
The elements in the range that is greater than or equal to "length" field and less than "capacity" field are filled with 0.
|
• |
Cloneable |
|||
|
• |
Countable |
"has capacity : virtual ro int;"
The capacity. This is the length of the internally reserved elements to extend the length of the list.
"has length : virtual ro int;"
The length of the list.
"has array : long[];"
The internal array stored in the LongList object.
"static method new : LongList ($array : long[] = undef, $capacity : int = −1);"
Create a new "LongList" object using "new_len".
The passed length to "new_len" is the length of the array. If the array is undef, the length is 0.
The elements of the array are copied to the elements of the the created array.
Examples:
my $list =
LongList−>new;
my $list = LongList−>new([(long)1, 2, 3]);
"static method new_len : LongList ($length : int, $capacity : int = −1);"
Creates a new "LongList" object with $length and $capacity.
If $capacity is less than 0, the capacity is set to the default value.
If $length is greater than $capacity, $capacity is set to $length.
Exceptions:
$length must be greater than or equal to 0. Otherwise an exception is thrown.
"static method new_ref : LongList ($array : long[]);"
Creates a new LongList object, and set "array" field to the array $array, and return the new object.
Exceptions:
The array $array must be defined. Otherwise an exception is thrown.
"method get : long ($index : int);"
Gets the element of the position of $index.
If $index is a netative value, $index is set to "length" plus $index.
Exceptions:
$index must be greater than or equal to 0. Otherwise an exception is thrown.
$index must be less than the length of $list. Otherwise an exception is thrown.
"method insert : void ($index : int, $element : long);"
Inserts an $element to the position of $index.
Exceptions:
$index must be greater than or equal to 0. Otherwise an exception is thrown.
$index must be less than or equal to the length of $list. Otherwise an exception is thrown.
"method pop : long ();"
Removes the last element and return it.
Exceptions:
The length of $list must be greater than 0. Otherwise an exception is thrown.
"method push : void ($element : long);"
Adds an $element after the end of the list.
"method remove : long ($index : int);"
Removes the element at the position of $index and return it.
Exceptions:
$index must be greater than or equal to 0. Otherwise an exception is thrown.
$index must be less than the length of $list. Otherwise an exception is thrown.
"method replace : void ($offset : int, $remove_length : int, $replace : long[] = undef);"
Same as "splice" method, but the return vlaue is not returned.
Exceptions:
Exceptions thrown by "splice" method could be thrown.
"method splice : long[] ($offset : int, $remove_length : int, $replace : long[] = undef);"
Replaces the elements of the range specified by $offset and $length with $replace array, and returns removed elements creating a new array.
If $replace is not defined, the replacemnet is not performed.
Exceptions:
$offset must be greater than or equal to 0. Otherwise an exception is thrown.
$remove_length must be greater than or equal to 0. Otherwise an exception is thrown.
$offset + $removing length must be less than or equal to the length of $list. Otherwise an exception is thrown.
"method reserve : void ($new_capacity : int);"
Reserves the elements with $new_capacity.
If $new_capacity is greater than the capacity of the list, the capacity of the list is extended to $new_capacity.
Exceptions:
$new_capacity must be greater than or equal to 0. Otherwise an exception is thrown.
"method resize : void ($new_length : int);"
Resize the list with $new_length.
Exceptions:
$new_length must be greater than or equal to 0. Otherwise an exception is thrown.
"method set : void ($index : int, $element : long);"
Sets $element at the position of $index.
If $index is a netative value, $index is set to "length" plus $index.
Exceptions:
$index must be greater than or equal to 0. Otherwise an exception is thrown.
$index must be less than the length of $list. Otherwise an exception is thrown.
"method shift : long ();"
Removes the first element and return it.
Exceptions:
The length of $list must be greater than 0. Otherwise an exception is thrown.
"method to_array : long[] ();"
Creates a new array with the length of the list and copies all elements of the list into the new array, and returns it.
"method get_array : long[] ();"
Returns the internal "array".
"method unshift : void ($element : long);"
Inserts an $element at the beginning of the list.
"method clone : LongList ();"
Clones this instance and returns it.
"method push_ : void ($elements : long[]);"
Adds the elements $elements after the end of this list.
This method calls "push" method internally.
Exceptions:
The elements $elements must be defined.
Exceptions thrown by "push" method could be thrown.
"method unshift_ : void ($elements : long[]);"
Inserts the elemnets $elements at the beginning of the list.
Exceptions:
The elements $elements must be defined.
Exceptions thrown by "unshift" method could be thrown.
Copyright (c) 2023 Yuki Kimoto
MIT License