Diferencia entre revisiones de «Stream.readString()»
De ArduWiki
(Página creada con «== Descripción == == Sintaxis == <pre> </pre> == Parametros == == Retorna == == Advertencias == Nada. == Ejemplo == <syntaxhighlight lang="c++"> </syntaxhighlight> =...») |
(→Referencias) |
||
(No se muestran 4 ediciones intermedias de 2 usuarios) | |||
Línea 1: | Línea 1: | ||
== Descripción == | == Descripción == | ||
+ | Lee caracteres y los coloca en un [[String]]. La función finaliza cuando el tiempo de espera (ver [[Stream.setTimeout()]]) se ha agotado. | ||
== Sintaxis == | == Sintaxis == | ||
<pre> | <pre> | ||
+ | objetoStream.readString(); | ||
</pre> | </pre> | ||
− | == | + | == Parámetros == |
+ | ;objetoStream: nombre de la instancia de la clase [[Stream]]. | ||
== Retorna == | == Retorna == | ||
+ | El objeto [[String]] resultante de la lectura. | ||
== Advertencias == | == Advertencias == | ||
− | + | * Hay un "bug" o fallo con esta función: si el flujo de entrada es constante (tiempo de espera nunca se agota) o lo suficientemente grande, se corre el riesgo de colgar completamente el programa. La razón se debe a que, conceptualmente, [[String]] es ilimitado en tamaño; pero como la [[SRAM]] no es así, eventualmente el programa llegará a colapsar. | |
== Ejemplo == | == Ejemplo == | ||
<syntaxhighlight lang="c++"> | <syntaxhighlight lang="c++"> | ||
+ | if (Serial.available()) { | ||
+ | Serial.print(F("Mensaje recuperado: \"")); | ||
+ | Serial.print(Serial.readString()); // Ojo con el tamaño, que puede que de aquí no pase u ocurra comportamiento indefinido. | ||
+ | Serial.println('\"'); | ||
+ | } | ||
</syntaxhighlight> | </syntaxhighlight> | ||
== Vea también == | == Vea también == | ||
− | + | <categorytree mode=all>Stream</categorytree> | |
− | |||
− | |||
− | |||
== Referencias == | == Referencias == | ||
− | [[Category: | + | [[Category:Stream]] |
Revisión actual del 18:31 6 may 2019
Contenido
Descripción
Lee caracteres y los coloca en un String. La función finaliza cuando el tiempo de espera (ver Stream.setTimeout()) se ha agotado.
Sintaxis
objetoStream.readString();
Parámetros
- objetoStream
- nombre de la instancia de la clase Stream.
Retorna
El objeto String resultante de la lectura.
Advertencias
- Hay un "bug" o fallo con esta función: si el flujo de entrada es constante (tiempo de espera nunca se agota) o lo suficientemente grande, se corre el riesgo de colgar completamente el programa. La razón se debe a que, conceptualmente, String es ilimitado en tamaño; pero como la SRAM no es así, eventualmente el programa llegará a colapsar.
Ejemplo
if (Serial.available()) {
Serial.print(F("Mensaje recuperado: \""));
Serial.print(Serial.readString()); // Ojo con el tamaño, que puede que de aquí no pase u ocurra comportamiento indefinido.
Serial.println('\"');
}
Vea también