}

Linguaxe de programación C (IV). Estruturas de control I

1991/05/01 Alegria Loinaz, Iñaki | Maritxalar, Montse Iturria: Elhuyar aldizkaria

Permite seleccionar ou reproducir expresións mediante estruturas de control. O obxectivo deste capítulo é a redacción e uso destas estruturas en linguaxe C.

Permite seleccionar ou reproducir expresións mediante estruturas de control. Aínda que as expresións analizadas no capítulo anterior permiten escribir programas totalmente lineais e secuenciales, na maioría dos programas débese decidir si executar ou non certas ordes segundo os datos, mediante estruturas condicionais e repetir a execución dos conxuntos de ordes utilizando estruturas repetitivas. O obxectivo deste capítulo é a redacción e uso destas estruturas en linguaxe C.

Entre as estruturas condicionais, as máis utilizadas son dúas e a linguaxe C ten dúas estruturas (if) e una opción (switch). Na primeira elíxese entre dúas ramas en función do valor dunha expresión lóxica. Na segunda, con todo, pódense pór tantas ramas como se desexe.

C é moi rico en estruturas repetitivas, xa que ten tres tipos: mentres (while), refrán (do/while) e cambiando (for). As súas características serán analizadas máis adiante.

Estrutura IF

Esta estrutura ou sentenza está en calquera linguaxe e en C mata as características xerais, é dicir, avalíase una expresión lóxica e execútase a rama correspondente á seguinte ou na súa falta ri (else) en función do resultado.

A sintaxe estrutural é a seguinte:

Como pode observarse, o ramal é opcional, distinguindo a estrutura completa ou simple en función da aparición.

Por exemplo, a estrutura if que aparece na parte seguinte do programa é sinxela.

En cambio, na seguinte parte temos toda a estrutura:

Hai que ter en conta os seguintes matices:

  • Expresións das ramas, terminando co carácter.
  • Nas ramas con máis dunha orde débese especificar ao principio e ao final da mesma.
  • Paira expresar a igualdade na expresión condicional utilízase o axente = e non =, xa que neste caso non se produce erro, pero se produce una asignación e se o valor asignado é Ø, considerarase un resultado falso e no resto como verdadeiro.
  • Cando hai outra if (if kabiatua) dentro de una if hai un problema coas ramas, xa que ao atopar una else pode dubidar de si corresponde á primeira ou segunda. A regra é que una else corresponde sempre co último if- escrito, sen ter en conta as marxes.
  • Condición de estrutura If? expresión 1: expresion2, que pode ser substituída pola expresión, como se aprecia no programa 1.
Programa 1. Exemplos de estrutura condicional.

Estrutura SWITCH

Esta estrutura permite xerar o número de ramas que desexamos segundo o valor dunha expresión, comezando cada rama por unha palabra crave case (excepto a última, que pode empezar pola palabra crave default). A sintaxe correspondente é:

Como se pode observar, as expresións nas ramas son opcionais como o ramal default. Si nunha rama colócase máis dunha expresión, non hai que pór{ e}, pero cada un debe acabar co carácter.

Cando se atopa un swicth na execución avalíase a expresión de baldin e búscase en función do valor en que rama a expresión contable ten o mesmo valor. Se se atopan estas ramas, realízanse as sentenzas correspondentes a esa rama e ás seguintes. Na estrutura “case” de Pascal realízanse unicamente as expresións correspondentes á rama. No entanto, si C deséxao, a última expresión das ramas será breas

...

Programa 2. Switches e break combinados.

Se o valor da expresión non se atopa nas ramas, realizaranse as expresións da rama default, se se escribiu esta rama.

No programa 2 explícase o uso convencional do switch (utilizado polo break).

No 3, pola contra, o uso máis específico.

Estrutura WHILE

A estrutura repetitiva máis xeral é como a sentenza “while-do” de Pascal. Desde o punto de vista sintáctico:

Avalíase a expresión de baldin e si é certa (non Ø) realízanse as expresións propias da estrutura e vólvese a avaliar a expresión, formando un bigal.

Cando a avaliación da expresión é falsa pasa á seguinte sentenza.

A expresión entre paréntese é a condición de repetición e o corpo no que se repite a outra expresión ou conxunto de expresións. Se o corpo ten varias sentenzas ao principio e ao final son necesarias. No programa 4 pódese ver un uso.

4º Programa. Factorial n a través de while.

Estrutura DO-WHILE

While

nesta modificación da estrutura, a avaliación da condición prodúcese ao final do abrandamento. Por tanto, nesta estrutura de do-while o corpo execútase polo menos una vez. Pola contra, na estrutura while pode ocorrer que a primeira avaliación sexa falsa. No resto son exactamente iguais.

A sintaxe da estrutura é a seguinte:

No programa 5 pódense ver os cambios realizados no programa do factorial do-while.

if

utilízase a nova para que os factoriales de Ø e 1 execútense correctamente.

5º Programa. Factorial n mediante do-white.

No seguinte capítulo continuaremos coas estruturas e coa axuda de exemplos profundaremos no uso de estruturas de control.

Gai honi buruzko eduki gehiago

Elhuyarrek garatutako teknologia