Pregunta Personal Programador JAVA!

Iniciado por ChavalChavito, 2 Agosto 2012, 01:50 AM

0 Miembros y 1 Visitante están viendo este tema.

ChavalChavito

Primero que todo muchas gracias x leer el post.
Eventualmente me siento muy disconforme con mi conocimiento como programador, a pesar q yo siempre intento superarme. Me pasa muy seguido que me nombran tecnologias y terminos q no comprendo, leo muchos codigos que no entiendo, o peoor inclusive leo codigo q hice yo mismo y paso considerable tiempo para volver a comprenderlo.
Nose si esto es gral y compartido x todos los programadores o solo es un rasgo mio...
Perdon x el tema del post se q no tiene nada q ver !

[Case]

Eso es muy normal, por eso siempre hay que documentar bien tu propio codigo.

sapito169

 ;-) ;-) ;-) ;-)

lo que no es normal es que te intereses la mayoría de los programadores son unos incompetentes que crean código imposible de entender y jamas se interesan en eso

la mayoría ni-siquiera sabe que escriben código horrendo es mas en la mayoría de los casos no lo hacen por desinterés o por que piensan que es la manera normal de trabajar

la mayoría no solo programa mal lo peor es que no saben que lo hacen.para ello todo es normal

te felicito que reconozcas en que estas mal y que te interese hacer tu trabajo bien yo te cuento que casi en todos los casos es todo lo contrario

sapito169

#3
aprende ingles usa los dicionarios ensiclopedias libros pregunta usa google wikipedia


Aprende ingles

Toda la documentación de java esta en ingles la mayoría de los libros están en inglés, todo el lenguaje java esta en ingles

estamos en el siglo 21 y me dises que no sabes de que no entiendes el lenguaje usa el maldito google averigua las cosas por tu cuenta se autodidacta tienes libros tienes enciclopedistas tienes diccionarios tienes internet estamos en el siglo donde la información es facil de obtener no puedes decir que no sabes que significan las cosas tienes wikipedia tienes google antes de decir cualquier cosa googlea

sapito169

#4
Para que escribas codigo que tu mismo entiendas
los Nombres deben ser
-largos y obvios es decir auto descriptivos simples y revelar su intencion estar en el idioma del que habla
-deben ser obvio de que clase representan
evitar
abreviatura,tecnicismo,No neologismo,No arcaismos,No Jergas,No siglas,No supresión de letras
-no uses prefijos ni sufijos

malos nombres
Código (java) [Seleccionar]

int x=3;//no revela su intencioa
int y=14;
fecNac=new Date();//suprime letras
Per p=new Per();//solo es una letra
String PerName="juan";//usa abreviatura
double weight=14.5;//esta en ingles pero yo escribo para gente que habla español
String jato="av victoria 511";//jato es jerga
String aka="corasonsito511";//aka es abreviatura y neologismo
String suMerced="juan";//arcaismo
String SEP ="Secretaría de Educación Pública";//solo lo entienden los mejicanos y es abreviatura
Date dfechaDeNacimiento=new Date;//eso es para dejar bien en claro que la fecha de nacimiento es de tipo fecha estoy siguiendo unos estandares estupidos que me fuersan a usar sufijos cuando un buen nombre basta


buenos nombres

Código (java) [Seleccionar]

int cantidadDePersonas=3;//me importa un comino de que el nombre sea largo
Date fechaDeNacimiento=new Date();//el nombre revela cual es su intención no necesito poner una de adelanta para decir que es de tipo fecha
Persona persona=new Persona();//eligo el nombre largo y descriptivo no uso abreviaturas es obvio que la variable persona es de tipo persona
Double peso=new Double(); //es obvio que peso es decimal nadie pensario que peso  es de tipo Cadena o de tipo Date  



En caso de que exista un nombre corto que sea sinonimo y que sea mas corto y que no cambie en nada el sentido que quieres expesar úsalo pero siempre prefiere los nombres largo si es mas legible

Los métodos
-esto es muy controversial deben ser extremadamente cortos
-los métodos que llaman otros metodos deben estar en la parte superior
-los metodos mas especificos deben estar en la parte inferior
-si un metodo llama a otro el metodo que es llamado debe estar en la parte inferior del que lo llama
-si sigues los consejos anteriores debes poder leer de arriba abajo en la parte superior los métodos mas globales y en la parte inferior los métodos mas específicos.No necesitaras leer los métodos que están mas abajo por que tienes la opción de considerarlo demasiado detalle

un ejemplo de clase con malos nombres y con métodos desordenados


Código (java) [Seleccionar]

package com.ejemplo;

