Tema destacado: ¿Eres nuevo? ¿Tienes dudas acerca del funcionamiento de la comunidad? Lee las Reglas Generales
Autor
|
Tema: ¿Por qué es no recomendable el uso de "goto"? (Leído 2,871 veces)
|
|
Draklit
|
Bueno, me gustaría si me aclaran esa duda ya que no estoy tan seguro al respecto 
|
|
|
|
|
En línea
|
|
|
|
Edu
Desconectado
Mensajes: 1.082
Ex XXX-ZERO-XXX
|
Busca en el buscador que ya se hablo hace poco de esto.
|
|
|
|
|
En línea
|
|
|
|
WaAYa HaCK
Desconectado
Mensajes: 262
import ehn / #include <ehn.h>
|
Básicamente es porque un montón de saltos en el código de un programa puede resultar muy engorroso de leer. Si haces un code con 86 goto's, el que lea el código se va a volver loco.
Saludos!
|
|
|
|
|
En línea
|
|
|
|
Leo Gutiérrez.
. . .. ... ..... ........ ............. .....................
Colaborador
 
Desconectado
Mensajes: 2.968
/^$/
|
No soy partidiario del código spaguetti, pero a veces usar goto facilita las cosas, aunque no sea necesario.
If You Want To Go Somewhere, Goto Is The Best Way To Get There. -- Ken Thompson
|
|
|
|
|
En línea
|
|
|
|
|
vertexSymphony
|
+1 a leo, la difamación al goto es ... básicamente culpa de Dijkstra y es perdonable, la fecha del paper ("Go To Statement Considered Harmful" -> PDF : http://ur1.ca/bbpu ) es de 1968 y vale pensar qué lenguajes había en esa época. Es un groso, pero faileó con esto ... muchos repiten lo que el dijo, que repitieron sus profesores y así (y siempre cosas exageradas y sin sentido) ... sin saber de donde salió lo de "código spaghetti" y lo más importante para preguntar : ¿por qué? por que muchos se conforman con una explicación "pedorra" u otros siquiera preguntan debidamente y aceptan pasivamente lo que el profesor dice mientras dicen "ok, goto no, goto no, goto no, listo, ya lo memoricé" En diaspora hace poco hubo un debate muy interesante sobre goto que empezó por un chiste ( http://blog.susam.in/2011/06/urls-in-c.html ) y se escribieron muchas cosas. Una de ellas revivió un viejo debate en las listas de Linux que te aconsejo leer (por que sí, linux usa goto en varios lugares, así como el código del kernel de FreeBSD en partes de muy bajo nivel -por cierto-) : http://kerneltrap.org/node/553/2131goto es una herramienta del lenguaje, y como tal hay que saber cuando se usa y cuando no. hay lugares donde un goto tiene más sentido que cualquier otra cosa y viceversa ... Saludos.
|
|
|
|
« Última modificación: 3 Julio 2011, 12:21 por vertex@Symphony »
|
En línea
|
Mail/PGP/XMPP/D* gpg --recv-keys --keyserver pgp.mit.edu 0xCD21671D
|
|
|
WaAYa HaCK
Desconectado
Mensajes: 262
import ehn / #include <ehn.h>
|
Pues claro que sí, alguien puede decir que los comentarios en un código no sirven para una *****, pero yo diría que sí que sirven.
Dicen que no es recomendable usar goto... si hay una opción mejor, pero en muchos casos goto sirve para mucho. En batch, por ejemplo. Saludos!
PD: Leo, me gustó la frase... +1
|
|
|
|
|
En línea
|
|
|
|
Leo Gutiérrez.
. . .. ... ..... ........ ............. .....................
Colaborador
 
Desconectado
Mensajes: 2.968
/^$/
|
Leyendo el código de los comandos del SO opensolaris te lo llegas a encontrar bastante seguido así que... no está tan prohibida su práctica.
|
|
|
|
|
En línea
|
|
|
|
Valkyr
Desconectado
Mensajes: 632
Divide y vencerás
|
En mi opinión, tal y como dice vertex@symphony, habrá circustancias en las que se imponga razonadamente el uso de goto y otras en las que no sea así. Lo que yo considero es que, en lo que viene siendo la disciplina de programación, cuando se están dando los primeros pasos, no es una buena técnica, ya que puede llegar a acostumbrar al "futuro programador" a solucionar cualquier situación con un goto sin pararse a pensar en otros aspectos del problema.
Es una sentencia más del lenguaje sí, y la habrán usado en innumerables ocasiones, pero eso no significa que sea recomendable su uso, que es lo que pregunta Draklit. Creo que si se hace un uso "razonable" de la instrucción, sin abusar de ella ante cualquier situación, es una instrucción tan válida como el resto. Sin embargo, cuando la cosa ya comienza a ser un cachondeo de goto's por todo el código ante el más mínimo inconveniente, lo considero la peor técnica del mundo. Así que supongo que la cosa estará en encontrar un punto medio y no volverse loco poniendo instrucciones de este tipo.
Yo sinceramente veo más lógicas estas instrucciones en bajo nivel, ya que las sentencias de control son mínimas. Pero en lenguajes de alto nivel, donde existen muchas otras sentencias de control de flujo...no la considero indispensable.
Saludos.
|
|
|
|
|
En línea
|
|
|
|
[Zero]
Wiki
Conectado
Mensajes: 1.065
CALL DWORD PTR DS:[0]
|
Pues yo discrepo, aparte de que tal vez el código se vuelva más confuso a la hora de leer (o al contrario, la mayoría de situaciones que se prestan a usar un goto es porque lo ves más claro), lo más importante es que choca con el resto de estructuras de control. Toda estructura de bucle o condición te permite ir a donde quieres, y me parece que si no utilizas estas salidas de las estructuras "estándar" y añades un goto, 1º, complicas el algoritmo, y 2º, tal vez el compilador genere un código menos optimizado. Además, a la hora de ver el código, al menos a mí, no sé si por costumbre, un vistazo a estas estructuras ya te da una idea precisa del algoritmo, mientras que, tal vez, de utilizar un goto debes releer el código y seguirle la pista al flujo de ejecución de instrucciones. Igual que el uso de break y continue, es más gusto personal que otra cosa seguramente, pero aún complicando el algoritmo para no utilizarlos, me parece que éste queda mejor reflejado sin ellos.
En resumen, yo no veo razonable el uso de un goto en ningún caso.
Saludos
|
|
|
|
|
En línea
|
“El Hombre, en su orgullo, creó a Dios a su imagen y semejanza.” Nietzsche
|
|
|
Akai
Desconectado
Mensajes: 823
|
por que sí, linux usa goto en varios lugares
En bastantes de hecho. @[Zero]: En una charla de FOSDEM 2010 (me parece que era 2010, sino, 2011) Greg Kroah-Hartman en la charla "Write and Submmit your first Kernel Patch" comenta acerca que: dado el carácter multihilo del kernel que cuando en una función haces locking a algo y por un caso finalizas es más simple saltar al final de la función donde en cualquier caso sea funcionamiento normal o anormal vas a hacer los unlocks necesarios que duplicar el codigo para desbloquear (esta última es más propensa a errores)
|
|
|
|
|
En línea
|
|
|
|
|
vertexSymphony
|
Si van a decir cosas como "Dicen que" y similares repitiendo demás crap, por favor, pongan argumentos justificados, nada de exageraciones, código or GTFO.
Por que la demonización de goto tarde o temprano tiene que terminar. Es una herramienta como cualquier otra, y como *CUALQUIER* construcción en un lenguaje de programación no debe ser abusada y debe utilizarse donde sea más coherente, pero muchos usan la exageración (léase: abuso del goto y ponerlo all over the place) como una forma de desaconsejar su uso.
Bajo esa idea, podríamos decir que cosas como punteros o cualquier otra construcción es "desaconsejable" Los argumentos contra el goto fueron desarmados hace mil años, pero hay gente que insiste repetir cosas de 1968 ...
Saludos.
P.S: sí, este es un mensaje al buen estilo "leave goto alone" (o era leave britney alone ? méh) P.S 2 : me toca un poco los ... que yo diga que hay gente repitiendo crap (y explique un poquito por qué y ofrezca referencias) , y vengan a hacer eso sin aportar absolutamente nada a la justificación de eso.
|
|
|
|
« Última modificación: 4 Julio 2011, 16:28 por vertex@Symphony »
|
En línea
|
Mail/PGP/XMPP/D* gpg --recv-keys --keyserver pgp.mit.edu 0xCD21671D
|
|
|
Akai
Desconectado
Mensajes: 823
|
Oh, Se me pasó complementar el comentario acerca de la charla que cité anteriormente y no voy a editar un post si alguien ha respondido ya después de publicarlo. Uno de los ejemplos sobre los cuales en el kernel de linux se usa bastante el goto sería una estructura similar: pthread_mutex_lock(&m) if (lo_que_sea){ haz_cosas(); }else{ //no queremos continuar, pero aun asi tenemos que desbloquear goto exit; } //aqui se tendria mucho mas codigo ... exit: pthread_mutex_unlock(&m); return algo; Obviamente, con un lock no parece mucho cambio duplicar el código. Pongamos 15 locks. En situaciones como estas donde en unos casos la función debería terminar y se han bloqueado diversos locks y que es muy probable que dicho código se vaya a modificar, creo que queda claro que es preferible no duplicarlo en el else sino hacer un goto al final de la función, camino que también se recorrería si la función entrase en el if, haciendo a parte más cosas. Sea cual sea el caso, al finalizar la función tenemos que soltar esos locks, llegaremos bien sea con un salto directo o bien por el recorrido completo. En este caso creo que se ve que el goto simplifica el código. saltos para atrás son los que en determinados casos pueden marear la perdiz (aun así, qué son los bucles sino saltos condicionales hacia atrás?), hacia adelante no tienen ningún problema como creo que se puede ver en este ejemplo.
|
|
|
|
|
En línea
|
|
|
|
Leo Gutiérrez.
. . .. ... ..... ........ ............. .....................
Colaborador
 
Desconectado
Mensajes: 2.968
/^$/
|
Como dato interesante, ¿saben cuántos goto's hay en el código fuente de Perl? ─[0 leo@leo-945GCT-M ~/Descargas/perl-5.14.1]$ └─> find . -type f -iregex ".*c$" -exec cat {} \; | grep -i "goto" | wc -l 1430 ┌─[0 leo@leo-945GCT-M ~/Descargas/perl-5.14.1]$ └─>
Perl está hecho totalmente en C y que yo sepa no tiene bugs.
|
|
|
|
|
En línea
|
|
|
|
Littlehorse
All the world's a stage
Moderador
 
Desconectado
Mensajes: 2.710
Nie Dam Sie
|
No siempre menos lineas de código significa que este bien hecho y el goto para lo único que sirve en el 99% de los casos es para ahorrar lineas de código, esa por lo menos es mi opinión.
Que se use en Perl o en el Kernel que gusten no es una muestra de nada puesto que son programadores como todos; no puede tomarse eso como una referencia de que algo es correcto. Con el mismo criterio podemos decir que Dijkstra comento que no debería usarse y explico muy bien por que, y ¿Quien de ustedes se atreveria a decir que Dijkstra no tenia idea de lo que hablaba?. Como verán ninguna de estas referencias pueden tomarse para probar que "esto es así sin ninguna duda" porque cada uno tiene una visión distinta; se puede estar de acuerdo o no.
Personalmente no creo que goto sea adecuado para nada, genera confusión en el código y torna al flujo del algoritmo difícil de seguir para los que deban continuar lo que uno hizo (nada mas propenso a errores que un programador que no puede entender el código base con el cual debe trabajar).
Lo del goto exit; puede aparentar valido cuando se muestra en 5 lineas pero cuando comienzan los errores, las excepciones, cuando comienza las unidades de testeo y la depuración, la historia es otra.
Estoy de acuerdo con lo que dijo Zero, es cuestión de gustos.
Saludos!
PD: Sin comentarios como gtfo ni demás porque todos tienen derecho a opinar en la forma que gusten mientras no se falte el respeto a nadie.
|
|
|
|
« Última modificación: 5 Julio 2011, 00:51 por Littlehorse »
|
En línea
|
An expert is a man who has made all the mistakes which can be made, in a very narrow field.
|
|
|
Leo Gutiérrez.
. . .. ... ..... ........ ............. .....................
Colaborador
 
Desconectado
Mensajes: 2.968
/^$/
|
No siempre menos lineas de código significa que este bien hecho y el goto para lo único que sirve en el 99% de los casos es para ahorrar lineas de código, esa por lo menos es mi opinión.
Que se use en Perl o en el Kernel que gusten no es una muestra de nada puesto que son programadores como todos; no puede tomarse eso como una referencia de que algo es correcto. Con el mismo criterio podemos decir que Dijkstra comento que no debería usarse y explico muy bien por que, y ¿Quien de ustedes se atreveria a decir que Dijkstra no tenia idea de lo que hablaba?. Como verán ninguna de estas referencias pueden tomarse para probar que "esto es así sin ninguna duda" porque cada uno tiene una visión distinta; se puede estar de acuerdo o no.
Personalmente no creo que goto sea adecuado para nada, genera confusión en el código y torna al flujo del algoritmo difícil de seguir para los que deban continuar lo que uno hizo (nada mas propenso a errores que un programador que no puede entender el código base con el cual debe trabajar).
Lo del goto exit; puede aparentar valido cuando se muestra en 5 lineas pero cuando comienzan los errores, las excepciones, cuando comienza las unidades de testeo y la depuración, la historia es otra.
Estoy de acuerdo con lo que dijo Zero, es cuestión de gustos.
Saludos!
PD: Sin comentarios como gtfo ni demás porque todos tienen derecho a opinar en la forma que gusten mientras no se falte el respeto a nadie.
Sí, programadores, pero programadores muy brillantes, y si ellos usan goto es por algo, para algo les servirá, y por algo no lo hicieron de otra manera, ¿no crees?.
|
|
|
|
|
En línea
|
|
|
|
|
| Mensajes similares |
|
Asunto |
Iniciado por |
Respuestas |
Vistas |
Último mensaje |
|
|
Descargando de emule sale "Esperando"es recomendable la espera...??
Dudas Generales
|
Ad0nis
|
4
|
998
|
4 Agosto 2005, 22:25
por abcde
|
|
|
"""BUSCO EJEMPLO VB PARA ENVIAR MAILS""""
Programación Visual Basic
|
gera
|
1
|
1,552
|
1 Septiembre 2005, 00:14
por Rey11
|
|
|
Que Significa "Auto(Baja)" y que prioridad es más recomendable (Emule) (¿?)
Dudas Generales
|
Ad0nis
|
1
|
774
|
17 Julio 2006, 18:36
por Pret0rian0
|
|
|
De donde puedo descargar utilidades: "Formas", "Estilos", "Motivos", D
Diseño Gráfico
|
Ad0nis
|
2
|
1,395
|
2 Septiembre 2006, 15:48
por Ad0nis
|
|
|
[Ayuda] modificar "start page" en "internet explorer" con "batch"
Scripting
|
taton
|
7
|
4,227
|
20 Septiembre 2006, 01:45
por taton
|
|