Hola a todos.
Lenguaje....................: "C"
Sistema operativo.....: Windows XP
Compilador.................: MinGW
Problema....................:Esta estructura puede tener el mismo problema que plantea rir3760 en este post.
http://foro.elhacker.net/programacion_cc/operadores_a_nivel_de_bits_lenguaje_c-t410671.0.html
Error...........................: Ninguno.
Otras Observaciones..:http://foro.elhacker.net/programacion_cc/de_minuscula_a_mayuscula_a_nivel_de_bits_en_lenguaje_c-t405856.0.html (http://foro.elhacker.net/programacion_cc/de_minuscula_a_mayuscula_a_nivel_de_bits_en_lenguaje_c-t405856.0.html)
Código.........................:
//Con uniones y campos de bit.
#include <stdio.h>
union caracteres
{
unsigned char c;
struct c_bits
{
unsigned b0:1;
unsigned b1:1;
unsigned b2:1;
unsigned b3:1;
unsigned b4:1;
unsigned b5:1;
unsigned b6:1;
unsigned b7:1;
} bits;
};
int main(void){
union caracteres caracter = {110};
printf("\n\n union caracteres caracter = {110};");
printf("\n\n La variable caracter contiene la letra...: \"%c\"", caracter.c);
printf("\n\n caracter.bits.b5 = 0; //Apaga el bits 5 para que la letra 'n' se transforme en 'N'");
caracter.bits.b5 = 0;
printf("\n\n Ahora la variable caracter contiene la letra...: \"%c\"", caracter.c);
printf("\n\n");
return 0;
}
//Con máscaras y operaciones a nivel de bit.
#include <stdio.h>
int main(void){
char letra = 'n';
printf("\n\n char letra = 'n';");
printf("\n\n La variable letra contiene la letra...: \'%c\'", letra);
letra &=0xDF;
printf("\n\n letra &=0xDF; // 0xDF es en binario = 1101 1111 --> pones a 0 el bit 5");
printf("\n\n Ahora la variable letra contiene la letra...: \'%c\'", letra);
printf("\n\n");
return 0;
}
Saludos y como siempre muchas gracias.
Daniel
??? que intentas?
Por lo visto, restar 32 decimal, o sea 0x20, para pasar del código ASCII de letra mayúscula al de la respectiva minúscula. Para eso anulas el bit 5, que puedes hacer con una máscara. Revisando los códigos ASCII de todos los caracteres en mayúscula, van desde 0x61 hast 0x7A y todos poseen el bit nro. 5 en '1', por lo tanto es válido restar de este modo (hubiera sido un problema si el bit5 fuera '0', pero esto no sucede).
Sinó puedes hacer un XOR para ese bit, que quedaría "var ^ 32;" si no me equivoco.
Cita de: NOB2014 en 18 Marzo 2014, 22:53 PM//Con uniones y campos de bit.
#include <stdio.h>
union caracteres
{
unsigned char c;
struct c_bits
{
unsigned b0:1;
unsigned b1:1;
unsigned b2:1;
unsigned b3:1;
unsigned b4:1;
unsigned b5:1;
unsigned b6:1;
unsigned b7:1;
} bits;
};
La mayoría de las características de los campos de bits son "implementation defined" eso mas el detalle de dar por sentado ocho bits por byte (lo usual pero pueden ser mas, mejor usar la macro CHAR_BIT de <limits.h>).
Para el caso la recomendación es utilizar toupper, tolower, etc. cortesía de <ctype.h>, portable y sencillo.
Un saludo