402y37

 

Operadores III: Precedencia

Normalmente, las expresiones con operadores se evalúan de izquierda a derecha, aunque no todos, ciertos operadores que se evalúan y se asocian de derecha a izquierda. Además no todos los operadores tienen la misma prioridad, algunos se evalúan antes que otros, de hecho, existe un orden muy concreto en los operadores en la evaluación de expresiones. Esta propiedad de los operadores se conoce como precedencia o prioridad.

Veremos ahora las prioridades de todos los operadores incluidos los que aún conocemos. Considera esta tabla como una referencia, no es necesario aprenderla de memoria, en caso de duda siempre se puede consultar, incluso puede que cambie ligeramente según el compilador, y en último caso veremos sistemas para eludir la precedencia.

 Operadores  Asociatividad
 () [] -> :: .  Izquierda a derecha
 Operadores unitarios: ! ~ + - ++ -- & (dirección de) * (puntero a) sizeof new delete  Derecha a izquierda
 .* ->*  Izquierda a derecha
 * (multiplicación) / %  Izquierda a derecha
 + - (operadores binarios)  Izquierda a derecha
 << >>  Izquierda a derecha
 < <= > >=  Izquierda a derecha
 == !=  Izquierda a derecha
 & (bitwise AND)  Izquierda a derecha
 (bitwise XOR)  Izquierda a derecha
 | (bitwise OR)  Izquierda a derecha
 &&  Izquierda a derecha
 ||  Izquierda a derecha
 ?:  Derecha a izquierda
 = *= /= %= += -= &= = |= <<= >>=  Derecha a izquierda
 ,  Izquierda a derecha

La tabla muestra las precedencias de los operadores en orden decreciente, los de mayor precedencia en la primera fila. Dentro de la misma fila, la prioridad se decide por el orden de asociatividad.

La asociatividad nos dice en que orden se aplican los operadores en expresiones complejas, por ejemplo:

int a, b, c, d, e; 
b = c = d = e = 10; 

El operador de asignación "=" se asocia de derecha a izquierda, es decir, primero se aplica "e = 10", después "d = e", etc. O sea, a todas las variables se les asigna el mismo valor: 10.

a = b * c + d * e; 

El operador * tiene mayor precedencia que + e =, por lo tanto se aplica antes, después se aplica el operador +, y por último el =. El resultado final será asignar a "a" el valor 200.

int m[10] = {10,20,30,40,50,60,70,80,90,100}, *f; 
f = &m[5]; 
++*f; 
cout << *f << endl; 

La salida de este ejemplo será, 61, los operadores unitarios tienen todos la misma precedencia, y se asocian de derecha a izquierda. Primero se aplica el *, y después el incremento al contenido de f.

f = &m[5]; 
*f--;
cout << *f << endl; 

La salida de este ejemplo será, 50. Primero se aplica el decremento al puntero, y después el *.

a = b * (c + d) * e; 

Ahora el operador de mayor peso es (), ya que los paréntesis están en el grupo de mayor precedencia.
 
Todo lo que hay entre los paréntesis se evalúa antes que cualquier otra cosa. Primero se evalúa la suma, y después las multiplicaciones. El resultado será asignar a la variable "a" el valor 2000.

Este es el sistema para eludir las precedencias por defecto, si queremos evaluar antes una suma que un producto, debemos usar paréntesis.
Ir al Principio
Compartir

Mi nombre es Alexander fundador y CEO, y me gusta llamarme un Geek. Amo la informática, tecnología y todo lo que está relacionado con ella. Inicié este sitio con la intención de compartir conocimientos como cursos en línea, tutoriales y videotutoriales. Estoy muy entusiasmado con la información que he descubierto y compartido hasta el momento. La verdad es que lo he hecho con el mayor de los gustos. Así es, soy un Geek con una visión para compartir conocimiento. Leer mas...