elhacker.net cabecera Bienvenido(a), Visitante. Por favor Ingresar o Registrarse
¿Perdiste tu email de activación?.

 

 


Tema destacado: ¿Eres nuevo? ¿Tienes dudas acerca del funcionamiento de la comunidad? Lee las Reglas Generales


+  Foro de elhacker.net
|-+  Programación
| |-+  Programación General
| | |-+  .NET (C#, VB.NET, ASP) (Moderador: kub0x)
| | | |-+  [Pregunta] Buenas Practicas de Programacion en VB.NET
0 Usuarios y 1 Visitante están viendo este tema.
Páginas: [1] Ir Abajo Respuesta Imprimir
Autor Tema: [Pregunta] Buenas Practicas de Programacion en VB.NET  (Leído 8,936 veces)
OscarCadenas_91

Desconectado Desconectado

Mensajes: 27


Ver Perfil
[Pregunta] Buenas Practicas de Programacion en VB.NET
« en: 27 Julio 2015, 00:58 am »

Soy aprendiz en visual basic .net y no sabia como preguntar esto, quería preguntarles a los que tiene mas conocimientos, sobre que buenas practicas se deben tomar para programar en este lenguaje, tengo poca base y estoy aprendiendo de forma autodidacta
Espero que se entienda.


En línea

El Benjo


Desconectado Desconectado

Mensajes: 392



Ver Perfil WWW
Re: [Pregunta] Buenas Practicas de Programacion en VB.NET
« Respuesta #1 en: 27 Julio 2015, 07:57 am »

Hola, mis conocimientos en la programación orientada a eventos comenzaron con este lenguaje. Te puedo decir algunas cosas que se aplican a cualquier lenguaje y no algo en específico al VB:

· Indenta el código.
· No pongas todas las funciones en un único archivo o módulo. (En el formulario principal, por ejemplo, intenta dejar únicamente las funciones relacionadas con los eventos o que trabajen directamente sobre el formulario y sus controles)
· Nombra a cada control al que hagas referencia en el código. (Me refiero a que si pones un label sobre el que nunca vas a actuar puedes dejarlo con el nombre de label1, por ejemplo, pero si en tu código haces referencia a él para asignar u obtener una propiedad entonces deberías nombrar al label según su función)
· Comenta las partes de tu código que no sean muy obvias, pero no escribas comentarios innecesarios. El de abajo es un comentario innecesario porque lo que hace la linea de código e bastante obvio.

Código
  1. 'Incremento la variable Var1.
  2. Var1 = Var1 + 1

Y por el momento creo que es todo lo que se me ocurre. Espero que más de uno de los puntos te fuera de ayuda.


En línea

www.es.neftis-ai.com

Sí hay un mejor lenguaje de programación y es ese con el que puedes desarrollar tus objetivos.
Eleкtro
Ex-Staff
*
Desconectado Desconectado

Mensajes: 9.866



Ver Perfil
Re: [Pregunta] Buenas Practicas de Programacion en VB.NET
« Respuesta #2 en: 27 Julio 2015, 10:08 am »

Son muchas cosas las que se deberían mencionar como para hacer una alusión a cada una de ellas en unas pocas lineas, pero te diré lo que considero que es más importante en general.



1. Usar las declaraciones Option.

Activa las declaraciones Option (excepto Option Inffer, e ignorando el valor de Option Compare) por defecto para todos los archivos de los nuevos proyectos, accediendo al menú Tools -> Options... -> Projects and solutions -> VB Defaults

También puedes hacerlo manualmente escribiendo lo siguiente en la cabecera de cualquier clase/módulo, los cambios solamente afectaran a ese archivo:
Código
  1. Option Explicit On
  2. Option Strict On
  3. Option Infer Off
  4.  
  5. Class ClassName
  6. ' ...
  7. End Class

Esto que he mencionado es lo primero que debes hacer, ya que es una medida que conseguirá que adquieras buenas prácticas de programación desde el principio, ya que, entre otras cosas, evitará que puedas escribir y compilar burradas como esta:
Código
  1. Dim form As Object = Nothing
  2. form.Close()

Sin embargo, será algo muy fastidioso si necesitases crear un tipo anónimo como este de abajo, ya que no lo permitirá compilar:
Código
  1. Dim colors = From value In [Enum].GetValues(GetType(ConsoleColor))
  2.             Select New With {
  3.                              .Value = value,
  4.                              .Name = value.ToString
  5.                             }

...Pero precisamente este tipo de cosas son las que debes evitar hacer. Siempre puedes rsolver el problema definiendo un Type personalizado:
Código
  1. <Serializable>
  2. Public NotInheritable Class ColorThing
  3.    Public Property Name As String
  4.    Public Property Value As Integer
  5. End Class
  6.  
  7. Dim colors As IEnumerable(Of ColorThing) =
  8.    From value As ConsoleColor In [Enum].GetValues(GetType(ConsoleColor)).Cast(Of ConsoleColor)()
  9.    Select New ColorThing With {
  10.                                .Value = value,
  11.                                .Name = value.ToString
  12.                               }



2. Leer, aprender y practicar las convenciones de código y de nombres.

¿Por qué?, pues ...entre otras razones, por que cada lenguaje tiene su estándar, así que al escribir un nombre preciso y del modo correcto estarás ayudando al compiler a identificar el miembro en cuestión, lo que se puede traducir cmo mayor estabilidad y velocidad en general (por ínfima que sea en la mayoría de casos).

Aquí tienes por donde empezar, aunque aquí se menciona solamente una pequeña porción:
Manuales de .NET

Citar

Otras convenciones a tener en cuenta:

  • Debes ignorar cualquier uso de los miembros contenidos en el namespace Microsoft.VisualBasic (Microsoft.VisualBasic.Left, Microsoft.VisualBasic.Mid, Microsoft.VisualBasic.IsDate y en fin, cualquier nombre de función vista en VisualBasic 6)
     
  • Debes evitar usar prefijos como "_" para declarar variables (tanto en VB.net como en C#), esto es una mala práctica que ha sido adoptada de forma muy común, pongamos como ejemplo esta propiedad con un backing field, la mayoría de personas lo harían así:
     
Código
  1. Public ReadOnly Property Thing As Boolean
  2.    Get
  3.        Return Me._thing
  4.    End Get
  5. End Property
  6. Private _thing As Boolean = False

Sin embargo, ya he mencionado que el prefijo no se debe usar, así que puedes optar por escribir por ejemplo una "B" al final del nombre, para saber que se trata de un backing field:
Código
  1. Public ReadOnly Property Thing As Boolean
  2.    Get
  3.        Return Me.thingB
  4.    End Get
  5. End Property
  6. Private thingB As Boolean = False

  • Debes escribir los nombres de los métodos, funciones, Classes, Modules, Structures, Properties, y muchos más miembros en Word-Casing, y los nombres de las variables generalmente en Camel-Casing, pero se debe tener en cuenta que el estándar de nombre depende de la visibilidad asignada al miembro (public, private, shared, etc), por ejemplo así es como deberías escribir el nombre de una variable en dos casos distintos:
Código
  1. Public MyObject As Object
Código
  1. Private myObject As Object


  • Al practicar el P/Invoking (o Platform Invoking), debes comprender que C++ no es C# ni tampoco VB.Net, como ya dije cada lenguaje tiene su estándar de convenciones, y un error muy común en el P/Invoking es copiar o traducir las definiciones de C++ (desde la MSDN o de páginas como www.pinvoke.net) tal y como están escritas para C++, por ejemplo estructuras que llevan nombres completamente en mayúscula, lo que es completamente incorrecto en .Net.
     
  • Utilizar la directiva Using para asegurarte de que un objeto libera sus recursos cuando ya no los necesita, o en su defecto un bloque Try/Catch/Finally
     
  • Asignar siempre un valor de retorno al definir la firma de una función.
     
  • Sustituir a una Class por un Module siempre y cuando sea mejor y óptimo para el compiler, no simplemente para poder usar miembros compartidos/globales.
     
  • Inicializar siempre las variables con un valor por defecto, excepto en casos innnecesarios donde ya se inicializan con un valor por defecto como por ejemplo variables con un datatype Boolean (False) o Integer (0).
     
  • Utilizar el keyword WithEvents al declerar una variable que exponga eventos, y en su lugar omitir el uso de AddHandler/RemoveHandler para usarlos solamente cuando realmente sea necesario.
     
  • Asignarle siempre la firma a un event-handler (un método que controla un evento).
     
  • No hacer uso de ninguna técnica resursiva, es decir evitar cualquier método o función recursiva, ya que inevitablemente la recursividad implica un desborde de la pila (o Stack Overflow).
     
  • No hacer uso del keyword GoTo ni por ende de los labels.
     
  • No utilizar los nombres internos de datatypes como por ejemplo [Int32] en lugar de Integer.
     
  • Muchas cosas más.
     



3. Aprender a utilizar las características de Visual Studio para detectar y corregir conflictos.

Aparte de la depuración con el uso de break points, la ventana de Autos, etc, Visual Studio tiene una herramienta llamada Code Analysis a la que puedes acceder en el menú Build -> Run Code Analysis,
como su propio nombre indica, sirve para analizar el código, y al analizarlo detectará y prevendrá posibles conflictos que se te hayan podido pasar por alto, como por ejemplo una fuga de memoria por un objeto sin liberar, un objeto que liberas más de una vez, o cosas tan específicas como un conflicto de portabilización (x86/x64) en una definición de un miembro de la API de Windows.

Es tan imprescindible para desarrollar un buen código como todo lo demás (igual que los tests de unidad), pero lamentablemente pocas personas le sacan provecho a la tan maravillosa IDE que tienen, Visual Studio.

Nota: Creo que esta herramienta no está disponible en las versiones Express y Community de Visual Studio, pero no estoy seguro. Yo uso VS2013 Ultimate, y VS2015 Profesional.

Otra cosa que podrías hacer ...aunque esto personálmente me parece MUY EXCESIVO excepto para proyectos comerciales, ni yo mismo lo practico generálmente, sería crear tests de unidad (o Unit Test).
Una unidad consiste en una porción de código, una porción puede ser una variable, un método individual o una class entera.
El test de unidad, digamos que sería una forma automatizada de llevar a cabo diversos análisis para determinar si las funcionalidades de tu código fuente realmente funcionan como es esperado.

Una buenísima herramienta para los tests de unidad es NCrunch.



4. Utilizar herramientas profesionales para corregir los errores de principiante (y de no tan principiante).

Siempre es bueno utilizar una especie de guía, maestro o ayudante en forma de herramienta digital, la cual te vaya indicando los errores que has cometido en tiempo real, y así aprender de ellos para la próxima vez,
mi herramienta o mejor dicho extensión favorita es Telerik JustCode, aunque hay otras extensiones muy buenas como ReSharper (exclusivamente para C#).



5. Refactorizar el código.

El término Refactorización (o Refactor) consiste en rediseñar un código/algoritmo para simplificarlo y/o para mejorarlo sin que el código pierda su funcionalidad, principalmente para conseguir hacer lo mismo en menos pasos o para aplicar buenas prácticas de programación a un código "feo", pero simplificar no siempre implica escribir menos.

Esto sería un ejemplo de un código que no ha pasado por la etapa de refactorización:
Código
  1. Dim value1 As Integer = 1
  2. Dim value2 As Integer = 2
  3. Dim value3 As Integer = 3
  4. Dim result As Integer = (value1 + value2 + value3)
  5.  
  6. MsgBox(value1 & "+" & value2 & "+" & value3 & " = " & result)

El código refactorizado (tener en cuenta que se le podría dar distintos enfoques):
Código
  1. Dim values As IEnumerable(Of Integer) = {1I, 2I, 3I}
  2. MessageBox.Show(String.Format("{0}={1}", String.Join("+", values), Enumerable.Sum(values)))



6. Desarrollar código rehusable.

Deberías tratar de transformar un código hardcodeado en código genérico, rehusable.
(aquí cuidado no confundir el término genérico o Generics, que tiene un significado distinto en lo que se refiere a los Types genéricos de un lenguaje de programación)

Es decir, tratar de evitar escribir un código que haga "X" funcionalidad específica solamente para el proyecto que estás desarrollando, la razón es muy sencilla, si en el futuro necesitas volver a desarrollar un código parecido, probablemente lo empezarás desde Cero otra vez, tal vez tomes ese antiguo código como referencia pero igualmente le harás cambios específicos, y eso se traduce en PERDER tiempo.

Ejemplo de un algoritmo sencillo el cual comprueba si una colección contiene un valor específico:
Código
  1. Dim values As String() = {"a", "b", "c", "d", "e"}
  2. Dim exists As Boolean = False
  3.  
  4. For Each value As String In values
  5.  
  6.    If value.Equals("C", StringComparison.OrdinalIgnoreCase) Then
  7.        exists = True
  8.        Exit For
  9.    End If
  10.  
  11. Next value

Como se puede comprobar, el código solo sirve para una colección de tipo String, todo está "pre-establecido" para que funcione así.

Ahora, este sería un ejemplo del mismo código o funcionalidad, refactorizada, documentada, genérica, y rehusable:
Código
  1. Dim exists As Boolean = {"a", "b", "c", "d", "e"}.Exists("C", StringComparer.OrdinalIgnoreCase)

Código
  1. #Region " Option Statements "
  2.  
  3. Option Strict On
  4. Option Explicit On
  5. Option Infer Off
  6.  
  7. #End Region
  8.  
  9. #Region " Imports "
  10.  
  11. Imports System
  12. Imports System.Linq
  13. Imports System.Diagnostics
  14. Imports System.Runtime.CompilerServices
  15.  
  16. #End Region
  17.  
  18. ''' <summary>
  19. ''' Contains custom extension methods applicable to <see cref="IEnumerable(Of T)"/>.
  20. ''' </summary>
  21. Public Module EnumerableExtensions
  22.  
  23. #Region " Public Extension Methods "
  24.  
  25.    ''' ------------------------------------------------------------------
  26.    ''' <summary>
  27.    ''' Determines whether the specified value exists inside the given collection.
  28.    ''' </summary>
  29.    ''' ------------------------------------------------------------------
  30.    ''' <typeparam name="T"></typeparam>
  31.    '''
  32.    ''' <param name="sender">
  33.    ''' The collection.
  34.    ''' </param>
  35.    '''
  36.    ''' <param name="find">
  37.    ''' The value to find.
  38.    ''' </param>
  39.    ''' ------------------------------------------------------------------
  40.    ''' <returns>
  41.    ''' <c>true</c> if value exists, <c>false</c> otherwise.
  42.    ''' </returns>
  43.    ''' ------------------------------------------------------------------
  44.    <Extension>
  45.    <DebuggerHidden>
  46.    <DebuggerStepThrough>
  47.    Public Function Exists(Of T)(ByVal sender As IEnumerable(Of T),
  48.                                 ByVal find As T,
  49.                                 ByVal comparer As IComparer(Of T)) As Boolean
  50.  
  51.        If (sender Is Nothing) Then
  52.            Throw New ArgumentNullException(paramName:="sender")
  53.  
  54.        Else
  55.            For Each value As T In sender
  56.  
  57.                If comparer.Compare(value, find) = 0 Then
  58.                    Return True
  59.                End If
  60.  
  61.            Next value
  62.  
  63.            Return False
  64.  
  65.        End If
  66.  
  67.    End Function
  68.  
  69. #End Region
  70.  
  71. End Module



7. Documentar el código fuente.

Ser un programador que documenta su trabajo otorga un mayor nivel de respeto o privilegio por aquello que haces de cara al interés o satisfacción del cliente o de las compañias informáticas, el esfuerzo se ve recompensado,
pero además, una razón igual de importante también, es que documentar te obliga a extender tus habilidades de programación, por que documentar un código en muchas ocasiones implica investigar, leer y aprender sobre aquello que estás llevando a cabo, por ejemplo si haces un copy/paste de un código que no entiendes ...pues así no aprendes nada, pero si intentas documentar ese código que no entiendes, probablemente llegarás a entenderlo de principio a fin con la suficiente dedicación,
por supuesto otra razón no menos importante es que mantener una buena documentación del código ...ya sea usando documentación XML o lineas de comentario, te ayudaría a recordar lo que hace un código que dejaste olvidado años atrás, lo que reduciría el tiempo necesario de refactorización o del tiempo invertido en programar en egeneral.

Se mire por donde se mira, la documentación es una práctica muy buena que te podrá llevar a otro nivel superior de entendimiento (bueno, quizás exagero un poco jaja) si la prácticas constantemente con mucha dedicación por lo que haces.

Hay muchas herramientas de terceros que te ayudarán a aplicar la documentación XML, como por ejemplo:
GhostDoc (tiene una versión gratuita, y realmente no necesitas más)
+
[SOURCE] Snippet Tool Extension For Visual Studio (C#/VB)



Vuelvo a repetir que hay muchas cosas más que se deberían mencionar como por ejemplo realizar Profillings de rendimiento y memoria, o todo lo que ha comentado el compañero @El Benjo, pero no se puede hablar sobre todo en un post ...ni en dos.

Creo que con todo esto que mencioné ya es suficiente por hoy, espero que algo de esto le sirva a quien lo lea, por que practicamente (casi) todo lo mencionado es aplicable a C# también.

Saludos!
« Última modificación: 27 Julio 2015, 17:34 pm por Eleкtro » En línea



OscarCadenas_91

Desconectado Desconectado

Mensajes: 27


Ver Perfil
Re: [Pregunta] Buenas Practicas de Programacion en VB.NET
« Respuesta #3 en: 28 Julio 2015, 18:21 pm »

 muchas gracias a los dos por responder.
@El Benjo:
      Crees que es mejor colocar las funciones en un modulo o en una Clase que diferencia hay.

@Eleкtro:
Gracias por los consejos, JustCode lo he descargado y se ve buena lastima que sea de pago
Sobre lo de realizar Profillings de rendimiento y memoria, como se lo Hace?
En línea

El Benjo


Desconectado Desconectado

Mensajes: 392



Ver Perfil WWW
Re: [Pregunta] Buenas Practicas de Programacion en VB.NET
« Respuesta #4 en: 28 Julio 2015, 20:05 pm »

Bueno, la diferencia es la manera en la que accedes a los miembros de la clase. Explico:

Los métodos, variables, propiedades, etc. declarados dentro de un módulo tienen un alcance global dentro del proyecto de manera predeterminada. Además, no puede haber instancias (objetos) del tipo de un módulo; las clases, por otro lado, necesitan ser instanciadas para usar sus métodos, propiedades, etc.

La MSDN explica mejor esto mismo: https://msdn.microsoft.com/es-es/library/7825002w(v=vs.90).aspx

Como dato adicional te puedo decir que puedes hacer que una clase se comporte de manera similar a un módulo si incluyes el modificador shared en una clase. La única diferencia que habría entre ésta y un módulo sería que para acceder a los elementos de la clase tendrías que escribir el nombre de la clase, un punto y el nombre del método, propiedad, variable, etc.
En línea

www.es.neftis-ai.com

Sí hay un mejor lenguaje de programación y es ese con el que puedes desarrollar tus objetivos.
Eleкtro
Ex-Staff
*
Desconectado Desconectado

Mensajes: 9.866



Ver Perfil
Re: [Pregunta] Buenas Practicas de Programacion en VB.NET
« Respuesta #5 en: 28 Julio 2015, 20:07 pm »

Crees que es mejor colocar las funciones en un modulo o en una Clase que diferencia hay.

Aunque la pregunta vaya dirigida a otra persona, te contestaré igual para despejar tu duda.

...¿Class o Module?, depende de tus necesidades.

Class
  • Permite herencia.
  • Permite instanciación.
  • Los miembros definidos existen solamente mientras la clase que contiene dichos miembros esté instanciada.
  • Los miembros públicos son accesibles unicamente desde la instancia del objeto, exceptuando algunos tipos de miembros públicos y cualquier miembro compartido (Shared) que son accesibles por cualquier otra clase o módulo del proyecto.
  • Se suele usar para encapsular todo tipo de miembros. Para casi todo en general.

Module
  • No permite herencia.
  • No permite instanciación.
  • Los miembros definidos existen todo el tiempo hasta que la aplicación finalice.
  • Los miembros públicos son globales, accesibles por cualquier otra clase o módulo del proyecto.
  • Se suele usar para exponer métodos y funciones públicas.

¿Conclusión?:
Yo te diría que generálmente utilices una Class, no un Module, excepto cuando realmente lo necesites por ejemplo para crear extensiones de método o para exponer un par de métodos y funciones que no requieran marear la perdíz instanciando una class, ya que de otro modo, si le dieses un uso muy frecuente a los módulos, entonces la visibilidad de los miembros definidos podría derivar de forma despistada en desambiguaciones de nombres con algún Namespace, aunque por otro lado, es algo que siempre puedes corregir.



JustCode ... lastima que sea de pago

Si, es una lástima ...siempre que no lo encuentres craqueado (es bien facil si buscas en Google).

Por ejemplo en este mismo foro:
Microsoft Visual Studio 2013 Ultimate + Resource Pack (Actualizado 09-Oct-2014) - By Elektro



Sobre lo de realizar Profillings de rendimiento y memoria, como se lo Hace?

Beginners Guide to Performance Profiling - MSDN
How To: Use CLR Profiler - MSDN

CLR Profiler for .NET Framework 4 - Microsoft Download Center
PerfView - Microsoft Download Center

Telerik Just-Trace
RedGate's ANTS Performance Profiler
RedGate's ANTS Memory Profiler

PD: Respecto a los profillers de Telerik y RedGate, ambas herramientas se pueden integrar en Visual Studio y también se distribuyen en versión standalone.

Saludos
« Última modificación: 28 Julio 2015, 20:09 pm por Eleкtro » En línea



Páginas: [1] Ir Arriba Respuesta Imprimir 

Ir a:  

Mensajes similares
Asunto Iniciado por Respuestas Vistas Último mensaje
Buenas practicas para mostrar contenido en web
PHP
Hadess_inf 1 2,456 Último mensaje 23 Abril 2012, 15:59 pm
por danicasasm
Aplicar POO en intranet - sugerencias de buenas practicas.
PHP
Hadess_inf 1 2,637 Último mensaje 13 Octubre 2012, 21:02 pm
por ~ Yoya ~
Buenas prácticas con C++ « 1 2 »
Programación C/C++
eferion 13 12,213 Último mensaje 19 Febrero 2014, 17:24 pm
por xaps
Sobre buenas prácticas de programación
Java
zonahurbana 3 3,495 Último mensaje 15 Marzo 2014, 02:47 am
por sapito169
Buenas prácticas para programar en php (Traducción)
PHP
alex171294 0 1,878 Último mensaje 22 Octubre 2014, 23:45 pm
por alex171294
WAP2 - Aviso Legal - Powered by SMF 1.1.21 | SMF © 2006-2008, Simple Machines