Code Complete cubre muchos conceptos atemporales como:
- fuerte cohesión
- bajo acoplamiento
- buenos nombres de rutina
- programación defensiva
- código autodocumentado
- revisiones de software
- examen de la unidad
que sin duda son relevantes hoy.
Algunos de los conceptos defendidos en CC ahora se aplican de manera sintáctica en lenguajes más nuevos, por ejemplo, C # no permite que la variable en los sub-ámbitos se defina de una manera que oculte una definición súper-alcance.
Otros conceptos, como la notación húngara para nombres de variables han quedado en el camino en la programación convencional (aunque cualquiera que todavía trabaje con la API Win32 argumentará con vehemencia que están vivos y bien). Sin embargo, el concepto real detrás de la convención de nomenclatura variable es transmitir el significado necesario y aclarar el código, conceptos que yo diría que también son intemporales.
En total, por lo que puedo recordar (y un vistazo rápido dentro de mi venerable copia de CC), diría que ciertamente vale la pena revisarlo.
Sin embargo, no creo que se eleve a la naturaleza verdaderamente atemporal del Mes del Hombre Mítico. MMM aborda cuestiones de quién está haciendo el trabajo, cómo y por qué lo están haciendo; así como los costos y la complejidad de las comunicaciones (humanas). MMM aborda problemas que son fundamentales para todo lo que hacemos. CC, en comparación, se centra en cuestiones prácticas y pragmáticas de cómo lo hacemos. Dicho de otra manera, si un proyecto está retrasado y un gerente decide agregar 100 personas al equipo, escribir un código comprensible realmente no hará la diferencia.
CC realmente no aborda problemas importantes que afectan a nuestra industria; pero proporciona una buena base para luchar por el mejor resultado en una situación a menudo imposible.
Sin duda consideraría que ambos requieren lectura para cualquiera que se preocupe por el desarrollo de software; y recomendaría volver a leer MM cada vez que necesite un repaso. Vale la pena releer CC si está liderando un equipo de desarrollo, estableciendo estándares grupales o capacitando a nuevos desarrolladores; fuera de eso, personalmente encuentro que hace mucho tiempo internalicé el material en CC y lo practiqué a diario.
Esperanzas que ayuden. Ciertamente son dos de mis favoritos.