Antworten:
Für den Debug-Druck können Sie ein Makro definieren, um sowohl den Namen als auch den Wert einer Variablen wie folgt zu drucken:
#define PRINTLN(var) Serial.print(#var ": "); Serial.println(var)
die du dann so verwendest:
int x = 5;
PRINTLN(x);
// Prints 'x: 5'
Auch das ist schön:
#define PRINT(var) Serial.print(#var ":\t"); Serial.print(var); Serial.print('\t')
#define PRINTLN(var) Serial.print(#var ":\t"); Serial.println(var)
wenn in einer Schleife wie so verwendet
PRINT(x);
PRINT(y);
PRINTLN(z);
druckt eine Ausgabe wie folgt:
x: 3 y: 0.77 z: 2
x: 3 y: 0.80 z: 2
x: 3 y: 0.83 z: 2
Vielen Dank für Ihre Antworten. Ich habe das gemacht ...
#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);
funktioniert nicht wie vorgesehen. Die Standardkorrektur ist zu #define VSayLn(var) do { Serial.print(#var " =\t"); Serial.println(var); } while (0)
. Vgl. Warum scheinbar bedeutungslose do-while- und if-else-Anweisungen in Makros verwenden?
Serial.print
.