Monthly Archives: March 2009

Microsoft IE8 (Test)

Después de pasar por un instalador demasiado microsofitado (desea instalar el paquete tal, el software pascual, etc) llegamos a la parte de reiniciar el sistema (por prescripción informática) y tachan!!! Ya podemos jugar con el nuevo IE 8. De buenas a primera el interfaz (sobre XP) es muy parecido a su predecesor en el cargo. Se puede apreciar algún ligero cambio en la barra de direcciones (las direcciones URL se resaltan en negrita a excepción del protcolo (http://), las w y algo más). En cuanto a la navegación, lo primero que hice fué visitar esta gran tierra en Internet (Riders Of The Bit) y directamente fuí a pasar el test Acid 3. Y que sorpresa la mia… un 20 sobre 100 juas, juas me parto. En estos mometos el Firefox con el que estoy trabajando obtiene un 70 sobre 100. En este punto decidí parar la fase de test y esperar a que los chicos de Redmond acaben su trabajo y no entregen una RC cuando todavía deberia estar en fase Beta.

Microsoft IE8 final code

Según se puede leer en ComputerWorld, durante el día de hoy (9:00 pm hora local en Redmond) Microsoft lanzará la primera versión, no beta, de su nuevo explorador IE8.  Desde ROTB estaremos atentos para probar esta nueva versión del popular navegador Internet Explorer y ver que beneficios aporta y a que “precio”.

Interfaces Comparator y Comparable (y III)

Ya hace más de dos meses que debería haber publicado este post pero como sabeis el tiempo es un bien escaso y entre unas cosas y otras no he podido preparar el código hasta ahora.

Bueno al código! En esta última parte utilizaremos el interfaz Comparator para crear clases específicas para ordenar. Siguiendo el hilo de los anteriores posts he creado una clase para ordenar Personas por edad y otra para ordenar por altura. Por si solas no tendrían mucho sentido pero al implementar Comparator podremos utilizarlas para fijar la ordenación en diferentes estructuras de datos como vectores, listas, etc.

La primera clase es OrdenarPersonaPorEdad y al implementar Comparator hay que implementar (o sobrecargar :-P) los métodos compare(…) y equals(…). Sobre este último comentar que según la documentación de Sun habría que comprobar que realmente los criterios de comparación son los mismos. Pero en la práctica únicamente se comprueba que se está utilizando el mismo objeto; this y obj hacen referencia al mismo objeto.

Como en la clase Persona se utilizó Integer para la edad y la altura, ahora únicamente deberemos utilizar el métode compareTo(..) de Integer, lo que simplifica el diseño y el ejemplo.

import java.util.Comparator;
 
public class OrdenarPersonaPorEdad implements Comparator {
    /**
      * Return a negative integer,
      * zero, or a positive integer as
      * this object is less than, equal to,
      * or greater than the specified object.
      */
    public int compare(Persona p1, Persona p2) {
        return p1.getEdad().compareTo(p2.getEdad());
    }
 
    public boolean equals(Object obj) {
        return this == obj;
    }
}

Aquí podemos ver el código para la clase que comparará por altura. Como apunte, si recordamos la segunda parte del artículo, dónde se multiplicaba por -1 el resultado de compareTo(..) para devolver el orden inverso, aquí podríamos utilizarlo de la misma forma.

import java.util.Comparator;
 
public class OrdenarPersonaPorAltura implements Comparator {
    /**
      * Return a negative integer,
      * zero, or a positive integer as
      * this object is less than, equal to,
      * or greater than the specified object.
      */
    public int compare(Persona p1, Persona p2) {
        return p1.getAltura().compareTo(p2.getAltura());
    }
 
    public boolean equals(Object obj) {
        return this == obj;
    }
}

Y como el código de la clase para probar los dos comparadores con un Vector.

import java.util.Vector;
import java.util.Iterator;
import java.util.Collections;
 
public class Test {
    /**
      * Main para probar la clase.
      */
    public static void main(String[] args) {
        // Franc
	Persona franc = new Persona("Franc", 38, 1.77);
	// Rosa
	Persona rosa = new Persona("Rosa", 29, 1.98);
	// Maite
	Persona maite = new Persona("Maite", 37, 1.78);
 
	// Creo una comunidad de personas.
	Vector miComunidad = new Vector();
	miComunidad.add(franc);
	miComunidad.add(rosa);
	miComunidad.add(maite);
 
	// Ordeno por edad la comunidad de personas.
	Collections.sort(miComunidad, new OrdenarPersonaPorEdad());
 
	// Ya se puede listar la comunidad ordenada por edad.
	Iterator personaIter = miComunidad.iterator();
	System.out.println("Comunidad ordenada por edad.");
	while (personaIter.hasNext())
	    System.out.println(personaIter.next());
 
        // Ordeno por altura la comunidad de personas.
	Collections.sort(miComunidad, new OrdenarPersonaPorAltura());
 
	// Ya se puede listar la comunidad ordenada por altura.
        personaIter = miComunidad.iterator();
	System.out.println("Comunidad ordenada por altura.");
	while (personaIter.hasNext())
	    System.out.println(personaIter.next());
    }
}

Resultado de la ejecución:

Comunidad ordenada por edad.
Me llamo Rosa, tengo 29 y mi altura es 1.98
Me llamo Maite, tengo 37 y mi altura es 1.78
Me llamo Franc, tengo 38 y mi altura es 1.77

Comunidad ordenada por altura.
Me llamo Franc, tengo 38 y mi altura es 1.77
Me llamo Maite, tengo 37 y mi altura es 1.78
Me llamo Rosa, tengo 29 y mi altura es 1.98

Como podéis ver el uso de Comparator simplifica en muchas ocasiones la tarea de ordenar un Vector (por ejemplo). Tener presente este interfaz, así como el interfaz Comparable, a la hora de diseñar una aplicación puede ahorrar mucho código y simplificar futuras modificaciones, mejoras, etc.

Espero que esta serie de artículos sobre los interfaces de comparación que ofrece Java os halla gustado y os ayude en el futuro.