Programando na Linguagem C

2.1    Constantes
 
            O C possui quatro tipos básicos de constantes: inteiras, de ponto flutuante, caracteres e strings. Constantes inteiras e de ponto flutuante representam números de um modo geral. Caracteres e strings representam letras e agrupamentos de letras (palavras).
 
 
            2.1.1    Constantes inteiras
 
            Uma constante inteira é um número de valor inteiro. De uma forma geral, constantes inteiras são seqüências de dígitos que representam números inteiros. Números inteiros podem ser escritos no formato decimal (base 10), hexadecimal (base 16) ou octal (base 8).
           
            Uma constante inteira decimal é formada por uma seqüência de dígitos decimais: 0, 1, 2, 3, 4, 5, 6, 7, 8, 9. Se a constantetiver dois ou mais dígitos, o primeiro não pode ser 0. Na verdade, pode ser 0 mas o compilador considerará esta constante como octal e não decimal.
           
            Exemplo: A seguir são mostradas algumas constantes inteiras decimais válidas.
     0   3   -45   26338   -7575   1010  
           
            Exemplo: Algumas constantes inteiras decimais inválidas.
            1.        (ponto)
     1,2       (vírgula)
     045       (primeiro dígito é 0: não é constante decimal)
     212-22-33 (caracter ilegal: -)
            Uma constante inteira hexadecimal é formada por uma seqüência de dígitos decimais: 0, 1, 2, 3, 4, 5, 6, 7, 8, 9, A, B, C, D, E, F (ou a, b, c, d, e). Uma constante hexadecimal deve começar por 0x. Neste caso, os dígitos hexadecimais podem ser minúsculos ou maiúsculos. 
           
            Exemplo: A seguir são mostrados algumas constantes inteiras hexadecimais válidas.
     0x0   0x3   0x4f5a   0x2FFE   OxABCD   0xAaFf  
           
            Exemplo: Algumas constantes inteiras hexadecimais inválidas.
            0x3.      (ponto)
     0x1,e     (vírgula)
     0x ff     (espaço)
     FFEE      (não começa com 0x: não é constante hexadecimal)
     0Xfg34    (caracter ilegal: g)
 
            Uma constante inteira octal é formada por uma seqüência de dígitos octais: 0, 1, 2, 3, 4, 5, 6, 7. A constante octal deve ter o primeiro digito 0 para que o compilador a identifique como tal           
            Exemplo: A seguir são mostrados algumas constantes octais válidas.
     00   -03   045   02633   07575   -0101  
           
            Exemplo: Algumas constantes inteiras octais inválidas.
            010.      (ponto)
     01,2      (vírgula)
     0 4       (espaço)
     45        (primeiro digito não é 0: não é constante octal)
     01784     (caracter ilegal: 8)
 
 
            2.1.2    Constantes de ponto flutuante
           
            Números reais (não inteiros) são representados em base 10, por números com um ponto decimal e (opcionalmente) um expoente. Um número ponto flutuante deve ter um ponto decimal que não pode ser substituído por uma vírgula. Um número de ponto flutuante pode ser escrito em notação científica. Neste caso o x10 é substituído por e ou E. O número 1.23e4 representa 1.23 x 104 ou 12300.
           
            Exemplo: Números de ponto flutuante válidos.
     0.234   125.65   .93   1.23e-9   -1.e2   10.6e18   -.853E+67
 
            A forma de representação de um número real em C é bastante flexível.
 
            Exemplo: O número 314 pode ser representado por qualquer uma das seguintes formas:
            314. 3.14e2    +3.14e+2 31.4e1    .314E+3   314e0
           
 
            2.1.3    Constantes caracteres
 
            Uma constante caracter é uma letra ou símbolo colocado entre aspas simples.
           
            Exemplo: Abaixo estão representados algumas constantes caracteres.
            ’a’ ’b’ ’X’ ’&’ ’{’ ’ ’
 
            Embora sejam visualizados como letras e símbolos as constantes caracteres são armazenadas internamente pelo computador como um número inteiro entre 0 e 255. O caracter ’A’ por exemplo, tem valor 65. Os valores numéricos dos caracteres estão padronizados em uma tabela chamada de American Standard Code for Information Interchange Table ou simplesmente tabela ASCII. Veja apêndice B.
 
            Certos codigos de controle da tabela ASCII (como o line feed) ou caracteres especiaiss (como ') possuem representação especial no C. Esta representacao chama-se seqüência de escape representada por uma barra invertida (\) e um caracter. Sequencias de escape são interpretadas como caracteres simples. Abaixo segue uma lista das principais sequencias de escape usadas no C.
 
     Controle/Caracter            Sequencia de escape     Valor ASCII
     nulo (null)                           \0                  00
     campainha (bell)                      \a                  07
     retrocesso (backspace)                \b                  08
     tabulacao horizontal                  \t                  09
     nova linha (new line)                 \n                  10
     tabulacao vertical                    \v                  11
     alimentacao de folha (form feed)      \f                  12
     retorno de carro (carriage return)    \r                  13
     aspas (")                             \"                  34
     apostrofo (')                         \'                  39
     interrogacao (?)                      \?                  63
     barra invertida (\)                   \\                  92
           
 
            2.1.4    Constantes strings
           
            Uma constante string consiste de um conjunto de caracteres colocados entre aspas duplas. Embora as instruções do C usem apenas os caracteres do conjunto padrão ASCII, as constantes caracter e string podem conter caracteres do conjunto estendido ASCII: é, ã, ç, ü, ... 
 
            Exemplo: Abaixo seguem algumas constantes strings válidas.
            ”Oba!”
     ”Caxias do Sul”
     ”A resposta é: ”
     ”João Carlos da Silveira”
     ”a”
     ”isto é uma string”
 
           
         2.2    Identificadores
 
            Identificadores são os nomes das variáveis e funções usadas no programa. Por exemplo raiz e MAX são nomes de variáveis utilizadas no programa e0101.cpp.
 
 
            2.2.1    Regras de sintaxe
 
            Os identificadores devem seguir as seguintes regras de construção:
·       Os identificadores devem começar por uma letra (a - z , A - Z) ou um underscore ( _ ).
·       O resto do identificador deve conter apenas letras, underscores ou dígitos (0 - 9). Não pode conter outros caracteres. Em C, os identificadores podem ter até 32 caracteres.
·       Em C, letras maiúsculas são diferentes de letras minúsculas: Por exemplo: MAX, max, Max são nomes diferentes para o compilador. Esta propriedade é chamada de case sensibility.
 
            Exemplo: os nomes abaixo são válidos:
     abc, y24, VetorPontosMovimentoRobo, nota_1, TAM_MAX.
    
            Exemplo: os nomes abaixo não são válidos:
     3dia, vetor-1, pao&leite, iteração.
 
            2.2.2    Palavras reservadas
 
            Existem certos nomes que não podem ser usados como identificadores. São chamadas as palavras reservadas e são de uso restrito da linguagem C (comandos, estruturas, declarações, etc.). O conjunto de palavras reservadas usadas em C é o seguinte:
 
 asm         auto        break       case        cdecl       char
 class       const       continue    _cs         default     delete
 do          double      _ds         else        enum        _es
 extern      _export     far         _fastcall   float       for
 friend      goto        huge        if          inline      int
 interrupt   _loadds     long        near        new         operator
 pascal      private     protected   public      register    return
 _saveregs   _seg        short       signed      sizeof      _ss
 static      struct      switch      template    this        typedef
 union       unsigned    virtual     void        volatile    while
 
            Exemplo: Não é possível declarar estes conjunto de variáveis:
     do, re, mi, fa, sol, la, si
     old, new
           
            Dos conjuntos acima, do e new são palavras reservadas.
 
 
         2.3    Tipos de dados
 
            Em C, como na maioria das linguagens, os dados são divididos tipos: inteiro, real, caracter, etc. Esta divisão se deve basicamente ao número de bytes reservados para cada dado. Cada tipo de dado possui um intervalo de valores permitidos.
 
 
            2.3.1    Tipos básicos
 
            Abaixo segue uma lista dos tipos básicos de dados permitidos em C. Os tipos char e int são inteiros e os tipos float e double são de ponto flutuante.
 
 
Tipo    Tamanho       Intervalo         Uso
char    1 byte       -128 a 127         número muito pequeno e caracter ASCII
int     2 bytes    -32768 a 32767       contador, controle de laço
float   4 bytes   3.4e-38 a 3.4e38      real (precisão de 7 dígitos)
double 8 bytes 1.7e-308 a 1.7e308     científico (precisão de 15 dígitos)
 
 
            2.3.2    Declaração de variáveis
 
Para que se possa usar uma variável em um programa, é necessário fazer uma declaração de variável antes. A declaração de variáveis simplesmente informa ao processador quais são os nomes utilizados para armazenar dados variáveis e quais são os tipos usados. Deste modo o processador pode alocar (reservar) o espaço necessário na memória para a manipulação destas variáveis. É possível declarar mais de uma variável ao mesmo tempo, basta separá-las por vírgulas (,).
 
            Sintaxe: A sintaxe para declaração de variáveis é a seguinte:
tipo variavel_1 [, variavel_2, ...] ;
 
            Onde tipo é o tipo de dado e variavel_1 é o nome da variável a ser declarada. Se houver mais de uma variável, seus nomes são separados por vírgulas.
 
Exemplo: Declaração das variáveis:
int i;
int x,y,z;
char letra;
float nota_1,nota_2,media;
double num;
 
            No exemplo acima, i, x, y e z foram declaradas variáveis inteiras. Assim elas podem armazenar valores inteiros de -32768 até 32767. Do mesmo modo letra foi declarada como variável caracter podendo receber valores de -128 até 127 ou caracteres do conjunto padrão ASCII. As variáveis nota_1, nota_2 e media foram declaradas como ponto flutuante tipo float e num como ponto flutuante tipo double.
 
            A declaração de variáveis é feita, em geral, dentro de uma rotina. Por exemplo, a rotina principal main(). Deste modo se diz que está se fazendo uma declaração de variáveis locais. Variáveis locais podem ser referenciadas apenas dentro da rotina dentro da qual foi declarada, neste caso a rotina main().
            Exemplo: Observe o uso da declaração de variáveis no trecho de programa abaixo:
            void main(){
      float raio, area;     // declaracao de variaveis
      raio = 2.5;
      área = 3.14 * raio * raio;
     }
 
            No exemplo acima, as variáveis area e raio foram declaradas como variáveis locais tipo float. Assim o processador faz a alocação de dois espaços (endereços) de 4 bytes cada para armazenar as informações, um para cada variável. Na terceira linha, o processador coloca no endereço alocado para raio o valor 2.5. Depois, na quarta linha, o processador coloca o resultado da conta (19.625) no endereço de área.
 
            É possível fazer a declaração de variáveis fora de uma rotina. Neste caso diz-se que se fez a declaração de variáveis globais. O uso de variáveis globais é explicado na sessão ?.?.
 
            2.3.3    Tipos modificados
 
            Além dos tipos de dados citados acima existem outros tipos de dados ditos modificados. Em C existem dois modificadores: o modificador long e o modificador unsigned. Tipicamente o modificador long aumenta o número de bytes usados para o registro do número. Por conseqüência o intervalo de validade do número fica aumentado significativamente. O modificador unsigned, usado somente em inteiros, permite que um bit usado para guardar o sinal do número seja usado para guardar o valor do número. Em conseqüência disto o intervalo do número fica dobrado, porém somente permite o uso de números positivos.
 
     Tipo              Tamanho (bytes)             Intervalo
     unsigned char           1                       0 a 255          
     unsigned int            2                       0 a 65 535
     long int                4          -2 147 483 648 a 2 147 483 647
     unsigned long int       4                       0 a 4 294 967 295
     long double            10               3.4e-4932 a 1.1e4932
 
           
2.3.4    Strings.
 
Uma string é um conjunto ordenado de caracteres que pode ser armazenado sob forma de um vetor um ponteiro. Estas estruturas de dados serão vistas em detalhe nos capitulo ? e ?. Por enquanto, nos basta saber como declarar e armazenar um conjunto caracter em uma variável.
 
Sintaxe: Para declararmos uma variável para receber um conjunto caracter devemos escrever:
char* var;
 
Exemplo: No exemplo seguinte a variável nome foi declarada como conjunto caracter e em seguida recebe uma constante string.
char* nome;
nome = "João Carlos de Oliveira Andrade";  
 
 
 
 
 
2.3.5    Inicialização de variáveis.
 
            Quando se faz a declaração de uma variável está se determinando que tipo de dado ela vai receber. É possível, em C, declarar uma variável e já armazenar nela um valor inicial. Chamamos este procedimento de inicialização de uma variável.
 
            Sintaxe: A sintaxe para a inicialização de variáveis é:
tipo var_1 = valor_1 [, var_2 = valor_2, ...] ;
 
Onde tipo é o tipo de dado, var_1 é o nome da variável a ser inicializada e valor_1 é o valor inicial da variável.
 
Exemplo: Inicialização de variáveis:
int i = 0, j = 100;
float num = 13.5;
char* titulo = " Programa Teste ";
 
            No exemplo acima, i e j foram declaradas variáveis tipo int. O valor inicial de i é 0 e o de j é 100. Do mesmo modo numfoi declarada como variável float com valor inicial de 13.5. Tambem a variavel titulo foi declarada como um conjunto caracter e recebeu como conteudo inicial a string " Programa Teste ".
 
2.3.6    Conversão de tipo (Casting)
 
            Algumas vezes queremos, momentaneamente, modificar o tipo de dado representado por uma variável, isto é, queremos que o dado seja apresentado em um tipo diferente do qual a variável foi inicialmente declarada. Por exemplo: declaramos uma variável como int e queremos, momentaneamente, que seu conteúdo seja apresentado como float. Este procedimento é chamado de conversão de tipo ou casting (moldagem, em inglês).
 
            Sintaxe: A sintaxe da instrução de conversão de tipo é:
(tipo) variável
 
onde tipo é o nome do tipo ao qual queremos converter o dado armazenado em variável.
 
 
Exemplo: observe a conversão de tipo feita no exemplo abaixo:
     int num;
float valor = 13.0;
num = (int)valor % 2;
 
No exemplo acima a variável valor foi declarada inicialmente como sendo do tipo float recebendo o valor inicial 13.0. Logo em seguida o conteúdo de valor é convertido para o tipo int para realizar a operação módulo (%) com o inteiro 2. Aqui a conversão é necessária pois a operação módulo somente pode ser feita com inteiros. É importante salientar que a conversão de tipo é feita com o dado armazenado em uma variável mas a variável continua tendo o seu tipo original. No exemplo acima a variável valor e os dados nela armazenados continuam sendo do tipo float após a conversão.
 
Veremos na seção 3.1 uma explicação mais detalhada do uso da conversão de tipos.
 
 
         2.4 Constantes Simbólicas
 
            Muitas vezes identificamos uma constante numérica por um símbolo: Pi = 3,14159 por exemplo. Podemos definir um nome simbólico para esta constante, isto é, podemos definir uma constante simbólica que represente valor.
 
 
2.4.1    Constantes definidas pelo programador
           
            O programador pode definir constantes simbólicas em qualquer programa.
 
            Sintaxe: A sintaxe da instrução de definição de uma con

Publicado por: Brasil Escola

icone de alerta

O texto publicado foi encaminhado por um usuário do site por meio do canal colaborativo Monografias. Brasil Escola não se responsabiliza pelo conteúdo do artigo publicado, que é de total responsabilidade do autor . Para acessar os textos produzidos pelo site, acesse: https://www.brasilescola.com.