אפליקציית הורדת שירים
ויאגרה
תרגום מספרדית לעברית אונליין
список брокеров бинарных опционов
קמגרה למכירה
отзывы о сайте ламода

Tag Archives: C++

Caracteres en un archivo binario usando C++

Escribir y leer datos en un archivo binario no presenta demasiadas dificultades. Por ejemplo, para escribir un entero “e” y un float “f” en un archivo binario “bin” hacemos lo siguiente:

int e=10;
float f=12.5;
fstream bin(“archivo.bin”, ios::binary|ios::out);
bin.write((char *)&e, sizeof(int));
bin.write((char *)&f, sizeof(float));
bin.close();

Todo es lindo y prolijo, ahora, qué pasa si tengo una cadena de caracteres al estilo C de 14 caracteres?

Bien, las cadenas de caracteres al estilo C son vectores de bytes, y por lo tanto el identificador de la variable es un puntero a la dirección de memoria del primer caracter. O sea que para escribir este flujo de 14 bytes debemos ir iterando y guardar dato por dato. Vamos a los bifes, supongamos que tenemos una cadena “pianobar”:

char pianobar[14]=”nace una flor”;
fstream bin(“archivo.bin”, ios::binary|ios::out);
for (int i=0;i<14;i++){
bin.write((char *)&pianobar[i], 1)
}

Ahora, vamos a leer esta cadena:

char pianobar[14];
fstream bin(“archivo.bin”, ios::binary|ios::in);
bin.read((char *)&pianobar, 14)

De lo anterior vemos que la escritura se hace caracter por caracter, dejando un espacio de 1 byte por cada uno, luego al momento de leer el dato, se indica la cantidad total de bytes (para el ejemplo 14) y se asigna a la variable.

El único detalle a tener en cuenta es que la longitud de la cadena que hemos definido es de 14, sin embargo posee un máximo de 13 caracteres, ya que el último caracter queda reservado para el siguiente código de finalización “\0”. Otro punto a tener en cuenta es que las cadenas, al igual que los vectores comienzan en la posición 0.

getline luego de cin

Desde no hace mucho estoy intentando aprender C++. Viste que todo el mundo te dice: “Un informático no puedo no saber C++…“, así que como creo que tienen algo de razón encaminé mi vida por el sendero del qué dirán.

C++ tiene muchas diferencias con respecto a otros lenguajes, no es solo aprenderse la nueva sintaxis, sino que existen nuevos conceptos previamente inexistentes para mi. Aparte de esto, a veces me encuentro con pequeños detalles pelotudos que me hacen renegar. Uno de esos detalles “pelotudos” se me dio este fin de semana: Simplemente utilizaba para leer un número entero el cin>>n y líneas más abajo para leer un renglón completo utilizaba un cin.getline().

Todo parecía y compilaba bien, pero al momento de ejecutar mi pequeño programa obtenía comportamientos NO esperados (para mi pobre lógica). Acá un fragmento de código que reproduce el problema:

cout<<"Cantidad de cadenas a ingresar:";
cin>>n;
for (int i=1;i<=n;i++){
cout<<"Cadena: ";
cin.getline(cadena);
}

La salida da lo siguiente:

Cantidad de cadenas a ingresar: 3
Cadena: Cadena:

Como se ve, el programa no esperó para ingresar la primer cadena, sino que siguió con el ingreso de la segunda cadena. ¿Por qué pasa esto?

El tema es que cin>> agrega al flujo de entrada previo al dato a leer un (caracter “\n”) e ignora el último (caracter “\n”). Luego, cuando getline() encuentra en el flujo ingresado previamente el primer “\n” culmina su ejecución -recordemos que el getline() lee hasta encontrar un salto de carro, o sea un “\n”-.


Solución:

Yo la hice simple, uso luego del cin un getline que lea un caracter, de modo que captura el “\n” que tanto jodía antes, quedaría así:


char s[1];
cout<<"Cantidad de cadenas a ingresar:";
cin>>n;
cin.getline(s);

for (int i=1;i<=n;i++){
cout<<"Cadena: ";
cin.getline(cadena);
}

Social Widgets powered by AB-WebLog.com.

Social Widgets powered by AB-WebLog.com.

Social Widgets powered by AB-WebLog.com.