Bitfields en C: ejercicio resuelto para flags compactas

Bitfields en C: ejercicio resuelto para flags compactas

Este ejercicio está programado para publicación diaria y mantiene la misma estructura didáctica del resto del sitio: enunciado claro, código compilable y salida esperada.

Enunciado

Implementa un caso práctico del tema y valida el resultado por consola.

Solución en C

 1
 2
 3
 4
 5
 6
 7
 8
 9
10
11
12
13
#include <stdio.h>

typedef struct {
    unsigned int lectura : 1;
    unsigned int escritura : 1;
    unsigned int ejecucion : 1;
} Permisos;

int main(void) {
    Permisos p = {1, 0, 1};
    printf("R:%u W:%u X:%u\n", p.lectura, p.escritura, p.ejecucion);
    return 0;
}

Resultado esperado

1
R:1 W:0 X:1

Errores frecuentes

  • No validar entradas o retornos de funciones estándar.
  • No controlar casos borde (buffers, límites, punteros nulos).
  • Omitir comprobaciones básicas de compilación y ejecución.

Aplicación práctica

Los campos de bits se usan en protocolos de red, registros de hardware embebido y formatos compactos de datos.

Siguiente ejercicio recomendado

Práctica guiada y libro completo

Si quieres una ruta completa con progresión real de dificultad:

FAQ

¿Este ejercicio sirve para entrevistas y exámenes de C?

Sí. Trabaja patrones que aparecen mucho en prácticas, entrevistas técnicas y evaluaciones de programación en C.

¿Dónde seguir con más ejercicios resueltos de C?

En Programación en C en 100 ejercicios resueltos y en Ejercicios C. Kindle Unlimited: Ver en Amazon.

¿Cómo practicar este tipo de ejercicio para mejorar más rápido?

Empieza con entradas pequeñas, prueba casos límite (vacío, un elemento y capacidad máxima) y luego reescribe la solución sin copiarla.