Jawaban:
Untuk pencetakan debug, Anda dapat menentukan makro untuk mencetak nama dan nilai variabel seperti ini:
#define PRINTLN(var) Serial.print(#var ": "); Serial.println(var)
yang kemudian Anda gunakan seperti ini:
int x = 5;
PRINTLN(x);
// Prints 'x: 5'
Ini juga bagus:
#define PRINT(var) Serial.print(#var ":\t"); Serial.print(var); Serial.print('\t')
#define PRINTLN(var) Serial.print(#var ":\t"); Serial.println(var)
ketika digunakan dalam satu lingkaran seperti itu
PRINT(x);
PRINT(y);
PRINTLN(z);
mencetak output seperti ini:
x: 3 y: 0.77 z: 2
x: 3 y: 0.80 z: 2
x: 3 y: 0.83 z: 2
Terima kasih banyak atas jawaban Anda. Saya membuat ini ...
#define DEBUG //If you comment this line, the functions below are defined as blank lines.
#ifdef DEBUG //Macros
#define Say(var) Serial.print(#var"\t") //debug print, do not need to put text in between of double quotes
#define SayLn(var) Serial.println(#var) //debug print with new line
#define VSay(var) Serial.print(#var " =\t"); Serial.print(var);Serial.print("\t") //variable debug print
#define VSayLn(var) Serial.print(#var " =\t"); Serial.println(var) //variable debug print with new line
#else
#define Say(...) //now defines a blank line
#define SayLn(...) //now defines a blank line
#define VSay(...) //now defines a blank line
#define VSayLn(...) //now defines a blank line
#endif
if (some_condition) VSayLn(some_var);
tidak akan berfungsi sebagaimana dimaksud. Perbaikan standar adalah untuk #define VSayLn(var) do { Serial.print(#var " =\t"); Serial.println(var); } while (0)
. Cf Mengapa menggunakan pernyataan do-while dan if-else yang tampaknya tidak berarti di makro?
Serial.print
.