Reglas para desarrollar código seguro
December 12, 2016
Reglas para desarrollar código seguro
Las siguientes reglas están extraidas de este artículo de Gerard J. Holzmann.
La mayoría de programadores siguen una guía de estilos para programar, pero usualmente estas guías no muestran la calidad del código. La mayoría de guías suelen estar enfocadas a un Lenguaje de programación o a un Framework en específico y presentan mas un manual de como debería verse en vez de cómo debería funcionar.
Las siguientes reglas están enfocadas a C, pero pueden extenderse con facilidad para otros Lenguajes de programación:
- Restrinja todo su código a estructuras simples de control, evite la recursión directa o indirecta.
- Todos los ciclos deben tener un límite superior, debería ser posible determinar que un programa no se ejecutará infinitamente con un chequeo básico. Si el límite de un ciclo no puede ser probado estáticamente, esta regla se considera violada.
- No utilice localización dinámica de memoria después de la inicialización.
- Cada función no debería ser mas larga de una hoja de papel, esto se traduce en un máximo de 60 líneas de código
- La densidad de aserciones no debería sobrepasar dos por función, y siempre deberían ser consideradas como test booleanos
- Los objetos que contienen datos deberían definirse en el ámbito mas pequeño posible.
- El valor de retorno de cada función debe verificarse después de cada llamado y la validación de cada parámetro debe realizarse dentro de cada función
- El código debería ser compilado frecuentemente desde el primer día de desarrollo, con todos los advertencias activadas.