Ir al contenido principal

Instrucciones de control

A continuación se presenta un ejemplo, con los diferentes usos para estructuras condicionales y de iteración.
El ejemplo es totalmente funcional y nos muestra en el método "ifCondicionalStatement()" las  instrucciones condicionales, las diferentes formas de utilizar la sentencia, if, else, switch y una forma opcional de implementar un switch con un mapa, con la ventaja de poder switchear valores mas alla de los primitivos. El método "iterateStatement()" contiene diferentes ejemplo para utilizar, while, for, además de instrucciones como; continue, break, etc.

package com.avventa.training.java.class4;

import java.util.Arrays;
import java.util.HashMap;
import java.util.Map;

public class ControlStatements {

public static void main(String[] args) {
System.out.println("** ifCondicionalStatement **");
ifCondicionalStatement();
System.out.println("** iterateStatement **");
iterateStatement();
}
/**
* Some examples of conditional statement: 
* Basic statement:
* if ([conditional]) {
*   
*   // do something
* }
*/
public static void ifCondicionalStatement () {
int i = 10;
int j = 20;
// Basic statement
if (i == 10) {
System.out.println("i is 10!");
}
// Two conditional statements and else.
if ( (i != 10) || 
(j == 20)) {
System.out.println("i != 10 or j == 10");
} else {
if (i == 10) {
System.out.println("i is 10 in the else statement");
}
}
// setting and conditional comparation.
if ((i = i + j) == 30) {
System.out.println(" i == 30 ");
}
switch (i) {
case 1:
System.out.println(" case 1 ");
break;
case 10:
System.out.println(" case 10 ");
break;
default:
System.out.println(" Default ");
break;
}
// Map instead of switch.
Map switchMap = new HashMap ();
i = 0;
switchMap.put(i++, " case 1 ");
switchMap.put(i++, " case 2 ");
i = 1;
System.out.println("switchMap.get(i) = " + switchMap.get(i));
} // ifCondicionalStatement.
public static void iterateStatement () {
String [] stringArray = new String [] {"one", "two", "three", "four"};
int index = 0;
System.out.println("while statement\n");
// while statement.
while (index <= stringArray.length) {
System.out.println("index = " + index);
if (index % 2 == 0) {
System.out.println("Doing continue with index = " + index);
index += 1;
continue;
}
index += 1;
}
System.out.println("do ... while\n");
// do ... while.
index = 0;
do {
System.out.println("index = " + index);
if (index > (stringArray.length / 2)) {
break;
}
index += 1;
} while (index <= stringArray.length);
System.out.println("for statement\n");
// for statement.
for (int i = 0; i <>
System.out.println("i = " + i);
}
System.out.println("foreach\n");
// for each.
for (String string : stringArray) {
System.out.println(string);
}
System.out.println("foreach with ArrayList\n");
// for each.
for (String string : Arrays.asList(stringArray)) {
System.out.println(string);
}
} // iterateStatement.
} // E:O:F:ControlStatements.

Comentarios

Anónimo dijo…
well.. it's like I said!

Entradas más populares de este blog

Transformando fechas a diferentes zonas horarias (TimeZone)

Ya es sabido por todo programador Java, que uno de los puntos mas bajos, recae en el uso de las fechas, las mismas se encuentran super mal diseñadas y algunos objetos como el caso de Date, practicamente no son usables, pues toda su API esta deprecada (cosa que siento debería de dejar de ponerla deprecada, pues van por la versión 6 y aun la conservan). Recientemente me encontré con el siguiente problema; resulta que al poner un sistema en otro servidor, el cual aparentemente tiene una diferencia horaria configurada, obtenemos como seria de esperar resultados no esperados, cuando realizamos consultas con fechas a la base de datos. La primera solución que se nos ha ocurrido es implementar un convertidor de fechas a diferentes zonas horarias, a continuación coloco el método necesario para realizar la operación: public static Date convertToTimeZoneDate(Date date, TimeZone timeZone) { Date newTimeZoneDate = null; Calendar foreignCalendar = null; // Create a Calendar object with the local ti...

Analizador de expresiones algebraicas recursivo decendente

Como les mencione en un post previo, estoy leyendo el libro el arte de programar en Java, el primer ejercicio consiste en un analizador de expresiones algebraicas recursivo descendente, el mismo consiste en la posibilidad de tomar una cadena que contenga una expresión matemática, la misma puede contener valores en punto flotante, sumar, restar, dividir, multiplicar, sacar exponente (potencia), uso de paréntesis para priorizar una operación, etc. A continuación clase a clase, con una pequeña explicación Lo primero que definiremos es una suite de excepciones para reportar errores, no tiene mucha ciencia, hay una para la division entre cero, cuando no existe una expresión valida, error de sintaxis o cuando los paréntesis no se encuentran balanceados, veamos package cap2; /** * Exception para reportar que hay al intentar dividir entre cero * * User: jsanca * Date: 4/16/13 * Time: 1:30 AM * @author jsanca */ public class DividedByZeroException extends RuntimeException { ...

Comparación de cadenas en Java

El siguiente código nos muestra diferentes formas y métodos para realizar comparaciones de cadenas. La primera comparación con el operador (==), se realiza simplemente a nivel de referencia de memoria. El método (equals) permite realizar una comparación carácter a carácter de dos strings. (equalsIgnoreCase) funciona igual que (equals) descartando las diferencias entre mayúsculas y minúsculas. (CompareTo) permite comparar dos cadenas, con la diferencias que si la clase es igual retorna 0, si la primera cadena es mayor retorna la diferencia (un numero positivo), si la cadena es menor retorna también la diferencia (un numero negativo). Por ultimo se utilizan métodos para realizar comparaciones de pre y pos cadenas, obtener un índice, etc. public void comparisonEqual () { String s1 = "Hello Word"; String s2 = "Hello Word"; String s3 = s1; // Equal examples... System.out.println((s1 == s2)?s1 + " = " + s3: s1 + " != " + s3); System.out...