deleteAt: Difference between revisions
Jump to navigation
Jump to search
Killzone Kid (talk | contribs) No edit summary |
m (2.16 -> 2.18) |
||
(7 intermediate revisions by one other user not shown) | |||
Line 9: | Line 9: | ||
|descr= Removes array element at the given index and returns removed element (modifies the original array, just like [[resize]] or [[set]]). | |descr= Removes array element at the given index and returns removed element (modifies the original array, just like [[resize]] or [[set]]). | ||
{{Feature|informative| For the | {{Feature|informative| For the main [[Array]] variant, if the index is a negative [[Number]], no error will appear, making it ideal for using with [[find]] (see {{Link|#Example 2}}) or [[findIf]] (see {{Link|#Example 3}}).}} | ||
|s1= array [[deleteAt]] index | |s1= array [[deleteAt]] index | ||
Line 15: | Line 15: | ||
|p1= array: [[Array]] | |p1= array: [[Array]] | ||
|p2= index: | |p2= index: [[Number]] (see a note in description) | ||
|r1= [[Anything]] - returns the deleted element | |r1= [[Anything]] - returns the deleted element or [[Nothing]] | ||
|s2= hashMap [[deleteAt]] key | |s2= hashMap [[deleteAt]] key | ||
Line 28: | Line 28: | ||
|r2= [[Anything]] | |r2= [[Anything]] | ||
|s3= array [[deleteAt]] indexes | |||
|s3since= arma3 2.18 | |||
|p41= array: [[Array]] | |||
|p42= indexes: [[Array]] - multiple indexes, negative indexes are supported and would remove elements counting from the end of array (see {{Link|#Example 4}}). | |||
|r3= [[Array]] - deleted elements in order of user supplied indexes | |||
|x1= <sqf> | |x1= <sqf> | ||
Line 53: | Line 63: | ||
|x4= <sqf> | |x4= <sqf> | ||
_arr = [1,2,3,4]; | _arr = [1,2,3,4]; | ||
_arr deleteAt [-1]; // Remove the last array element | _res = _arr deleteAt [-1, 0]; // Remove the last and the first array element | ||
systemchat str _arr; // [1,2,3] | systemchat str [_res, _arr]; // [[4,1],[2,3]] | ||
</sqf> | </sqf> | ||
Latest revision as of 15:08, 8 February 2024
Description
- Description:
- Removes array element at the given index and returns removed element (modifies the original array, just like resize or set).
- Groups:
- ArraysHashMap
Syntax 1
- Syntax:
- array deleteAt index
- Parameters:
- array: Array
- index: Number (see a note in description)
- Return Value:
- Anything - returns the deleted element or Nothing
Syntax 2
- Syntax:
- hashMap deleteAt key
- Parameters:
- hashMap: HashMap
- key: HashMapKey
- Return Value:
- Anything
Syntax 3
- Syntax:
- array deleteAt indexes
- Parameters:
- array: Array
- indexes: Array - multiple indexes, negative indexes are supported and would remove elements counting from the end of array (see Example 4).
- Return Value:
- Array - deleted elements in order of user supplied indexes
Examples
- Example 1:
- Example 2:
- Example 3:
- Example 4:
Additional Information
- See also:
- deleteRange set resize select in find findIf toArray toString forEach count pushBack pushBackUnique apply append sort param params arrayIntersect splitString joinString
Notes
-
Report bugs on the Feedback Tracker and/or discuss them on the Arma Discord or on the Forums.
Only post proven facts here! Add Note
- Posted on Oct 15, 2014 - 16:55 (UTC)
-
Copyis almost 60x faster than (Tested with an array of 10.000 strings, iterating through it using a for-from-to-do loop)_array deleteAt 0;
- Posted on Mar 04, 2016 - 15:58 (UTC)
- Deleting from an array with foreach and _foreachIndex variable is tricky. The array is being altered, the _foreachIndex won't keep up and other elements in the array will be skipped and in worst case not being deleted. If you delete elements from an array in descending order (using while or for) it will work.
- Posted on Feb 09, 2017 - 22:45 (UTC)
- To expand on Highheads comment above - this is because forEach implements iterators to traverse a collection, which are read only by definition. The variable _x is an iterator that points to the current item in the collection. Trying to alter _x will have no effect. When trying to use deleteAt inside forEach, the behaviour would be undefined as you are invalidating the iterator reference, and it will not know how to traverse to the next element. In short, only use forEach when reading data from an array. For more info about iterators, see C++ Iterators.
- Posted on Feb 01, 2021 - 18:06 (UTC)
-
As you would expect from a simple array implementation,
is virtually zero cost (0.0005ms on an array of 1000000 elements), while
Copyis very performance heavy (0.7ms on the same huge array).array deleteAt 0;