User Tools

Site Tools


en:reference:language:define

Differences

This shows you the differences between two versions of the page.

Link to this comparison view

en:reference:language:define [2017/04/07 10:03] (current)
Line 1: Line 1:
 +====== Define ======
 +
 +
 +#define is a useful C component that allows the programmer to give a name to a constant value before the program is compiled. Defined constants in ocrobot don't take up any program memory space on the chip. The compiler will replace references to these constants with the defined value at compile time.
 +
 +
 +This can have some unwanted side effects though, if for example, a constant name that had been #defined is included in some other constant or variable name. In that case the text would be replaced by the #defined number (or text).
 +
 +
 +In general, the const keyword is preferred for defining constants and should be used instead of #define.
 +
 +
 +Ocrobot defines have the same syntax as C defines:
 +===== Syntax =====
 +
 +#define constantName value
 +
 +
 +Note that the # is necessary.
 +===== Example =====
 +<code cpp>
 +#define ledPin 3
 +// The compiler will replace any mention of ledPin with the value 3 at compile time.
 +</​code>​
 +===== Tip =====
 +
 +There is no semicolon after the #define statement. If you include one, the compiler will throw cryptic errors further down the page.
 +<code cpp>
 +#define ledPin 3;    // this is an error 
 +</​code>​
 +
 +Similarly, including an equal sign after the #define statement will also generate a cryptic compiler error further down the page.
 +<code cpp>
 +#define ledPin ​ = 3  // this is also an error 
 +</​code>​
  
en/reference/language/define.txt · Last modified: 2017/04/07 10:03 (external edit)