public class MalEcho {

   public static void main(String arg[]) {

       double[] x = new double[50];
       int[] y= new int[50];
       sum(x, y);
       
       double z=0;
       z = tot(z, x, y);
       System.out.print(z);
   }

   private static double tot(double z, double[] x, int[] y) {
       for(int c=0;c<=3;c++){
           z=z+x[c]*y[c];
       }
       return z;
   }

   private static void sum(double[] x, int[] y) {
       x[0]=20;
       x[1]=50;
       x[2]=30;
       
       
       
       y[0]=1;
       y[1]=1;
       y[2]=1;
   }
}



y aca la version con mejores nombres tambien date cuenta que pongo los metodos en orden como dentro del main primero lleno las variables entonces escribo despues del main el metodo llenarVariables

Código (java) [Seleccionar]

package com.ejemplo;

public class Regular {

   public static void main(String arg[]) {

       double[] precios = new double[50];
       int[] cantidades = new int[50];
       llenarVariables(precios, cantidades);

       double respuesta = 0;
       respuesta = obtenerTotal(respuesta, precios, cantidades);
       System.out.print(respuesta);
   }

   private static void llenarVariables(double[] presios, int[] cantidades) {
       presios[0] = 20;
       presios[1] = 50;
       presios[2] = 30;



       cantidades[0] = 1;
       cantidades[1] = 1;
       cantidades[2] = 1;
   }

   private static double obtenerTotal(double respuesta, double[] precios, int[] cantidades) {
       for (int indice = 0; indice <= 3; indice++) {
           respuesta = respuesta + precios[indice] * cantidades[indice];
       }
       return respuesta;
   }
}
       
       
       
       cantidades[0]=1;
       cantidades[1]=1;
       cantidades[2]=1;
   }
}




Comentarios

-no pongas comentarios obvios borra todos los comentarios generados por el ide

Código (java) [Seleccionar]

//creo esta clase para mostrar un ejemplo
//esta clase tiene muchos comentarios

/*
* To change this template, choose Tools | Templates
* and open the template in the editor.
*/
//esto es un paquete
package com.ejemplo;

/**
*
* @author luis
*/
//esto es una clase publica
public class NewClass {

   //esto es una variable global
   int a;

   //esta variable es privada
   private String b;
   
   //esto es un construcor
   public NewClass() {
   }
   
   
   
}



-jamas tengas código comentado esta practica es de las peores  el código comentado es inútil.
Algunos dirán que pueden necesitar el código eso es falso si realmente lo necesitas en primer lugar para que lo tienes comentado
Otros dirán que lo van a necesitar luego eso es falso por que si lo necesita deben estar en su propia clase separada o dentro de un método
Otros dirán que tiene miedo a borrar el código eso es falso por que lo puedes tener  en el control de versiones te juro que no se va a perder
Otros dirán que es para reutilizar código en ese caso dejo de escucharlo si no consigo que lo despidan yo renuncio

-no comentes codigo es una horrible practica en ves de poner comentarios reescribe el código hasta que no necesites comentarios usando métodos cortos privados y buenos nombres

la misma clase sin seguir estas normas

Código (java) [Seleccionar]

package com.ejemplo;

public class Regular {
//este es el main

   public static void m(String arg[]) {
//este es el precio
       double[] p = new double[50];
       //esta el la cantidad
       int[] c = new int[50];

       //a qui lleno las variables
       p[0] = 20;
       p[1] = 50;
       p[2] = 30;
       c[0] = 1;
       c[1] = 1;
       c[2] = 1;

       double respuesta = 0;
       //a qui obtengo el total
       for (int indice = 0; indice <= 3; indice++) {
           respuesta = respuesta + p[indice] * c[indice];
       }
       respuesta = respuesta;
       System.out.print(respuesta);
   }
}



convenciones

esto es simple NO CREES TU PROPIA CONVENCION la única convension es la sun coding convension no existe otra convencion valida  >:(

Usa orientacion a objetos

clase =sustantivo singular
Interfase=sustantivo singular o adjetivo
metodos = verbos
las variables gloabales son sustantivos
extends o implements =representacion la relasion de es un ,es un subtipo

una clase persona

Código (java) [Seleccionar]

package com.ejemplo;

import java.util.Date;

public class Persona {

   private String nombre;
   private double salario;
   private Date fechaDeNacimiento;
   private String direcion;

   public Persona(String nombre, double salario, Date fechaDeNacimiento, String direcion) {
       this.nombre = nombre;
       this.salario = salario;
       this.fechaDeNacimiento = fechaDeNacimiento;
       this.direcion = direcion;
   }

   public Persona() {
   }

   public String getDirecion() {
       return direcion;
   }

   public void setDirecion(String direcion) {
       this.direcion = direcion;
   }

   public Date getFechaDeNacimiento() {
       return fechaDeNacimiento;
   }

   public void setFechaDeNacimiento(Date fechaDeNacimiento) {
       this.fechaDeNacimiento = fechaDeNacimiento;
   }

   public String getNombre() {
       return nombre;
   }

   public void setNombre(String nombre) {
       this.nombre = nombre;
   }

   public double getSalario() {
       return salario;
   }

   public void setSalario(double salario) {
       this.salario = salario;
   }
}




herencia y implementacion

Código (java) [Seleccionar]

package com.ejemplo;

public class Factura extends Documento implements Imprimible {

   @Override
   public void imprimir() {
   }
}



Código (java) [Seleccionar]


public class Main {

   public static void main(String arg[]) {
       Documento documento = new Factura();
   }
 
}



Tu codigo debe ser pronusiable debe leerse como español eso se logra siguendo todas las reglas ejemplo

Código (java) [Seleccionar]

public void presionoBotonGuardar(){

Orden orden =leerDesdeElFormulario();
       BaseDeDatos baseDeDatos =new BaseDeDatos();
       if(orden.puedeGurdarseEnBaseDeDatos()){
           baseDeDatos.guardar(orden);        
       }
       else{
           JOptionPane.showMessageDialog(null, "no se puede guardar la orden ");
       }
}


sigue todas las reglas hasta que:
tu código pueda leerse de arriba abajo sin tener que saltar la vista a la parte superior de la clase para eso ponemos los métodos mas generales arriba y si ese método llama a otro método pues ponlo inmediatamente abajo cosa que se lea de corrido sin saltar a la parte superior.
Tus ojos no deben saltar a la parte superior para ver el tipo de datos por que el nombre deja obvio que tipo de dato es
tu no debes buscar comentarios por que el nombre de los métodos dicen todo lo que necesitas saber
en caso de querer comentar un pedazo de código pues en ves de comentarlo ponlo dentro de un método privado con un buen nombre



sapito169

#5
-usa la orientación a objetos para ordenar el código
por ejemplo si te preguntas donde esta la programación de una orden de compra pues en la clase orden de compra si quieres saber donde esta la programación del formulario de la Caja pues en la clase FrmCaja si te preguntas donde esta la programación de la linea de una Orden  pues debe estar en la clase LineaDeOrden
si quieres saber donde esta el total de una orden pues en el método total de la clase orden

-recuerdas para reflejar que una clase tiene relacion de multiplisidad usa Arraylist

-un metodo no puede tener efectos secundarios es decir no puede cambiar de varias formas una clase si el nombre de un metodo dise agregarLinea pues la unica  operacion es agregar una linea a la orden

-solo pueden existir dos tipos de metodo los que cambien el estado de una clase y los que obtiene alguna propiedad calculada de una clase por ejemplo un metodo que cambia el estado de la clase Orden seria agregar linea y otro metodo que obtenga la proíedad total seria obtenertotal

-un metodo no puede cambiar el estado y dar una respuesta al mismo tiempo

-las clases deben seguir las 3 formas normales al igual que las tablas de una base de datos


un ejemplo de la clase anterior con todas las correcciones


Código (java) [Seleccionar]

Orden orden = new Orden();
orden.agrega(new Linea(2, "litro gaseosa", 14.5));
orden.agrega(new Linea(1, "1/4 de pollo", 10));
orden.agrega(new Linea(3, "churrasco a lo pobre", 25));
System.out.println("El total de la orden es: " + orden.obtenerTotal());
System.out.println("El la cantidad de lineas es:" +orden.obtenerCantidadDeLineas());




con el siguiente ejemplo ya sabes que hace y no es necesario que leas el resto de las clases puedes simplemente suponer que esta bien

de todas maneras te paso la clase

Código (java) [Seleccionar]


import java.util.ArrayList;
import java.util.List;

public class Orden {
private List<Linea> lineas = new ArrayList<Linea>();

public void agrega(Linea linea) {
lineas.add(linea);

}

public double obtenerTotal() {
double total=0;

for (Linea linea : lineas) {
total =total+linea.obtnerTotal();
}
return total;
}

public int obtenerCantidadDeLineas() {

return lineas.size();
}

}


Código (java) [Seleccionar]



public class Linea {
private int cantidad;
private String nombrePlato;
double precio;



public Linea(int cantidad, String nombrePlato, double precio) {
this.cantidad = cantidad;
this.nombrePlato = nombrePlato;
this.precio = precio;
}

public double obtnerTotal() {

return precio*cantidad;
}

}


fuersa el lenguaje usando impor static y retornando this el metodos que modifique en el estado
puedes forsar el lenguaje para que tengas propiedades con nombre

solo hazlo con gente con experiensia regular

ejemplo

Código (java) [Seleccionar]

package com.ejemplo;

import static com.ejemplo.Linea.*;
import static com.ejemplo.Orden.*;
public class Main {

public static void main(String[] args) {
Orden orden = orden()
.con(linea(cantidad(1), "litro gaseosa", precio(14.5)))
.con(linea(cantidad(1), "1/4 de pollo", precio(10)))
.con(linea(cantidad(3), "churrasco a lo pobre", precio(25)));
System.out.println("El total de la orden es: " + orden.total());
System.out.println("La cantidad de lineas es: "
+ orden.cantidadDeLineas());
}
}




Código (java) [Seleccionar]


package com.ejemplo;
import java.util.ArrayList;
import java.util.List;

public class Orden {
private List<Linea> lineas = new ArrayList<Linea>();

public Orden con(Linea linea) {
lineas.add(linea);
return this;
}

public static Orden orden(){
return new Orden();
}
public double total() {
double total=0;

for (Linea linea : lineas) {
total =total+linea.obtnerTotal();
}
return total;
}

public int cantidadDeLineas() {

return lineas.size();
}

}


Código (java) [Seleccionar]

package com.ejemplo;

public class Linea {
private int cantidad;
private String nombrePlato;
double precio;

private  Linea(int cantidad, String nombrePlato, double precio) {
this.cantidad = cantidad;
this.nombrePlato = nombrePlato;
this.precio = precio;
}

public Linea(CantidadDePlatos cantidadDePlatos, String nombrePlato,
PrecioPlato precioPlato) {
this(cantidadDePlatos.cantidad, nombrePlato, precioPlato.precio);
}

public double obtnerTotal() {

return precio * cantidad;
}

public static PrecioPlato precio(double precio) {
return new PrecioPlato(precio);
}

public static CantidadDePlatos cantidad(int cantidad) {
return new CantidadDePlatos(cantidad);
}

public static Linea linea(CantidadDePlatos cantidadDePlatos,
String nombrePlato, PrecioPlato precioPlato) {
return new Linea(cantidadDePlatos, nombrePlato, precioPlato);
}

static class PrecioPlato {
double precio;

public PrecioPlato(double precio) {
this.precio = precio;
}

}

static class CantidadDePlatos {
int cantidad;

public CantidadDePlatos(int cantidad) {
this.cantidad = cantidad;
}

}

}




por favor por favor por favor respondan me no me importa si es para decirme que soy troll  pero dignamente algo porfavor no me ignoren
porfavor respondan me no dejes que me deprima

leogtz

Cita de: ChavalChavito en  2 Agosto 2012, 01:50 AM
Primero que todo muchas gracias x leer el post.
Eventualmente me siento muy disconforme con mi conocimiento como programador, a pesar q yo siempre intento superarme. Me pasa muy seguido que me nombran tecnologias y terminos q no comprendo, leo muchos codigos que no entiendo, o peoor inclusive leo codigo q hice yo mismo y paso considerable tiempo para volver a comprenderlo.
Nose si esto es gral y compartido x todos los programadores o solo es un rasgo mio...
Perdon x el tema del post se q no tiene nada q ver !

A todos nos pasa lo mismo, no te preocupes, sin embargo debes de tener muy en cuenta la documentación, si vas a programas cosas algo complicadas debes por lo menos escribir algunos comentarios de qué es lo que hace esa parte de código, unas ligeras líneas o incluso sólo una línea.

Ahora, la parte intricada podría ayudarse a explicar así misma sólo por los identificadores, lo cual es también de mucha importancia, si estás en Java sigue la notación "camelcase", ejemplo:

Código (java) [Seleccionar]
int numeroResultadosAfiliacion = 0;

Es preferible que utilices identificadores largos a que los cortes y pierdan algo de su significado.

Otra cosa son los javadoc, es una potente herramienta para documentar, aprende a utilizarla.

Saludos.
Código (perl) [Seleccionar]

(( 1 / 0 )) &> /dev/null || {
echo -e "stderrrrrrrrrrrrrrrrrrr";
}

http://leonardogtzr.wordpress.com/
leogutierrezramirez@gmail.com

sapito169

mmmmmmm

el punto que quiero dejar claro es que debes escoger tan bien los nombres que la documentación sea redundate e innecesaria