Arrays
Arrays are a data type in Max. Similar to lists, arrays store multiple items in order. Unlike lists, which are limited to storing numbers and symbols, arrays can store other Max data structures including strings, dictionaries, and other arrays. Similar to dictionaries and strings, arrays are stored in memory by name. Generally, arrays are a more powerful version of lists.
When to Use Arrays
Creating an Array
Create an array with the array object. Initialize the contents of the array by including the initial values as object arguments.
data:image/s3,"s3://crabby-images/a87a9/a87a95396b92b1ec19429932986c0277f0d2dc9f" alt="An Max patcher containing two object boxes. The first has the contents array" and the second has the contents "array 1 2 3". A comment describes the first object as an empty array, and the second object as an array with initial contents An Max patcher containing two object boxes. The first has the contents "array" and the second has the contents "array 1 2 3". A comment describes the first object as an empty array, and the second object as an array with initial contents"
Editing Arrays
Edit an array in place by using the append, clear, delete, insert, prepend, and replace messages.
data:image/s3,"s3://crabby-images/146b0/146b044879fe5ef2146d8cb504271405140cb777" alt="An Max patcher containing an array object. Message boxes containing example messages like append, clear, delete, insert, prepend, and replace are connected to it. An Max patcher containing an array object. Message boxes containing example messages like append, clear, delete, insert, prepend, and replace are connected to it."
Objects that modify arrays as they pass through them, like array.rotate
, don't change the original array, but create a new array with the result of their computation. In this example, the objects on the left always output the same result, but the objects on the right will update the original array with every rotation.
data:image/s3,"s3://crabby-images/714de/714de977da21b762c7994abbdbf8b0d239149b90" alt="On the left, objects connected in series that rotate an array to the right by one. On the right, the same set of objects, with an additional connection that updates the original array after rotation. On the left, objects connected in series that rotate an array to the right by one. On the right, the same set of objects, with an additional connection that updates the original array after rotation."
Named Arrays
Like dictionaries and strings, arrays always have a unique name. By default, the name will simply be a randomly generated unique identifier. You can also assign a name to an array using the @name attribute.
data:image/s3,"s3://crabby-images/221f1/221f107ae84137c3d9cfeb157bfdb3f740c6fa09" alt="On the left, an array object connected to a chooser object, demonstrating the unique name assigned to array objects by default. On the right, an array with the name Peter. On the left, an array object connected to a chooser object, demonstrating the unique name assigned to array objects by default. On the right, an array with the name Peter."
An array is identified by its unique name, so you can access the same array from any array object with the same name.
data:image/s3,"s3://crabby-images/7ac6b/7ac6bdfec02209cf3c5c76f03aca20cbc15cab7b" alt="Two array objects, both with the name tom". A message box with the contents "1 2 3" is connected to the right inlet of one of the array objects. A button is connected to the left inlet of the other array object, and that array object is also connected to the right inlet of a message box with the contents "1 2 3". Two array objects, both with the name "tom". A message box with the contents "1 2 3" is connected to the right inlet of one of the array objects. A button is connected to the left inlet of the other array object, and that array object is also connected to the right inlet of a message box with the contents "1 2 3"."
Converting to and from a List
Any list sent to an array object will automatically be converted to an array. When it comes to working with arrays and lists, many objects will use arrays and lists interchangeably. However, in some circumstances, you might need to use a list and not an array. In these cases, you can use the array.tolist object to convert an array into a list.
data:image/s3,"s3://crabby-images/67eba/67eba81e9989e652ad68dbdbc12fd22191768716" alt="arrays_006"
If the array contains structured data, like dictionaries or other arrays, converting to a list will not unpack the contents of any structured data object. Instead, the list will simply contain a symbol representation of the object.
data:image/s3,"s3://crabby-images/878c9/878c9c4cebb4e692d4e74be8b69acbbfe8941656" alt="arrays_007"
If your array contains only numbers, symbols/strings, and other arrays, you can use the object array.flatten to collect all sub-arrays and their contents into one long array. This can then pass through the array.tolist object to return a simple representation of your array's contents.
data:image/s3,"s3://crabby-images/1f22d/1f22da0a494ddc27e5acf202b49e7f4345301e56" alt="arrays_008"
Arrays and Dictionaries
Dictionaries can contain arrays, and arrays can contain dictionaries. Printing an array containing a dictionary will output a JSON representation of the dictionary.
data:image/s3,"s3://crabby-images/e02fe/e02fe654de46094a2684605089b1b640b9955bf6" alt="arrays_009"
JavaScript
Use the MaxArray
class to create a JavaScript reference to a Max Array.
You can give it an initial value by passing a list or Array value to the
constructor. Update the value of the array by calling .set
.
var max_arr = new MaxArray(1, 2, "three", 4.0);
max_arr.set(10, 9, "eight", 7.0); // update the array contents
By setting the name property of the MaxArray
, you can refer to a Array
defined in the parent patcher.
var max_arr = new MaxArray();
max_arr.name = "frith"; // Now the MaxArray refers to an array named "frith"
max_arr.set(2, 4, "six", 8); // Updates the array in the containing patcher
If you want to manipulate the Array value, call .stringify
and JSON.parse
to turn
the Max Array into a JavaScript Array. From there, you can use regular JavaScript
array manipulation functions. To convert back, use JSON.stringify
and .parse
.
var max_arr = new MaxArray();
max_arr.set(2, "3", "four", 6);
var js_arr = JSON.parse(max_arr.stringify()); // retrieve the value as a JS string, convert to Array
post(JSON.stringify(js_arr) + '\n'); // prints "[the, old, array, value]"
js_arr[1] = 3;
max_arr.parse(JSON.stringify(js_arr));
post(max_arr.stringify() + '\n'); // prints "[the, new, array, value]"
To send a Max Array out of an outlet defined in JavaScript, send the string "array" followed by the name of the array.
function bang() {
var arr = new MaxArray();
arr.parse("I got a bang");
outlet(0, "array", arr.name);
}