std.array
| Function Name | Description |
|---|---|
| array | Returns a copy of the input in a newly allocated dynamic array. |
| appender | Returns a new Appender or RefAppender initialized with a given array. |
| assocArray | Returns a newly allocated associative array from a range of key/value tuples. |
| byPair | Construct a range iterating over an associative array by key/value tuples. |
| insertInPlace | Inserts into an existing array at a given position. |
| join | Concatenates a range of ranges into one array. |
| minimallyInitializedArray | Returns a new array of type T. |
| replace | Returns a new array with all occurrences of a certain subrange replaced. |
| replaceFirst | Returns a new array with the first occurrence of a certain subrange replaced. |
| replaceInPlace | Replaces all occurrences of a certain subrange and puts the result into a given array. |
| replaceInto | Replaces all occurrences of a certain subrange and puts the result into an output range. |
| replaceLast | Returns a new array with the last occurrence of a certain subrange replaced. |
| replaceSlice | Returns a new array with a given slice replaced. |
| replicate | Creates a new array out of several copies of an input array or range. |
| sameHead | Checks if the initial segments of two arrays refer to the same place in memory. |
| sameTail | Checks if the final segments of two arrays refer to the same place in memory. |
| split | Eagerly split a range or string into an array. |
| uninitializedArray | Returns a new array of type T without initializing its elements. |
Source: std/array.d
- ForeachType!Range[]
array(Range)(Ranger)
if (isIterable!Range && !isNarrowString!Range && !isInfinite!Range); - Allocates an
arrayand initializes it with copies of the elements of ranger.Narrow strings are handled as a special case in an overload.Parameters:Range rrange (or aggregate with opApply function) whose elements are copied into the allocated arrayReturns:allocated and initializedarrayExamples:auto a = array([1, 2, 3, 4, 5][]); writeln(a); // [1, 2, 3, 4, 5]
- @trusted ElementType!String[]
array(String)(scope Stringstr)
if (isNarrowString!String); - Convert a narrow string to an
arraytype that fully supports random access. This is handled as a special case and always returns anarrayof dcharParameters:String strisNarrowString to be converted to an arrayof dcharReturns:a dchar[], const(dchar)[], or immutable(dchar)[] depending on the constness of the input. - auto
assocArray(Range)(Ranger)
if (isInputRange!Range); - Returns a newly allocated associative array from a range of key/value tuples.Parameters:
Range rAn input range of tuples of keys and values. Returns:A newly allocated associative array out of elements of the input range, which must be a range of tuples (Key, Value). Returns anullassociative array reference when given an empty range.Duplicates: Associative arrays have unique keys. If
rcontains duplicate keys, then the result will contain the value of the last pair for that key inr.See Also:Examples:import std.range; import std.typecons; auto a = assocArray(zip([0, 1, 2], ["a", "b", "c"])); // aka zipMap assert(is(typeof(a) == string[int])); writeln(a); // [0:"a", 1:"b", 2:"c"] auto b = assocArray([ tuple("foo", "bar"), tuple("baz", "quux") ]); assert(is(typeof(b) == string[string])); writeln(b); // ["foo":"bar", "baz":"quux"]
- auto
byPair(Key, Value)(Value[Key]aa); - Construct a range iterating over an associative array by key/value tuples.Parameters:
Value[Key] aaThe associative array to iterate over. Returns:A forward range of Tuple's of key and value pairs from the given associative array.Examples:import std.typecons : tuple, Tuple; import std.algorithm.sorting : sort; auto aa = ["a": 1, "b": 2, "c": 3]; Tuple!(string, int)[] pairs; // Iteration over key/value pairs. foreach (pair; aa.byPair) { pairs ~= pair; } // Iteration order is implementation-dependent, so we should sort it to get // a fixed order. sort(pairs); assert(pairs == [ tuple("a", 1), tuple("b", 2), tuple("c", 3) ]);
- nothrow @system auto
uninitializedArray(T, I...)(Isizes)
if (isDynamicArray!T && allSatisfy!(isIntegral, I) && hasIndirections!(ElementEncodingType!T)); - Returns a new array of type T allocated on the garbage collected heap without initializing its elements. This can be a useful optimization if every element will be immediately initialized. T may be a multidimensional array. In this case
sizesmay be specified for any number of dimensions from 0 to the number in T.uninitializedArrayis nothrow and weakly pure.uninitializedArrayis @system if the uninitialized element type has pointers. - nothrow @trusted auto
uninitializedArray(T, I...)(Isizes)
if (isDynamicArray!T && allSatisfy!(isIntegral, I) && !hasIndirections!(ElementEncodingType!T)); - Examples:
double[] arr = uninitializedArray!(double[])(100); writeln(arr.length); // 100 double[][] matrix = uninitializedArray!(double[][])(42, 31); writeln(matrix.length); // 42 writeln(matrix[0].length); // 31 char*[] ptrs = uninitializedArray!(char*[])(100); writeln(ptrs.length); // 100
- nothrow @trusted auto
minimallyInitializedArray(T, I...)(Isizes)
if (isDynamicArray!T && allSatisfy!(isIntegral, I)); - Returns a new array of type T allocated on the garbage collected heap.Partial initialization is done for types with indirections, for preservation of memory safety. Note that elements will only be initialized to 0, but not necessarily the element type's .init.
minimallyInitializedArrayis nothrow and weakly pure. - void
insertInPlace(T, U...)(ref T[]array, size_tpos, Ustuff)
if (!isSomeString!(T[]) && allSatisfy!(isInputRangeOrConvertible!T, U) && U.length > 0);
voidinsertInPlace(T, U...)(ref T[]array, size_tpos, Ustuff)
if (isSomeString!(T[]) && allSatisfy!(isCharOrStringOrDcharRange, U)); - Inserts
stuff(which must be an input range or any number of implicitly convertible items) inarrayat positionpos.Parameters:T[] arrayThe arraythatstuffwill be inserted into.size_t posThe position in arrayto insert thestuff.U stuffAn input range, or any number of implicitly convertible items to insert into array.Examples:int[] a = [ 1, 2, 3, 4 ]; a.insertInPlace(2, [ 1, 2 ]); writeln(a); // [1, 2, 1, 2, 3, 4] a.insertInPlace(3, 10u, 11); writeln(a); // [1, 2, 1, 10, 11, 2, 3, 4]
- pure nothrow @safe bool
sameHead(T)(in T[]lhs, in T[]rhs); - Returns whether the fronts of
lhsandrhsboth refer to the same place in memory, making one of the arrays a slice of the other which starts at index 0.Examples:auto a = [1, 2, 3, 4, 5]; auto b = a[0 .. 2]; assert(a.sameHead(b));
- pure nothrow @trusted bool
sameTail(T)(in T[]lhs, in T[]rhs); - Returns whether the backs of
lhsandrhsboth refer to the same place in memory, making one of the arrays a slice of the other which end at index $.Examples:auto a = [1, 2, 3, 4, 5]; auto b = a[3..$]; assert(a.sameTail(b));
- ElementEncodingType!S[]
replicate(S)(Ss, size_tn)
if (isDynamicArray!S);
ElementType!S[]replicate(S)(Ss, size_tn)
if (isInputRange!S && !isDynamicArray!S); - Parameters:
S san input range or a dynamic array size_t nnumber of times to repeat sReturns:An array that consists ofsrepeatedntimes. This function allocates, fills, and returns a new array.See Also:For a lazy version, refer to std.range.repeat.Examples:auto a = "abc"; auto s = replicate(a, 3); writeln(s); // "abcabcabc" auto b = [1, 2, 3]; auto c = replicate(b, 3); writeln(c); // [1, 2, 3, 1, 2, 3, 1, 2, 3] auto d = replicate(b, 0); writeln(d); // []
- pure @safe S[]
split(S)(Ss)
if (isSomeString!S); - Eagerly
splitthe stringsinto an array of words, using whitespace as delimiter. Runs of whitespace are merged together (no empty words are produced).@safe, pure and CTFE-able.Parameters:S sthe string to splitSee Also:std.algorithm.iteration.splitter for a version that splits using any separator. std.regex.splitter for a version that splits using a regular expression defined separator.Examples:writeln(split("hello world")); // ["hello", "world"] writeln(split("192.168.0.1", ".")); // ["192", "168", "0", "1"] auto a = split([1, 2, 3, 4, 5, 1, 2, 3, 4, 5], [2, 3]); writeln(a); // [[1], [4, 5, 1], [4, 5]]
- auto
split(Range, Separator)(Rangerange, Separatorsep)
if (isForwardRange!Range && is(typeof(ElementType!Range.init == Separator.init)));
autosplit(Range, Separator)(Rangerange, Separatorsep)
if (isForwardRange!Range && isForwardRange!Separator && is(typeof(ElementType!Range.init == ElementType!Separator.init)));
autosplit(alias isTerminator, Range)(Rangerange)
if (isForwardRange!Range && is(typeof(unaryFun!isTerminator(range.front)))); - Eagerly splits
rangeinto an array, usingsepas the delimiter.The range must be a forward range. The separator can be a value of the same type as the elements inrangeor it can be another forward range.Example: If
rangeis a string,sepcan be a char or another string. The return type will be an array of strings. Ifrangeis an int array,sepcan be an int or another int array. The return type will be an array of int arrays.Parameters:Range rangea forward range. Separator sepa value of the same type as the elements of rangeor another forwardrange.Returns:An array containing the divided parts ofrange.See Also:std.algorithm.iteration.splitter for the lazy version of this function. - ElementEncodingType!(ElementType!RoR)[]
join(RoR, R)(RoRror, scope Rsep)
if (isInputRange!RoR && isInputRange!(Unqual!(ElementType!RoR)) && isInputRange!R && is(Unqual!(ElementType!(ElementType!RoR)) == Unqual!(ElementType!R)));
ElementEncodingType!(ElementType!RoR)[]join(RoR, E)(RoRror, scope Esep)
if (isInputRange!RoR && isInputRange!(Unqual!(ElementType!RoR)) && is(E : ElementType!(ElementType!RoR)));
ElementEncodingType!(ElementType!RoR)[]join(RoR)(RoRror)
if (isInputRange!RoR && isInputRange!(Unqual!(ElementType!RoR))); - Eagerly concatenates all of the ranges in
rortogether (with the GC) into one array usingsepas the separator if present.Parameters:RoR rorAn input range of input ranges R sepAn input range, or a single element, to jointhe ranges onReturns:An array of elementsSee Also:For a lazy version, see std.algorithm.iteration.joinerExamples:writeln(join(["hello", "silly", "world"], " ")); // "hello silly world" writeln(join(["hello", "silly", "world"])); // "hellosillyworld" writeln(join([[1, 2, 3], [4, 5]], [72, 73])); // [1, 2, 3, 72, 73, 4, 5] writeln(join([[1, 2, 3], [4, 5]])); // [1, 2, 3, 4, 5] const string[] arr = ["apple", "banana"]; writeln(arr.join(",")); // "apple,banana" writeln(arr.join()); // "applebanana"
- E[]
replace(E, R1, R2)(E[]subject, R1from, R2to)
if (isDynamicArray!(E[]) && isForwardRange!R1 && isForwardRange!R2 && (hasLength!R2 || isSomeString!R2));
voidreplaceInto(E, Sink, R1, R2)(Sinksink, E[]subject, R1from, R2to)
if (isOutputRange!(Sink, E) && isDynamicArray!(E[]) && isForwardRange!R1 && isForwardRange!R2 && (hasLength!R2 || isSomeString!R2)); - Replace occurrences of
fromwithtoinsubjectin a new array. Ifsinkis defined, then output the new array intosink.Parameters:Sink sinkan output range E[] subjectthe array toscanR1 fromthe item toreplaceR2 tothe item toreplaceall instances offromwithReturns:Ifsinkisn't defined, a new array without changing the contents ofsubject, or the original array if no match is found.Examples:writeln("Hello Wörld".replace("o Wö", "o Wo")); // "Hello World" writeln("Hello Wörld".replace("l", "h")); // "Hehho Wörhd"
Examples:auto arr = [1, 2, 3, 4, 5]; auto from = [2, 3]; auto to = [4, 6]; auto sink = appender!(int[])(); replaceInto(sink, arr, from, to); writeln(sink.data); // [1, 4, 6, 4, 5]
- T[]
replace(T, Range)(T[]subject, size_tfrom, size_tto, Rangestuff)
if (isInputRange!Range && (is(ElementType!Range : T) || isSomeString!(T[]) && is(ElementType!Range : dchar))); - Replaces elements
fromarray with indices rangingfromfrom(inclusive)toto(exclusive) with the rangestuff.Parameters:T[] subjectthe array toscansize_t fromthe starting index size_t tothe ending index Range stuffthe items toreplacein-betweenfromandtoReturns:A new array without changing the contents ofsubject.Examples:auto a = [ 1, 2, 3, 4 ]; auto b = a.replace(1, 3, [ 9, 9, 9 ]); writeln(a); // [1, 2, 3, 4] writeln(b); // [1, 9, 9, 9, 4]
- void
replaceInPlace(T, Range)(ref T[]array, size_tfrom, size_tto, Rangestuff)
if (is(typeof(replace(array,from,to,stuff)))); - Replaces elements
fromarraywith indices rangingfromfrom(inclusive)toto(exclusive) with the rangestuff. Expands or shrinks thearrayas needed.Examples:int[] a = [1, 4, 5]; replaceInPlace(a, 1u, 2u, [2, 3, 4]); writeln(a); // [1, 2, 3, 4, 5] replaceInPlace(a, 1u, 2u, cast(int[])[]); writeln(a); // [1, 3, 4, 5] replaceInPlace(a, 1u, 3u, a[2 .. 4]); writeln(a); // [1, 4, 5, 5]
- E[]
replaceFirst(E, R1, R2)(E[]subject, R1from, R2to)
if (isDynamicArray!(E[]) && isForwardRange!R1 && is(typeof(appender!(E[])().put(from[0..1]))) && isForwardRange!R2 && is(typeof(appender!(E[])().put(to[0..1])))); - Replaces the first occurrence of
fromwithtoinsubject.Parameters:E[] subjectthe array toscanR1 fromthe item toreplaceR2 tothe item toreplacefromwithReturns:A new array without changing the contents ofsubject, or the original array if no match is found.Examples:auto a = [1, 2, 2, 3, 4, 5]; auto b = a.replaceFirst([2], [1337]); writeln(b); // [1, 1337, 2, 3, 4, 5] auto s = "This is a foo foo list"; auto r = s.replaceFirst("foo", "silly"); writeln(r); // "This is a silly foo list"
- E[]
replaceLast(E, R1, R2)(E[]subject, R1from, R2to)
if (isDynamicArray!(E[]) && isForwardRange!R1 && is(typeof(appender!(E[])().put(from[0..1]))) && isForwardRange!R2 && is(typeof(appender!(E[])().put(to[0..1])))); - Replaces the last occurrence of
fromwithtoinsubject.Parameters:E[] subjectthe array toscanR1 fromthe item toreplaceR2 tothe item toreplacefromwithReturns:A new array without changing the contents ofsubject, or the original array if no match is found.Examples:auto a = [1, 2, 2, 3, 4, 5]; auto b = a.replaceLast([2], [1337]); writeln(b); // [1, 2, 1337, 3, 4, 5] auto s = "This is a foo foo list"; auto r = s.replaceLast("foo", "silly"); writeln(r); // "This is a foo silly list"
- inout(T)[]
replaceSlice(T)(inout(T)[]s, in T[]slice, in T[]replacement); - Returns a new array that is
swithslicereplaced byreplacement[].Examples:auto a = [1, 2, 3, 4, 5]; auto b = replaceSlice(a, a[1 .. 4], [0, 0, 0]); writeln(b); // [1, 0, 0, 0, 5]
- struct
Appender(A) if (isDynamicArray!A); - Implements an output range that appends data to an array. This is recommended over array ~= data when appending many elements because it is more efficient.
Appendermaintains its own array metadata locally, so it can avoid global locking for each append where capacity is non-zero.See Also:Examples:auto app = appender!string(); string b = "abcdefg"; foreach (char c; b) app.put(c); writeln(app.data); // "abcdefg" int[] a = [ 1, 2 ]; auto app2 = appender(a); app2.put(3); app2.put([ 4, 5, 6 ]); writeln(app2.data); // [1, 2, 3, 4, 5, 6]
- pure nothrow @trusted this(A
arr); - Constructs an Appender with a given array. Note that this does not copy the data. If the array has a larger capacity as determined by
arr.capacity, it will be used by the appender. After initializing an appender on an array, appending to the original array will reallocate. - pure nothrow @safe void
reserve(size_tnewCapacity); - Reserve at least
newCapacityelements for appending. Note that more elements may be reserved than requested. IfnewCapacity<= capacity, then nothing is done. - const pure nothrow @property @safe size_t
capacity(); - Returns the
capacityof the array (the maximum number of elements the managed array can accommodate before triggering a reallocation). If any appending will reallocate,capacityreturns 0. - inout pure nothrow @property @trusted inout(ElementEncodingType!A)[]
data(); - Returns the managed array.
- void
put(U)(Uitem)
if (canPutItem!U); - Appends
itemto the managed array. - void
put(Range)(Rangeitems)
if (canPutRange!Range); - Appends an entire range to the managed array.
- void
opOpAssign(string op : "~", U)(Urhs)
if (__traits(compiles, put(rhs))); - Appends
rhsto the managed array.Parameters:U rhsElement or range. - pure nothrow @trusted void
clear(); - Clears the managed array. This allows the elements of the array to be reused for appending.
Note:
clearis disabled for immutable or const element types, due to the possibility that Appender might overwrite immutable data. - pure @trusted void
shrinkTo(size_tnewlength); - Shrinks the managed array to the given length.Throws:Exception if
newlengthis greater than the current array length.Note:
shrinkTois disabled for immutable or const element types.
- struct
RefAppender(A) if (isDynamicArray!A); - A version of Appender that can update an array in-place. It forwards all calls to an underlying appender implementation. Any calls made to the appender also update the pointer to the original array passed in.
Tip: Use the arrayPtr overload of appender for construction with type-inference.
- this(A*
arr); - Constructs a RefAppender with a given array reference. This does not copy the data. If the array has a larger capacity as determined by
arr.capacity, it will be used by the appender.Note: Do not use built-in appending (i.e. ~=) on the original array until you are done with the appender, because subsequent calls to the appender will reallocate the array data without those appends.
Parameters:A* arrPointer to an array. Must not be null. - void
opDispatch(string fn, Args...)(Argsargs)
if (__traits(compiles, (Appender!A a) => mixin("a." ~ fn ~ "(args)"))); - Wraps remaining Appender methods such as put.Parameters:
fn Method name to call. Args argsArguments to pass to the method. - void
opOpAssign(string op : "~", U)(Urhs)
if (__traits(compiles, (Appender!A a) { a.put(rhs); } )); - Appends
rhsto the managed array.Parameters:U rhsElement or range. - const @property size_t
capacity(); - Returns the
capacityof the array (the maximum number of elements the managed array can accommodate before triggering a reallocation). If any appending will reallocate,capacityreturns 0. - inout @property inout(ElementEncodingType!A)[]
data(); - Returns the managed array.
- Appender!A
appender(A)()
if (isDynamicArray!A);
Appender!(E[])appender(A : E[], E)(auto ref Aarray); - Convenience function that returns an Appender instance, optionally initialized with
array. - RefAppender!(E[])
appender(P : E[]*, E)(ParrayPtr); - Convenience function that returns a RefAppender instance initialized with
arrayPtr. Don't usenullfor the array pointer, use the other version ofappenderinstead.