Examples > Control Structures

Arrays

An array is a container of multiple values. Arrays are used to store blocks of data that need to be grouped together.

Hardware Required

  • MSP430 LaunchPad
  • (9) 220 ohm resistors
  • (9) LEDs
  • hook-up wire
  • breadboard

Relevant Groundwork

This variation on the For Loop example shows how to use an array. An array is a variable with multiple parts. If you think of a variable as a cup that holds values, you might think of an array as an ice cube tray. It's like a series of linked cups, all of which can hold the same maximum value.

The For Loop example shows you how to light up a series of LEDs attached to pins 2 through 10 of the LaunchPad, with certain limitations (the pins have to be numbered contiguously, and the LEDs have to be turned on in sequence).

This example shows you how you can turn on a sequence of pins whose numbers are neither contiguous nor necessarily sequential. To do this is, you can put the pin numbers in an array and then use for loops to iterate over the array.

This example makes use of 9 LEDs connected to the pins 2 - 10 on the board using 220 Ohm resistors, just like in the For Loop. However, here the order of the LEDs is determined by their order in the array, not by their physical order.

This technique of putting the pins in an array is very handy. You don't have to have the pins sequential to one another, or even in the same order. You can rearrange them however you want.

Circuit

Connect nine LEDS, with 220 ohm resistors in series, to digital pins 2-10 on your LaunchPad.

image developed using Fritzing. For more circuit examples, see the Fritzing project page

Schematic:

Code Explanation

None.

Code

/*
  Arrays
 
  Demonstrates the use of  an array to hold pin numbers
  in order to iterate over the pins in a sequence. 
  Lights multiple LEDs in sequence, then in reverse.
 
  Unlike the For Loop tutorial, where the pins have to be
  contiguous, here the pins can be in any random order.
 
  The circuit:
  * LEDs from pins 2 through 10 to ground
 
  created 2006
  by David A. Mellis
  modified 16 Apr 2013
  by Adrian Fernandez 

  This example code is in the public domain.
 
*/

int timer = 100;           // The higher the number, the slower the timing.
int ledPins[] = { 
  4, 10, 2, 6, 5, 3, 7, 9, 8};       // an array of pin numbers to which LEDs are attached
int pinCount = 9;           // the number of pins (i.e. the length of the array)

void setup() {
  // the array elements are numbered from 0 to (pinCount - 1).
  // use a for loop to initialize each pin as an output:
  for (int thisPin = 0; thisPin < pinCount; thisPin++)  {
    pinMode(ledPins[thisPin], OUTPUT);      
  }
}

void loop() {
  // loop from the lowest pin to the highest:
  for (int thisPin = 0; thisPin < pinCount; thisPin++) { 
    // turn the pin on:
    digitalWrite(ledPins[thisPin], HIGH);   
    delay(timer);                  
    // turn the pin off:
    digitalWrite(ledPins[thisPin], LOW);    

  }

  // loop from the highest pin to the lowest:
  for (int thisPin = pinCount - 1; thisPin >= 0; thisPin--) { 
    // turn the pin on:
    digitalWrite(ledPins[thisPin], HIGH);
    delay(timer);
    // turn the pin off:
    digitalWrite(ledPins[thisPin], LOW);
  }
}

See Also:

  • pinMode()
  • digitalWrite()
  • for()
  • delay()
  • For Loop - Control multiple LEDs with a For Loop.
  • While Loop - Use a While Loop to calibrate a sensor while a button is being pressed.
  • Switch Case - Choose between a number of discrete values in a manner that is the equivalent of using multiples If statements. This example shows how to divide a sensor's range into a set of four bands and to take four different actions depending on which band the result is in.

Getting Started Home

Corrections, suggestions, and new documentation should be posted to the Forum.

The text of the Energia reference is licensed under a Creative Commons Attribution-ShareAlike 3.0 License. Energia reference is based on the Arduino reference. Code samples in the reference are released into the public domain.