RSS

Asignaciones – Asignaciones, Widening, Cast

27 Sep

La operación de asignación nos sirve para dar valor a una variable.

La forma genérica de una asignación es la siguiente:
variable = valor;

Donde valor puede ser un literal, otra variable o una expresión.

El proceso de la asignación se realiza en dos fases. En primer lugar, se evalúa la parte derecha y se obtiene un valor. En segundo lugar, se asigna ese valor a la variable de la parte izquierda.

Literales

Ya comentamos que tenemos ocho tipos primitivos en Java: byte, short, int, long, float, double, char y boolean. Un literal es un valor concreto de un tipo.

Enteros
Se pueden representar utilizando una notación decimal, octal o hexadecimal.
15        formato decimal.
017      formato octal, el prefijo 0 indica un valor octal.
0xF     formato hexadecimal, el prefijo 0x indica un valor hexadecimal.

Un literal entero se considera por defecto de tipo int. Para indicar que queremos que sea de tipo long debemos acompañarlo de ‘l’ o ‘L’. Algunos literales enteros: 15, 320, 29999, 130000, 250L.

Reales
Un literal real se considera por defecto de tipo double. Para indicar que queremos que sea de tipo float debemos acompañarlo de ‘f’ o ‘F’. Algunos literales reales en coma flotante: 3.4, 1293.239, 150.23F.

Carácter
Un literal char se escribe entre comillas simples. Como son carácteres Unicode también se puede especificar el carácter en concreto por sus dígitos hexadecimales.
Algunos literales char: ‘b’, ‘z’, ‘\n’, ‘\t’, ‘\u003B’

Lógico
Los literales son false y true.


Expresiones

Es frecuente que nos encontremos expresiones en la que participan diferentes tipos de datos. Algunos tipos de datos pueden ser compatibles (enteros con caracteres p.e),  mientras que otros no (enteros con reales).

Los booleanos no son compatibles con ningún otro tipo de dato.

En las expresiones con datos enteros el resultado será al menos un int o el tipo del mayor operando de la expresión.

byte a = 10;
byte b = 20;
byte c  = (a + b) * 0.5; //El resultado de (a+b) * 0.5 es de tipo double.

En este caso el compilador generará un error, se necesita una conversión.
En Java las conversiones pueden ser implícitas o explícitas.

Conversión Implícita (Widening)

Se produce cuando los tipos son compatibles y Java realiza la conversión de forma automática.
Siempre es posible asignar un valor de un tipo más pequeño en una variable de un tipo mayor.

Grande = Pequeño; //OK

 long a = 100;  //100 al ser un literal entero, es de tipo int.

No hay problema en guardar este valor en una variable long. La conversión es automática.

Conversión Explícita (Cast)

Cuando los tipos son incompatibles o existe la posibilidad de perder información en una asignación, el compilador dará un error pidiendo que se confirme esa asignación con una conversión explícita.

Pequeño = Grande; //ERROR

int a = 100L; //ERROR 100L es un literal de tipo long y se quiere asignar a una variable int.
int a = (int) 100L; // OK

El compilador generará error. Como sabemos que en la asignación no hay peligro de perder información al
caber 100 perfectamente en un int, convertimos explícitamente.


Casos Posibles de Asignaciones

    • Asignación de Iguales: Se produce cuando el tipo del valor a asignar coincide con el tipo de la variable. En esta situación no hay ningún problema.
      char c = 'a';
      int entero = 100;
      int suma = entero + 25;
      double precio = 950.283;
      boolean indCerrado = false;
      

En estas asignaciones es necesario ningún tipo de conversión.

    • Conversión de ampliación (Widening): Ocurre cuando el tipo del valor a asignar es más pequeño que el tipo de la variable.
      //grande = pequeño;  //OK
      int a = 150;  //Declaramos un entero
      long var = a; //La variable a se puede asignar al long var, ya que vamos de pequeño a grande.
      double b = 15.3f * var;
      

