Calcular diferencias en días entre dos fechas

Estimados

Me presentaron el siguiente problema en el trabajo calcular entre dos fecha cual seria la diferencia en días de ambas.

Ejemplo :

public static void main(String[] args) {
// Crear una fecha new Date( 2010, 12, 11 ); Esta deprecada
Calendar cal = Calendar.getInstance();
cal.set(Calendar.DATE, 1);
// Enero = 0, asi que Diciembre = 11
cal.set(Calendar.MONTH, 11);
cal.set(Calendar.YEAR, 2010);

Date fecha1 = cal.getTime();
Date fecha2 = new Date();

Long dif = difDiasEntre2fechas( fecha1 , fecha2 );

System.out.println( "Dif " + dif );

}

/*
* getTime() Returns the number of milliseconds since
* January 1, 1970, 00:00:00 GMT represented by this Date object.
* http://download.oracle.com/javase/1.4.2/docs/api/java/util/Date.html#getTime()
* Ciendo Mayo fecha2
*/
public static long difDiasEntre2fechas( Date fecha1 , Date fecha2 ){

long difms = fecha2.getTime() - fecha1.getTime();
long difd=difms / (1000 * 60 * 60 * 24);

return difd;
}

Espero que les sea de utilidad.

Ahora si tienen un ejemplo mejor agradecería que me la envíen Saludos.

Tengo Prueba Jajaaaa..

Tengo una prueba lo bueno de estas pruebas es que me obligan a estudiar o repasar algunos conceptos por ejemplo en la prueba no pueden faltar las preguntas :

¿Qué es un interface?

¿Diferencias entre un interface y una clase abstracta?

interface Cloneable (Simple y compuesto)

¿Diferencias entre Runnable y Thread?

¿Defina que hace un método synchronizable?

Describa de ServletContext

Bueno también tendrán que mostrarme un ERROR. (Alguna Exception)

Espero que no me pidan hacer un modelo de objetos.



Por ahora voy a dejar esas no mas, ya que estoy en el terminal de buses. y por hoy se me ocurren esas no mas. :D

Saludos.

Distancia de Levenshtein [código]



La distancia de Levenshtein es una herramienta muy potente y aplicada en diferentes correctores ortograficos de editores de texto. La distancia de Levenshtein, que también es conocida como la generalización de la distancia de Hamming, determina la medida de similitud entre dos cadenas de caracteres.


Este algoritmo fue propuesto por Vladimir Levenshtein en 1965 y desde entonces ha sido ampliamente usado para realizar el matching entre cadenas de caracteres con diferente longitud.

La implementación eficiente de éste algoritmo requiere del uso de la programación dinámica puesto que implementa el uso de una matriz de tamaño (n + 1) × (m + 1), donde n y m son las longitudes de los cadenas que se comparan. Su implementación es sencilla y se las presento a continuación. (Esto no lo escribí yo, es un copi paste lo deje así ya esta clara la reseña sobre distancia de Levenshtein lo copie de aqui)

Un ejemplo en java desarrollado con netbeans.
http://www.2shared.com/file/oG5kzucg/Levenshteintar.html

Ahora mas fácil aun encontraran en la api de apache common land la clase StringUtils esta clase tiene un método getLevenshteinDistance

http://commons.apache.org/lang/api-release/org/apache/commons/lang/StringUtils.html#getLevenshteinDistance%28java.lang.String,%20java.lang.String%29

Sobre este tema hay mucha más información por ejemplo :

http://en.wikibooks.org/wiki/Algorithm_implementation/Strings/Levenshtein_distance
http://es.wikipedia.org/wiki/Distancia_de_Levenshtein
http://jc-info.blogspot.com/2009/03/distancia-de-levenshtein-codigo.html