append: Difference between revisions
Jump to navigation
Jump to search
Lou Montana (talk | contribs) m (Some wiki formatting) |
Lou Montana (talk | contribs) m (Some wiki formatting) |
||
Line 6: | Line 6: | ||
|gr1= Arrays | |gr1= Arrays | ||
|descr= Appends array2 to the back of array1 modifying array1. | |descr= Appends array2 to the back of array1 modifying array1. See [[insert]] for an "appendUnique" equivalent. | ||
{{Feature|informative| | {{Feature|informative|[[append]] does not return array, it modifies the existing array. If you need to return a copy, use "[[+]]": <sqf>array3 = array1 + array2;</sqf>}} | ||
[[append]] does not return array, it modifies existing array. If you need to return a copy, use "[[+]]": | |||
<sqf>array3 = array1 + array2;</sqf> | |||
}} | |||
|s1= array1 [[append]] array2 | |s1= array1 [[append]] array2 | ||
Line 20: | Line 17: | ||
|r1= [[Nothing]] | |r1= [[Nothing]] | ||
|x1= <sqf>_arr = [1,2,3]; | |x1= <sqf> | ||
_arr = [1,2,3]; | |||
_arr append [4,5,6]; | _arr append [4,5,6]; | ||
hint str _arr; // [1,2,3,4,5,6]</sqf> | hint str _arr; // [1,2,3,4,5,6] | ||
</sqf> | |||
|seealso= [[set]] [[pushBack]] [[pushBackUnique]] [[apply]] [[select]] [[resize]] [[reverse]] [[count]] [[deleteAt]] [[deleteRange]] | |seealso= [[set]] [[pushBack]] [[pushBackUnique]] [[apply]] [[select]] [[resize]] [[reverse]] [[count]] [[deleteAt]] [[deleteRange]] | ||
Line 31: | Line 30: | ||
|timestamp= 20150309004100 | |timestamp= 20150309004100 | ||
|text= <sqf>_array1 append _array2;</sqf> | |text= <sqf>_array1 append _array2;</sqf> | ||
is roughly 1. | is roughly 1.2× faster (depending on array size) than | ||
<sqf>_array1 = _array1 + _array2</sqf> | <sqf>_array1 = _array1 + _array2</sqf> | ||
(Averaged over 10.000 iterations with two identical arrays containing the numbers 0 through 9)<br> | (Averaged over 10.000 iterations with two identical arrays containing the numbers 0 through 9)<br> | ||
Line 93: | Line 92: | ||
// Example | // Example | ||
arr = [1,2,3]; | arr = [1,2,3]; | ||
[arr,[4,5,6]] call KK_fnc_pushStack; // both arr and function return are [1,2,3,4,5,6] | [arr, [4,5,6]] call KK_fnc_pushStack; // both arr and function return are [1,2,3,4,5,6] | ||
</sqf> | </sqf> | ||
}} | }} |
Revision as of 14:22, 8 August 2022
Description
- Description:
- Appends array2 to the back of array1 modifying array1. See insert for an "appendUnique" equivalent.
- Groups:
- Arrays
Syntax
Examples
- Example 1:
Additional Information
- See also:
- set pushBack pushBackUnique apply select resize reverse count deleteAt deleteRange
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 Mar 09, 2015 - 00:41 (UTC)
-
is roughly 1.2× faster (depending on array size) than (Averaged over 10.000 iterations with two identical arrays containing the numbers 0 through 9)_array1 append _array2;
The larger the arrays to append, the faster append is as it does not create a new array, which happens with array addition.
- Posted on May 21, 2015 - 10:27 (UTC)
- Array "unshift" implementation using append, a faster alternative to BIS_fnc_arrayUnShift:
- Posted on May 21, 2015 - 15:21 (UTC)
-
Array "insert" implementation using append, much faster alternative to BIS_fnc_arrayInsert:
KK_fnc_insert = { private ["_arr", "_i", "_res"]; _arr = _this select 0; _i = _this select 2; _res = []; _res append (_arr select [0, _i]); _res append (_this select 1); _res append (_arr select [_i, count _arr - _i]); _res; }; // Example arr = [1,2,3,4]; [arr, ["a","b"], 2] call KK_fnc_insert; // [1,2,"a","b",3,4]
- Posted on May 21, 2015 - 15:52 (UTC)
- A faster alternative to BIS_fnc_arrayPushStack using append: