Siguiendo la regla de Pareto, un programador dedica solo el 20% de su tiempo a cosas realmente útiles.
Paso el 80% de mi tiempo depurando, arreglando cosas pequeñas para que todo funcione.
¿Hay alguna manera de pasar menos tiempo depurando?
Siguiendo la regla de Pareto, un programador dedica solo el 20% de su tiempo a cosas realmente útiles.
Paso el 80% de mi tiempo depurando, arreglando cosas pequeñas para que todo funcione.
¿Hay alguna manera de pasar menos tiempo depurando?
Respuestas:
Código en Agda o Coq . Una vez que su código se compila, funcionará. Si es demasiado duro, elija un idioma con un sistema de tipo más débil, por ejemplo, Haskell o F #.
Pero aún así, en la mayoría de los casos será mucho más productivo gastando el 20% de su tiempo en codificación y el 80% en pruebas y depuración. El 100% de una semana es mucho más que el 20% de una hora. Si la depuración es lo que necesita para hacer las cosas, entonces la depuración no es una pérdida de tiempo y no debería molestarse en "mejorar" esta proporción.
Examen de la unidad.
Después de que comencé a aplicar pruebas unitarias, descubrí que el código que escribí se estructuraba mejor. Entonces era más fácil de evitar y detectar errores. Pasé menos tiempo depurando, pero más tiempo escribiendo pruebas unitarias.
También creo que el tiempo invertido en pruebas unitarias tiene un mejor retorno de la inversión que la depuración. Después de una sesión de depuración, acabo de arreglar el código. El mismo error puede aparecer semanas después y tengo que depurar nuevamente. Si escribo una prueba unitaria, el error se documenta como una prueba unitaria y luego actúa como una prueba de regresión. Si el error aparece nuevamente, las pruebas unitarias me lo revelan.
a + b
fragmento de código (a menos que su prueba cubra todo el rango de su tipo de datos aritméticos).
Las pruebas unitarias ayudarán con la esperanza de que si introduce errores se rompan antes de su código de producción; las pruebas unitarias bien escritas también le dirán exactamente qué se rompió.
Eso lo llevará a la mayor parte del camino, pero para el 99.999% de los proyectos aún necesitará depurar las cosas a tiempo. Lo mejor que puedo hacer aquí es 4 cosas:
Mi 80% es depuración. Estoy arreglando errores simples y tratando de hacer que todo funcione.
Comience escribiendo pruebas unitarias e intente tener la mayor cobertura posible. Alguien mencionó TDD, pero yo iría con BDD .
Al final, lo más probable es que gaste el 80% en la depuración de errores complejos.
¿Cómo pasar menos tiempo depurando? Escribe menos código.
En serio, siempre y cuando escribas código, deberás depurarlo. Las pruebas unitarias, etc., ayudan enormemente, pero no piense que alguna vez eliminará por completo la necesidad.
Comprenda el qué y el por qué antes de comenzar a escribir código. Luego use una metodología de manera consistente. La metodología que elija no es tan importante como el uso repetido constante de la metodología. Si desea resultados consistentemente buenos, debe hacer un trabajo consistentemente bueno y tener un "método para su locura" es el primer paso para obtener estos resultados. A medida que identifique problemas, puede ajustar su metodología según sea necesario y, con el tiempo, mejorará su proceso de desarrollo y, con suerte, menos errores y más desarrollo nuevo y significativo.
Lea detenidamente su código antes de incluso compilarlo. Una lectura muy cuidadosa para la sintaxis y la funcionalidad. Puede ser sorprendentemente informativo, y también es un buen indicador si una sección de código es demasiado complicada.
La mayoría de las respuestas parecen centrarse en cómo reducir la cantidad de problemas que tiene que depurar y eso es valioso. Sin embargo, la depuración siempre será necesaria, por lo que es útil buscar formas de acelerar la depuración.
Sepa cómo usar su software de control de versiones.
Mejore su comprensión del lenguaje de programación que utiliza.
Ser lógico
Agregando a los comentarios para Pruebas unitarias, pero solo es realmente bueno si su código se ha separado para admitirlo (por ejemplo, MVC). Si no puede implementar MVC (o similar) (proyecto heredado), las pruebas unitarias no funcionan para su interfaz de usuario. Luego agregaría pruebas de IU automatizadas (Pruebas de IU codificadas de Microsoft, WaitN) ya que esto reducirá los errores en esa parte de su código.
También recomendaría encarecidamente ejecutar herramientas de análisis estático (por ejemplo, FxCop / Microsoft Code Analysis, Resharper, JustCode para el mundo MS). Estos pueden encontrar todo tipo de problemas de codificación comunes que pueden reducir las tontas tareas de depuración y centrarse más en la depuración de la lógica empresarial.
Haz que funcione, luego hazlo rápido, luego hazlo bonito. La mayoría de los errores provienen de optimizaciones tempranas o re-factorización en líneas de código que estaban totalmente bien. Si opta por la orientación a objetos, no se repita, manténgalo simple y siempre realice controles de cordura de los rangos de valores, especialmente si sus métodos seguirán funcionando con restricciones. No lo ayudará a cometer menos errores, pero probablemente lo ayudará a detectar errores más rápido y, por lo tanto, la depuración lleva menos tiempo.
Recientemente he pensado mucho en este problema: la respuesta simple es ir a leer El diseño de las cosas cotidianas de Don Norman; Escriba el código como diseñaría un producto.
Parafraseando, un buen diseño minimiza el error. Eso significa que, pocas cosas, la mayoría de los cuales usted ya hace (aunque puede que no sepa exactamente por qué ).
-Nombre funciona intuitivamente. Esto se conoce formalmente como asequibilidad. Es decir, un botón permite presionarlo, una palanca permite cambiar, un mango para tirar, etc.
-Es difícil escribir código incorrecto. Compruebe si hay errores de entrada y arroje errores más temprano que tarde, use aplicaciones húngaras cuando sea apropiado, etc. Estas se llaman funciones de bloqueo.
-Utilice la abstracción donde corresponda. La memoria a corto plazo es débil.
-La documentación es obviamente importante, pero es la menos efectiva para asegurarse de que el código se use correctamente. En resumen, los productos bien diseñados no necesitan ninguna documentación. (La forma más obvia de ver esto es mirando malos ejemplos: a saber, puertas con manijas que se supone que debes empujar).
-Unidad de pruebas. Estos realmente no evitan errores, sino que hacen que sea obvio dónde están los errores y proporcionan cordura.
Estoy seguro de que me faltan muchos más principios, pero el punto es leer sobre el diseño por error.
Si bien apoyo totalmente las pruebas unitarias sugeridas anteriormente, TDD o BDD serán de gran valor ya que primero debe pensar en el problema y la solución.
Pero personalmente para mí, tomarme unos minutos para sentarme en silencio y pensar sobre el problema y cómo abordarlo y cualquier pros y contras con cada enfoque, hace maravillas por mi calidad de código y ayuda a despejar mi mente del desorden.
A veces, un garabato rápido en una hoja de papel te ayuda a ver las piezas conectadas más grandes del rompecabezas.
Escribo el peor código cuando solo me sumerjo de cabeza y golpeo el teclado. Un poco de pensamiento y contemplación hace un mundo de diferencia.
PD. Quiero decir 5 tal vez diez minutos, no horas escribiendo una gran especificación.
Algunas buenas respuestas ya, solo un poco más de comida, aunque además de lo que otros han dicho.
Aprende de tus errores. No sigas haciendo los mismos una y otra vez.
Asegúrese de cubrir los casos extremos al programar; esos son lugares donde frecuentemente hay errores.
Presta atención al requisito. Incluso si funciona pero no cumple con el requisito especificado, eso es un error.
Los registros de excepciones pueden ser de gran ayuda cuando algo sale mal dentro de seis meses. Acostúmbrate a registrar excepciones.
Mis dos pensamientos principales son 1) Escribir un mejor código que fallará cuando haces algo inesperado 2) Mejora la depuración
Mi código está lleno de
if(value!=null) throw new NotImplementedException();
if(obj.v>0) throw new Exception(); //sometimes i dont write NotImplementedException
if(value=="thing") throw ...;
Cada vez que ejecuto ese fragmento de código, se produce la excepción que hace que el depurador se detenga, lo que me permite codificar las nuevas funciones o evitar las condiciones en lugar de confundirme sobre lo que está sucediendo / tener un error
Para mejorar en la depuración, la pila de llamadas, los puntos de interrupción (con condiciones), la ventana inmediata (también conocida como ventana de solicitud o respuesta), las variables de 'observación' y cualquier otra cosa.