Cualquier expresión entera siempre se podrá asignar a una variable double, ya que es el mayor tipo entero.

  • Conversión de reducción (Narrowing): Ocurre cuando el tipo del valor a asignar es más grande que el tipo de la variable. Es necesaria la conversión explícita.
    //pequeño = grande; //ERROR
    //pequeño = (pequeño) grande; //OK
    
    long grande = 5500L;
    int pequeño = (int) grande; //Es necesario hacer un casting a int.
    
    byte primero = 5;
    byte segundo = 20;
    byte suma = (byte) (primero + segundo); //La suma de dos bytes es un int, por lo tanto necesita
    //un casting a byte.
    
    • Excepción:
      Cuando el valor a asignar es una expresión onstante de tipo byte, short, char o int el
      compilador hace la conversión automáticamente. Esto se llama compile-time narrowing of constants:

      byte auto = 10; //OK, no hace falta hacer byte auto = (byte) 10;
      

      Si la variable a asignar es final y “cabe” en el destino no es necesario casting:

      final short prueba = 100;
      byte destino = prueba; //OK
      
      final short prueba = 300; //sobrepasa el valor posible para los byte.
      byte destino = prueba; //ERROR: possible loss of precision
      
    • Nota:
      Aunque tengamos un valor real que pueda caber en un “float” y lo queremos asignar a un
      double, siempre será necesario el sufijo o el casting:

      float f = 500.7; //ERROR
      float f = 500.7f; //OK
      float f = (float) 500.7; //OK
      
  • Conversión de Tipos de Referencia:Se puede asignar a un tipo menos especializado un tipo más especializado en la jerarquía.Padre = Hijo //OK
    Persona pe = new Programador();
    

    Esto es posible porque un objeto hijo (más especializado) puede hacer todo lo que haga el
    padre (menos especializado) pero no al revés.

    Hijo = Padre //ERROR

    Programador pro = new Persona(); //ERROR
    
Anuncios
 
6 comentarios

Publicado por en 27 septiembre, 2011 en Estudio, Tema 3

 

Etiquetas: , , , , ,

6 Respuestas a “Asignaciones – Asignaciones, Widening, Cast

  1. Victor

    20 noviembre, 2014 at 12:07 am

    que buen aporte edgar calderon.

     
  2. Freddy Moran

    5 febrero, 2013 at 7:15 pm

    Estoy queriendo certificarme pero aún siento que no estoy 100% listo, estoy siguiendo tu blog como guía, tiene muchos apuntes muy útiles, ya te contare como me va con el examen.

    Saludos.

     
    • Virginia Lopez Fernandez

      15 febrero, 2013 at 12:47 pm

      Antes de ir al examen procura hacer todos los tests y exámenes que encuentres. Sigue preparándote y no te desanimes, seguro que la apruebas!

      Un saludo!

       
  3. Edgar Calderon

    17 junio, 2012 at 1:49 am

    Se me olvidaba agradecerte por este blog.

    Muchas gracias por tu aporte.

    Saludos desde Colombia

     
    • Virginia Lopez

      17 junio, 2012 at 11:43 am

      Hola Edgar, es cierto. Está equivocado, creo que me refería a float en lugar de double.
      Lo corrijo, gracias! Espero que te vaya bien con la certificación.
      Un saludo!!

       
  4. Edgar Calderon

    17 junio, 2012 at 1:45 am

    Hola Virginia
    Creo que en la Nota donde hablas de los float y double hay un error, Java considera a los literales con decimales como double por defecto y no habria ningun problema asignar 500.7 a la variable double f

     

Responder

Introduce tus datos o haz clic en un icono para iniciar sesión:

Logo de WordPress.com

Estás comentando usando tu cuenta de WordPress.com. Cerrar sesión / Cambiar )

Imagen de Twitter

Estás comentando usando tu cuenta de Twitter. Cerrar sesión / Cambiar )

Foto de Facebook

Estás comentando usando tu cuenta de Facebook. Cerrar sesión / Cambiar )

Google+ photo

Estás comentando usando tu cuenta de Google+. Cerrar sesión / Cambiar )

Conectando a %s

 
A %d blogueros les gusta esto: