Notas de Aulas (parte 2)

Tamanho: px
Começar a partir da página:

Download "Notas de Aulas (parte 2)"

Transcrição

1 Curso: Ciência da Computação (Integral) Disciplina: Linguagem de Programação C Notas de Aulas (parte 2) Professora: Luciana Rita Guedes março/2014

2 Linguagem de Programação C - notas de aula - parte 2 Página: i Índice 1. PONTEIROS PARA PONTEIROS: PONTEIROS QUE APONTAM PARA PONTEIROS PONTEIROS E MATRIZES MULTIDIMENSIONAIS: USO DE NOMES DE MATRIZES COMO PONTEIROS MATRIZES DE PONTEIROS: FUNÇÕES QUE RETORNAM PONTEIROS: PONTEIROS PARA O TIPO VOID ESTRUTURAS EM C ESTRUTURAS SIMPLES: Acessando os Membros de Uma Estrutura: ESTRUTURAS QUE CONTÊM ESTRUTURAS: ESTRUTURAS QUE CONTÊM MATRIZES: MATRIZES DE ESTRUTURAS: INICIALIZANDO ESTRUTURAS: ESTRUTURAS E PONTEIROS PONTEIROS COMO MEMBROS DE ESTRUTURAS: PONTEIROS PARA STRINGS COMO MEMBROS DE ESTRUTURAS: PONTEIROS PARA STRINGS X MATRIZES DE CHAR EM ESTRUTURAS: PONTEIROS PARA ESTRUTURAS: ARQUIVOS EM DISCO A ESTRUTURA FILE: ABRINDO ARQUIVOS: FECHANDO ARQUIVOS: GRAVANDO ARQUIVOS, CARACTER A CARACTER: LENDO ARQUIVOS, CARACTER A CARACTER: ERROS AO ABRIR ARQUIVOS: GRAVANDO ARQUIVOS, LINHA A LINHA: LENDO ARQUIVOS, LINHA A LINHA: ARQUIVOS BINÁRIOS LENDO E GRAVANDO REGISTROS: GRAVAÇÃO DIRETA COM FWRITE( ): LEITURA DIRETA COM FREAD( ): TIPOS DE ACESSO A ARQUIVOS: ACESSO SEQÜENCIAL CONTROLANDO O INDICADOR DE POSIÇÃO ACESSO ALEATÓRIO FUNÇÕES DE GERENCIAMENTO DE ARQUIVOS: APAGANDO UM ARQUIVO: MUDANDO O NOME DE UM ARQUIVO: COPIANDO UM ARQUIVO: USANDO ARQUIVOS TEMPORÁRIOS:... 50

3 Linguagem de Programação C - notas de aula - parte 2 Página: 1 1. PONTEIROS PARA PONTEIROS: Revisando: ponteiros são variáveis que contêm o endereço de outra variável; para declarar um ponteiro usa-se o operador de indireção (*): int *ptr; para fazer com que um ponteiro aponte para uma variável, pode-se usar o operador endereço de (&): ptr=&x; // supondo x uma variável do tipo int pode-se usar o operador de indireção (*) para armazenar um valor na variável para a qual o ponteiro estiver apontando (armazenamento indireto): *ptr=12; // equivale a x = 12 se ptr estiver // apontando para x 1.1 PONTEIROS QUE APONTAM PARA PONTEIROS Um ponteiro é uma variável numérica e é armazenado em algum endereço de memória; portanto, pode-se criar um ponteiro que aponte para outro ponteiro, ou seja, uma variável cujo valor é o endereço de um ponteiro. EXEMPLO (declaração): int x; int int *ptr; int **ptr_para_ptr; int // x é uma variável do tipo // ptr é um ponteiro para x // ptr_para_ptr é um ponteiro // para um ponteiro do tipo

4 Linguagem de Programação C - notas de aula - parte 2 Página: 2 Para atribuir valores a estas variáveis: x = 12; // x recebe o valor 12 ptr = &x; // ptr aponta para o endereço de x ptr_para_ptr = &ptr; // ptr_para_ptr aponta para o // endereço do ponteiro ptr x ptr ptr_para_ptr para declarar um ponteiro que aponta para outro ponteiro usa-se o operador de indireção duplo (**); o operador de indireção duplo (**) também pode ser usado para acessar a variável que é referenciada **ptr_para_ptr = 12; // atribui o valor 12 para a variável // referenciada pelo ponteiro ptr // que no exemplo é a variável x printf( %d,**ptr_para_ptr); // imprime o valor da // variável x a declaração e utilização de um ponteiro-para-ponteiro é chamada de indireção múltipla ; o uso mais comum de ponteiros-para-ponteiros está relacionado à criação de matrizes de ponteiros, como será visto adiante.

5 Linguagem de Programação C - notas de aula - parte 2 Página: PONTEIROS E MATRIZES MULTIDIMENSIONAIS: Como já foi visto anteriormente, há uma relação especial entre ponteiros e matrizes: o nome de uma matriz (sem os colchetes) é um ponteiro para o primeiro elemento desta matriz; pode-se usar ponteiros para acessar os demais elementos desta matriz; porém, o estudo anterior limitou-se ao uso de matrizes unidimensionais: como trabalhar com matrizes multidimensionais? Para declarar uma matriz multidimensional usa-se um par de colchetes: int multi[2][4]; // declara uma matriz de 8 ele- // mentos pode-se interpretar a declaração acima como sendo de uma matriz de 2 linhas por 4 colunas. outra forma de visualizar esta matriz é mais compatível com a forma como a linguagem C realmente lida com matrizes, ou seja: MULTI é uma matriz de 2 elementos, sendo que cada um desses 2 elementos é uma matriz de 4 números inteiros (pode-se dizer que MULTI é uma matriz de matrizes );

6 Linguagem de Programação C - notas de aula - parte 2 Página: 4 multi multi[0] multi[1][3] Uma matriz bidimensional é visualizada como uma matriz de matrizes 1.3 USO DE NOMES DE MATRIZES COMO PONTEIROS Como em matrizes unidimensionais: o nome de uma matriz é um ponteiro para o primeiro elemento desta matriz: multi é um ponteiro para multi[0] multi[0] é um ponteiro para multi[0][0] multi[1] é um ponteiro para multi[1][0] Como regra geral para matrizes com n dimensões, temos: O nome da matriz seguido por n pares de colchetes (cada par contendo um índice apropriado, evidentemente) é avaliado com base nos dados contido nessa matriz (ou seja, é igual aos dados armazenados no elemento especificado da matriz).

7 Linguagem de Programação C - notas de aula - parte 2 Página: 5 O nome da matriz seguido por um número de pares de colchetes menor que n é avaliado como um ponteiro para um elemento da matriz. Relação entre uma matriz multidlmenslonal e os ponteiros: 01:/* Demonstra o uso de ponteiros e matrizes multidimensionais. * / 02: 03:#include <stdio.h> 04: 05:int multi[2][4]; 06: 07:main() 08:{ 09: printf( \nmulti = %u, multi); 10: printf( \nmulti[0] = %u, multi[0]); 11: printf( \nmulti[0][0] = %u, &multi[0][0]); 12:} Resultados do programa (supondo o endereço inicial da matriz como 1328): multi = 1328 multi[0] = 1328 &multi[0][0] = 1328 Determinando o tamanho dos elementos: 01:/* Mostra o tamanho dos elementos de uma matriz multidimensional */ 02: 03:#include <stdio.h> 04: 05:int multi[2][4]; 06: 07:main() 08:{ 09: printf( \ntamanho de multi = %u, sizeof(multi)); 10: printf( \ntamanho de multi[0] = %u, sizeof(multi[0])); 11: printf( \ntamanho de multi[0][0] = %u, sizeof(multi[0][0])); 12: } Resultados: Tamanho de multi = 16 Tamanho de multi[0] = 8 Tamanho de multi[0][0] = 2

8 Linguagem de Programação C - notas de aula - parte 2 Página: 6 2. MATRIZES DE PONTEIROS: Na linguagem C pode-se declarar e usar matrizes de ponteiros; O uso mais comum para matrizes de ponteiros está relacionado aos strings; Para declarar uma matriz de ponteiros que apontam para variáveis do tipo char: char *texto[10]; // texto é uma matriz com 10 // ponteiros texto[0]?? texto[1]?? texto[2]?? texto[3]?? texto[4]?? texto[5]?? texto[6]?? texto[7]?? texto[8]?? texto[9]?? cada elemento da matriz texto é um ponteiro individual para o tipo char; Para declarar e inicializar uma matriz de ponteiros que apontam para diversos strings diferentes: char *texto[10]={ um, dois, três }; a declaração acima: aloca espaço para uma matriz chamada texto com 10

9 Linguagem de Programação C - notas de aula - parte 2 Página: 7 elementos, onde cada elemento é um ponteiro para o tipo char; aloca espaço em alguma outra região da memória para armazenar os três strings de inicialização inicializa o elemento texto[0] para apontar para o primeiro caractere do string um ; inicializa o elemento texto[1] para apontar para o primeiro caractere do string dois ; inicializa o elemento texto[2] para apontar para o primeiro caractere do string três ; 1524 texto[0] 1524 u m \0 texto[1] texto[2] 5012 d o i s \0 texto[3]? 5012 texto[4]? t r ê s \0 texto[5]? texto[6]? texto[7]? texto[8]? texto[9]? EXEMPLO: inicializando e usando uma matriz do tipo char 01: /* Inicializando uma matriz de ponteiros para o tipo char */ 02: 03: #include <stdio.h> 04: 05: main() 06: { 07: char *mensagem[8] = { Já, dizia, vovó, antes, só, que, mal, acompanhado }; 08: 09: int contagem; 10: 11: for (contagem = 0; contagem < 8; contagem++) 12: printf( %s\n, mensagem[contagem]); 13: }

10 Linguagem de Programação C - notas de aula - parte 2 Página: 8 EXEMPLO: passando uma matriz de ponteiros para uma função 01: /* Passando uma matriz de ponteiros para uma função */ 02: 03: #include <stdio.h> 04: 05: void imprime_strings(char *p[], int n); 06: 07: main() 08: { 09: char *mensagem[8] = { Já, dizia, vovó, antes, só, que, mal, acompanhado } 10: 11: 12: imprime_strings(mensagem, 8); 13: } 14: 15: void imprime_strings(char *p[], int n) 16: { 17: int contagem; 18: 19: for (contagem = 0; contagem<n; contagem++) 20: printf( %s\n, mensagem[contagem]); 21: }

11 Linguagem de Programação C - notas de aula - parte 2 Página: 9 3. FUNÇÕES QUE RETORNAM PONTEIROS: A biblioteca-padrão C contém diversas funções que retornam um ponteiro para o programa de origem. Da mesma forma, é possível escrever funções que retornem ponteiros. Para declarar e/ou definir uma função que irá retornar um ponteiro, usa-se o operador de indireção (*). O formato geral é: tipo *nome_função(lista_parâmetros); Estas funções não têm nada de especial pois são usadas exatamente como qualquer outra função, atribuindo seu valor de retorno a uma variável do tipo apropriado; a única diferença é que este valor será um ponteiro. EXEMPLOS: usando funções que retornam ponteiros: O programa a seguir possui duas funções: maior1( ) e maior2( ). O objetivo do programa é obter dois valores inteiros do usuário (a partir do teclado) e indicar qual dos dois é o maior; este resultado é obtido igualmente através das duas funções, porém de forma um pouco diferente: A função maior1( ) recebe duas variáveis do tipo inteiro e retorna um valor do tipo inteiro; A função maior2( ) recebe dois poneiros para variáveis do tipo inteiro e retorna um ponteiro para o tipo inteiro.

12 Linguagem de Programação C - notas de aula - parte 2 Página: 10 01: /* Funcao que retorna um ponteiro. */ 02: 03: #include <stdio.h> 04: 05: int maiorl(int x, int y); // protótipo da 1a. função 06: int *maior2(int *x, int *y); // protótipo da 2a. função 07: 08: main() 09: { 10: int a, b, resultadol, *resultado2; 11: 12: printf( Digite dois numeros inteiros: ); 13: scanf( %d %d, &a, &b); 14: 15: resultadol = maiorl(a, b); 16: printf( \no maior valor e %d., resultadol); 17: 18: resultado2 = maior2(&a, &b); 19: printf( \no maior valor e %d., *resultado2); 20: } 21: 22: int maiorl(int x, int y) 23: { 24: if (y>x) 25: return y; 26: return x; // retorna um valor numérico inteiro 27: } 28: 29: int *maior2(int *x, int *y) 30: { 31: if (*y > *x) 32: return y; 33: // retorna o endereço de uma variável 34: return x; // do tipo inteiro 35: }

13 Linguagem de Programação C - notas de aula - parte 2 Página: PONTEIROS PARA O TIPO VOID Qual a finalidade da palavra-chave void antes de uma função? Também é possível usar void para criar um ponteiro genérico, ou seja, um ponteiro que pode apontar para qualquer tipo de dados. EXEMPLO 1 void *x; declara o ponteiro genérico x, que aponta para algo; você apenas não especificou ainda para o que ele está apontando. EXEMPLO 2 Digamos que você queira criar uma função que aceite uma variável numérica como argumento e divida o seu valor por 2, retornando a resposta para a própria variável de argumento. Se a variável x contém o valor 4, depois de chamar a função metade (x), ela passaria a conter o valor 2. Considerações: Como você pretende modificar o argumento, ele deve ser passado por referência; Como você quer que a função seja acessível a qualquer dos tipos de dados numéricos possíveis em C, você deve declarála usando como argumento um ponteiro para o tipo void. EXEMPLO 3 void metade(void *x); Agora você já pode chamar essa função usando qualquer tipo de ponteiro como argumento.

14 Linguagem de Programação C - notas de aula - parte 2 Página: ESTRUTURAS EM C OBJETIVO: Usar esquemas especiais de dados para simplificar tarefas de programação. Estes esquemas são chamados de estruturas. As estruturas constituem-se num método de armazenagem desenhado pelo próprio programador. 5.1 ESTRUTURAS SIMPLES: Uma estrutura é uma coleção de uma ou mais variáveis agrupadas sob um único nome; As variáveis de uma estrutura, ao contrário de uma matriz, podem ser de diferentes tipos de dados; Uma estrutura pode conter quaisquer tipos de dados, inclusive matrizes ou mesmo outras estruturas. Definindo e Declarando Estruturas Simples: Para definir uma estrutura simples usa-se a seguinte sintaxe: struct rotulo { membros_da_estrutura; }; A instrução acima define uma estrutura chamada rotulo que pode conter diversos membros, os quais podem ser do mesmo tipo ou podem ser de tipos diferentes;

15 Linguagem de Programação C - notas de aula - parte 2 Página: 13 Exemplos de Definição de Estruturas: struct hora { int horas; int minutos; int segundos; }; struct data { char dia[2]; char mes[2]; char ano[4]; }; Para declarar estruturas cujo gabarito foi previamente definido usa-se seguinte sintaxe: struct rotulo instancia1, instancia2,...; A instrução acima declara instancias da estrutura chamada rotulo, isto é, variáveis cujo formato é definido pela estrutura denominada rotulo; Outra forma de declarar estruturas é no momento de criação da estrutura (definição) colocando-se os nomes das instâncias logo após à definição: struct rotulo { membros_da_estrutura; } instancia1, instancia2,...; Exemplos de Declaração de Estruturas: // declaração em separado struct hora { int horas; int minutos; }; // pode haver outras // instrucoes aqui struct hora inicio, fim; // declaração junto c/definição struct data { char dia[2]; char mes[2]; char ano[4]; } data_nasc, data_atual; // neste caso a declaracao deve // vir logo apos a definicao

16 Linguagem de Programação C - notas de aula - parte 2 Página: Acessando os Membros de Uma Estrutura: Os membros individuais de uma estrutura podem ser acessados como qualquer variável, desde que seja usado o operador de membro de estrutura (.), entre o nome da estrutura (instância) e o nome do membro. O operador de membro de estrutura também é chamado de operador ponto: nome_instancia.nome_membro = valor; printf(...,nome_instancia.nome_membro); Exemplos de Uso de Membros de Estruturas: // definição da estrutura HORA struct hora { int horas; int minutos; }; // pode haver outras instrucoes aqui // declaração das instâncias INICIO e FIM struct hora inicio, fim; // uso dos membros da estrutura através da instancia INICIO inicio.horas = 10; inicio.minutos = 35; // uso dos membros da estrutura através da instancia FIM fim.horas = inicio.horas; fim.minutos = 49; Ainda com relação ao uso dos membros de uma estrutura, é possível copiar informações entre estruturas de mesmo formato, como no exemplo abaixo: // os dados contidos nos membros da estrutura INICIO são // passados a cada um dos membros da estrutura FIM fim = inicio;

17 Linguagem de Programação C - notas de aula - parte 2 Página: ESTRUTURAS QUE CONTÊM ESTRUTURAS: Uma estrutura pode conter outras estruturas dentro de si formando um agrupamento de variáveis mais complexos e interessantes. Vejamos isto através de um exemplo: Exemplos de Estruturas que Contêm Estruturas: // definição da estrutura COORD que é composta de // duas coordenadas num plano cartesiano (X e Y) struct coord { int x; int y; }; // definição e declaração da estrutura RETANGULO composta // de dois conjuntos de coordenadas X e Y struct retangulo { struct coord superior_esquerdo; struct coord inferior_direito; } caixa; // uso dos membros da estrutura da instancia CAIXA caixa.superior_esquerdo.x = 0; caixa.superior_esquerdo.y = 10; caixa.inferior_direito.x = 100; caixa.inferior_direito.y = 200; // estes dados podem ser interpretados como um conjunto // de duas coordenadas X e Y no plano cartesiano para // formarem uma caixa retangular O resultado da atribuição acima pode ser representado da seguinte forma: CAIXA SUPERIOR_ESQUERDO INFERIOR_DIREITO X Y X Y

18 Linguagem de Programação C - notas de aula - parte 2 Página: 16 Programa Exemplo com Estruturas que Contêm Estruturas: 01: /* Demonstra o uso de estruturas que contem outras estruturas */ 02: 03: /* Recebe informacoes sobre as coordenadas dos cantos de 04: um retangulo e calcula a sua area. Presume que a 05: coordenada y do canto superior esquerdo e maior que a 06: coordenada y do canto inferior direito, que a coordenada x 07: do canto inferior direito e maior que a coordenada x do canto 08: superior esquerdo, e que todas as coordenadas sao positivas. */ 09: 10: #include <stdio.h> 11: 12: int comprimento, largura; 13: long area; 14: 15: struct coord { 16: int x; 17: int y; 18: }; 19: 20: struct retangulo { 21: struct coord sup_esq; 22: struct coord inf_dir; 23: } caixa; 24: 25: main() 26: { 27: /* Recebe as coordenadas */ 28: 29: printf( \ndigite a coordenada x superior esquerda: ); 30: scanf( %d, &caixa.sup_esq.x); 31: 32: printf( \ndigite a coordenada y superior esquerda: ); 33: scanf( %d, &caixa.sup_esq.y); 34: 35: printf( \ndigite a coordenada x inferior direita: ); 36: scanf( %d, &caixa.inf_dir.x); 37: 38: printf( \ndigite a coordenada y inferior direita: ); 39: scanf( %d, &caixa.inf_dir.y); 40: 41: /* Calcula o comprimento e a largura */ 42: largura = caixa.inf_dir.x caixa.sup_esq.x; 43: comprimento = caixa.inf_dir.y caixa.sup_esq.y; 44: 45: /* Calcula e informa a area */ 46: area = largura * comprimento; 47: printf( \na área do retângulo é de %ld unidades., area); 48: }

19 Linguagem de Programação C - notas de aula - parte 2 Página: ESTRUTURAS QUE CONTÊM MATRIZES: Pode-se definir uma estrutura cujos membros incluam uma ou mais matrizes. A matriz pode ser de qualquer tipo válido em C. Vejamos isto através de um exemplo: Exemplo de Estruturas que Contêm Matrizes: // definição da estrutura ALUNO contendo duas matrizes struct aluno { char nome[10]; float nota[3]; }; // declaração de uma instância da estrutura ALUNO struct aluno ZEZINHO; A estrutura definida acima poderia ser representada da seguinte forma: zezinho.nome[7] zezinho.nome zezinho.nota zezinho.nota[2] Para acessar os membros da estrutura, usa-se as mesmas instruções de manipulação de matrizes: zezinho.nota[2] = 10; zezinho.nome[1] = J ;

20 Linguagem de Programação C - notas de aula - parte 2 Página: 18 Exemplo de programa com estrutura que contêm matrizes:. 01: /* Demonstra uma estrutura que contem matrizes como membros */ 02: 03: #include <stdio.h> 04: 05: /* Define e declara uma estrutura para conter os dados, */ 06: /* cujos membros sao uma variavel float e duas matrizes char. */ 07: 08: struct dados { 09: float quantia; 10: char nome[30]; 11: char snome[30]; 12: } reg; 13: 14: main() 15: { 16: /* Recebe os dados do teclado. */ 17: 18: printf( Digite o nome e o sobrenome do doador,\n ); 19: printf( separados por um espaco: ); 20: scanf( %s %s, reg.nome, reg.snome); 21: 22: printf( \ndigite a quantia doada: ); 23: scanf( %f, &reg.quantia); 24: 25: /* Exibe as informacoes. */ 26: /* Nota: %.2f especifica um valor de ponto flutuante */ 27: /* que deve ser impresso com dois algarismos a direita */ 28: /* do ponto decimal. */ 29: 30: /*Exibe os dados na tela */ 31: 32: printf( \no doador %s %s deu $%.2f., reg.nome, reg.snome, reg.quantia); 33: 34: }

21 Linguagem de Programação C - notas de aula - parte 2 Página: MATRIZES DE ESTRUTURAS: As matrizes de estruturas são ferramentas de programação poderosas. Significa que, partindo de uma estrutura definida, pode-se ter uma matriz onde cada elemento é uma estrutura deste tipo. Por exemplo, supondo uma estrutura como declarada abaixo: struct dados_pessoa { char nome[10]; char sobrenome[12]; char fone[8]; }; Esta estrutura poderia ser representada da seguinte forma: estrutura dados_pessoa nome sobrenome fone Para definir uma matriz a partir desta estrutura poderia ser usada, por exemplo, a seguinte definição: struct dados_pessoa cliente[5]; cliente[0] cliente[1] cliente[2] cliente[3] cliente[4] nome sobrenome fone nome sobrenome fone nome sobrenome fone nome sobrenome fone nome sobrenome fone

22 Linguagem de Programação C - notas de aula - parte 2 Página: 20 Exemplo de programa com matrizes de estruturas: 01: * Demonstra o uso de matrizes de estruturas */ 02: 03: #include <stdio.h> 04: #define tam 5 05: 06: main() 07: { 08: struct dados_aluno 09: { 10: char nome[15]; 11: float media; 12: int ano_nasc; 13: } aluno[tam]; 14: 15: int x; 16: 17: /* Recebe os dados do teclado. */ 18: 19: for(x=0;x<tam;x++) 20: { 21: printf("\ndigite o nome do %io. aluno: ",x+1); 22: scanf("%s", aluno[x].nome); 23: printf("digite a média deste aluno: "); 24: scanf("%f", &aluno[x].media); 25: printf("digite o ano de nascimento deste aluno: "); 26: scanf("%i", &aluno[x].ano_nasc); 27: } 28: 29: /*Exibe os dados na tela */ 30: 31: printf("\n\tnomes \tmedias\tidades"); 32: 33: for(x=0;x<tam;x++) 34: { 35: printf("\n\t%s\t%.2f\t%i",aluno[x].nome,aluno[x].media, 2001-aluno[x].ano_nasc); 36: } 37: 38: }

23 Linguagem de Programação C - notas de aula - parte 2 Página: INICIALIZANDO ESTRUTURAS: As estruturas podem ser inicializadas ao serem declaradas. O procedimento é semelhante ao adotado para inicializar matrizes: coloca-se um sinal de igualdade após a declaração da estrutura seguido de uma lista de valores separados por vírgula e delimitados por chaves. Por exemplo: struct venda { char cliente[10]; char item[10]; float quantidade; } ultima_venda = { Fulano, Rebimboca,10.5}; No caso de uma estrutura que contenha outras estruturas como membros, os valores de inicilização devem ser listados em ordem. Esses valores serão armazenados nos membros da estrutura no ordem em que os membros estão listados na definição da estrutura. Por exemplo: struct cliente { char empresa[20]; char contato[15]; }; struct venda { struct cliente comprador; char item[10]; float quantidade; } primeira_venda = { { Indústria Acme, Fulano }, Rebimboca, 10.5 };

24 Linguagem de Programação C - notas de aula - parte 2 Página: 22 No caso de uma matriz de estrutura, os dados de inicilização fornecidos serão aplicados, pela ordem, às estruturas da matriz. Por exemplo: struct cliente { char empresa[20]; char contato[15]; }; struct venda { struct cliente comprador; char item[10]; float quantidade; } diaria[10] = { { /* Dados para diaria[0] */ { Indústria Acme, Fulano }, Rebimboca, 10.5 } { /* Dados para diaria[1] */ { ABC Ltda., Beltrano }, Parafuseta, 5.6 } { /* Dados para diaria[2] */ { Cia. XYZ, Cicrano }, Treco, 17.0 } }; No exemplo acima, apenas os três primeiros elementos da matriz de estrutura diaria receberam informações. Os demais elementos não foram inicializados.

25 Linguagem de Programação C - notas de aula - parte 2 Página: ESTRUTURAS E PONTEIROS Pode-se usar ponteiros como membros de estruturas e também declarar ponteiros que apontem para estruturas. 6.1 Ponteiros Como Membros de Estruturas: Para usar um ponteiro como membro de uma estrutura, para declará-los precedidos do operador de indireção (*), tal como na declaração comum de ponteiros. Por exemplo: struct financiamento { int *valor; float *juros; }fin_automovel; Estas instruções declaram uma estrutura denominada financiamento que possui dois membros que são ponteiros. Além disso, uma estrutura denominada fin_automovel é definida com este gabarito de financiamento. A inicialização dos ponteiros acima declarados pode ser, por exemplo: fin_automovel.valor = &custo_total; fin_automovel.juros = &taxa; Também pode-se usar o operador de indireção para acessar o valor das variáveis apontadas por estes ponteiros: printf( \nvalor: %d, *fin_automovel.valor); tot = *fin_automovel.valor + *fin_automovel.juros;

26 Linguagem de Programação C - notas de aula - parte 2 Página: Ponteiros para Strings como Membros de Estruturas: O uso mais comum de ponteiros como membros de estruturas é o de ponteiros para strings, como no exemplo abaixo: struct mensagem { char *msg1; char *msg2; } observacao; Tal como no uso comum de ponteiros para strings, podese inicializá-lo diretamento com um string, como abaixo: observação.msg1= Primeira mensagem de observação ; observação.msg2= Segunda mensagem de observação ; Desta mesma forma, os ponteiros que são membros de estruturas podem ser usados em qualquer lugar em que um ponteiro normal poderia ser usado. Por exemplo: printf( %s %s,observação.msg1, observação.msg2) puts(observação.msg1); puts(observação.msg2);

27 Linguagem de Programação C - notas de aula - parte 2 Página: Ponteiros para strings x Matrizes de char em Estruturas: Tanto o uso de ponteiros para strings quanto o uso de matrizes para o tipo char são usados para armazenar um string dentro de uma estrutura. Definição de Ponteiros para Strings x Matrizes do tipo char: struct msg { char p1[20]; char *p2; } obs; Uso de Ponteiros para Strings x Matrizes do tipo char: /* atribuição de valores */ strcpy(obs.p1, Primeira mensagem ); strcpy(obs.p2, Segunda mensagem ); /* impressão dos valores */ puts(obs.p1); puts(obs.p2); Observe que a forma de uso tanto de ponteiros para strings quanto de matrizes para o tipo char é idêntico. Assim, a diferença entre ambos consiste basicamente em: Ao definir uma estrutura que contenha uma matriz do tipo char, todas as instâncias desse tipo de estrutura conterão espaço de armazenagem para o tamanho especificado. Além disso, com o uso de matrizes para o tipo char, o tamanho do string estará limitado ao tamanho

28 Linguagem de Programação C - notas de aula - parte 2 Página: 26 especificado e não poderá armazenar um número de caracteres maior na estrutura. Exemplo: limitação no uso de matrizes para o tipo char: // definição e declaração struct nome_completo { char prenome[10]; char sobrenome[10]; } cliente; // pode haver outras instruções aqui strcpy(cliente.prenome, Escolástica ); /* string maior que matriz provocará erros */ strcpy(cliente.sobrenome, Silva ); /* string menor que matriz desperdício de memória */ O uso de ponteiros para strings impede que tais problemas venham a ocorrrer. Vantagens do uso de ponteiros para strings no lugar de matrizes do tipo char: Cada instância da estrutura conterá apenas o espaço de armazenagem necessário para o próprio ponteiro; Os strings propriamente ditos serão armazenados em qualquer outra parte da memória (não há necessidade de se saber onde); Não há restrição ao tamanho do string nem haverá espaço ocioso; Cada ponteiro da estrutura pode apontar para um string de qualquer tamanho; Os strings referenciados por estes ponteiros passam a fazer parte da estrutura indiretamente.

29 Linguagem de Programação C - notas de aula - parte 2 Página: PONTEIROS PARA ESTRUTURAS: É possível declarar e usar ponteiros que apontem para estruturas exatamente como são usados para qualquer outro tipo de armazenagem de dados. As grandes utilidades deste tipo de ponteiro são: para passar uma estrutura para uma função; para usá-los em listas encadeadas. Exemplo do uso de Ponteiros para Estruturas: /* definição e declaração da estrutura */ struct produto { int codigo; char nome[10]; } prod1; /* declaração de um ponteiro para esta estrutura */ struct produto *p_prod; /* inicialização do ponteiro */ p_prod = &prod1; /* atribuição de valor através da indireção */ (*p_prod).codigo = 100; // prod1.codigo = 100; strcpy((*p_prod).nome,"rebimboca"); /* operador (.) tem prioridade sobre (*) */ /* impressão dos valores através da indireção */ printf("%d\n",(*p_prod).codigo); printf("%s\n",(*p_prod).nome); puts((*p_prod).nome);

30 Linguagem de Programação C - notas de aula - parte 2 Página: 28 Outra forma de acessar membros da estrutura através de ponteiros é com o uso do operador de acesso a membro (->) como mostrado a seguir: printf("%d\n",p_prod->codigo); puts(p_prod->nome); p_prod->codigo é similar a (*p_prod).codigo struct produto { int codigo; char nome[10]; } prod[100]; /* declaração de um ponteiro para esta estrutura */ struct produto *p_prod; p_prod = &prod[0]; // p_prod = prod; // usando a matriz prod for(i=0;i<100;i++) { printf( Digite o código do %i o produto: ); scanf( %d,&prod[i].codigo) printf( Digite o nome do %i o produto: ); scanf( %s,prod[i].nome) } // usando o ponteiro p_prod for(i=0;i<100;i++) { printf( Digite o código do %i o produto: ); scanf( %d,&p_prod->codigo) printf( Digite o nome do %i o produto: ); scanf( %s,p_prod->nome) p_prod++; } // no final, o ponteiro estará apontando para // o fim da matriz (um endereço após o último)

31 Linguagem de Programação C - notas de aula - parte 2 Página: 29 PONTEIROS E MATRIZES DE ESTRUTURAS: 01: /* Demonstra a progressao atraves de unia matriz de estruturas */ 02: /* usando a notacao de ponteiros. */ 03: 04: #include <stdio.h> 05: 06: #define MAX 4 07: 08: /* Define uma estrutura, depois declara e inicializa */ 09: /* uma matriz contendo 4 estruturas. */ 10: 11: struct peca { 12: int numero; 13: char nome[10]; 14: } dados[max] = {1, Smith, 15: 2, Jones, 16: 3, Adams, 17: 4, Wilson 18: }; 19: 20: /* Declara um ponteiro p/o tipo peca e uma variavel de contagem */ 21: 22: struct peca *p_peca; 23: int contagem; 24: 25: main() 26: { 27: /* Inicializa o ponteiro para o primeiro elemento da matriz */ 28: 29: p_peca = dados; 30: 31: /* Faz um loop atraves da matriz, incrementando o ponteiro */ 32: /* a cada iteracao. */ 33: 34: for (contagem = 0; contagem < MAX; contagem++) 35: { 36: printf( \nno endereco %d: %d %s,p_peca, p_peca >numero, p_peca >nome); 37: p_peca++; 38: 39: } 40: 41: }

32 Linguagem de Programação C - notas de aula - parte 2 Página: 30 PONTEIROS E MATRIZES DE ESTRUTURAS: 01: /* Demonstra o uso de estrutura como argumento de uma função */ 02: 03: #include <stdio.h> 04: 05: /* Define e declara uma estrutura para conter os dados */ 06: 07: struct dados { 08: float quantia; 09: char nome[30]; 10: char snome[30]; 11: } reg; 12: 13: /* O protótipo da função: A função não tem valor de retorno e */ 14: /* aceita como único argumento uma estrutura do tipo dados. */ 15: 16: void print_reg(struct dados x); 17: 18: main() 19: { 20: /* Recebe os dados do teclado. */ 21: 22: printf( Digite o nome e o sobrenome do doador,\n ); 23: printf( separados por um espaço: ); 24: scanf( %s %s, reg.nome, reg.snome); 25: 26: printf( \ndigite a quantia doada: ); 27: scanf( %f, &reg.quantia); 28: 29: /* Chama a função que exibe os dados. */ 30: 31: print_reg( reg ); 32: } 33: 34: void print_reg(struct dados x) 35: { 36: printf( \no doador %s %s deu $%.2f., x.nome, x.snome, x.quantia); 37: } Digite o nome e o sobrenome do doador, separados por um espaço: Carlos Silva Digite a quantia doada: O doador Carlos Silva deu $

33 Linguagem de Programação C - notas de aula - parte 2 Página: ARQUIVOS EM DISCO ARQUIVO (conceito): Uma coleção de bytes armazenados em memória secundária (disquete, disco rígido, fita magnética, etc.), e referenciados por um nome comum. IBPI, Dominando a linguagem C Os dados manipulados em C, a princípio, vêm do teclado (dispositivo padrão de entrada STDIN) e são enviados para a tela (dispositivo padrão de saída STDOUT). A linguagem C permite que sejam manipulados outros dispositivos de entrada e saída, como a impressora (STDPRN) ou mesmo arquivos em disco. Os arquivos em disco manipulados pela linguagem C podem ser do tipo texto ou do tipo binário. ARQUIVO EM MODO DE TEXTO: Um arquivo em modo de texto é uma seqüência de linhas, onde cada linha contém zero ou mais caracteres e termina com caracteres de sinalização de fim de linha. Uma linha não é um string pois não termina com \0 e sim com \n. Um \n é um sinalizador de fim de linha e, em geral, é representado pelos caracteres CR (carriage return) e LF (line feed). ARQUIVO EM MODO BINÁRIO: Um arquivo em modo binário é uma seqüência de caracteres onde os dados são gravados e lidos exatamente como estão armazenados na memória (2 bytes para inteiros, 4 bytes para float e assim por diante).

34 Linguagem de Programação C - notas de aula - parte 2 Página: 32 NOMES DE ARQUIVOS: Ao lidar com arquivos é preciso mencionar o nome do arquivo desejado. Os nomes de arquivos são armazenados em strings e são idênticos aos nomes usados pelo sistema operacional, seguindo portanto as mesmas regras de nomenclatura. Nomes de arquivos podem conter também informações sobre o drive e o diretório onde se encontra. Como exemplo, no DOS, poderíamos ter o arquivo: C:\DATA\LIST.TXT Num programa em C, este mesmo arquivo poderia ser mencionado da seguinte forma: char *nomearq = C:\\DATA\\LIST.TXT ; Observações: o uso de duas barras invertidas consecutivas deve-se ao fato que, em C, uma barra invertida possui um significado especial quando colocada dentro de um string; porém, se o nome do arquivo for especificado via teclado, deve-se digitar somente uma barra invertida. no DOS, a regra para nomenclatura de arquivos permite um nome e uma extensão de até três caracteres; os caracteres válidos são: - letras de A a Z - números de 0 a 9 - caracteres especiais como $ entre outros.

35 Linguagem de Programação C - notas de aula - parte 2 Página: A ESTRUTURA FILE: O tipo FILE é uma estrutura declarada em <stdio.h> cujos elementos são informações sobre o arquivo que está sendo acessado, tais como: status do arquivo, endereço do buffer para transferência de dados, posição corrente do ponteiro, entre outras. Cada arquivo manipulado pela linguagem C tem a ele associada uma estrutura do tipo FILE e o modo de referência ao arquivo passa a ser através de um ponteiro para essa estrutura: FILE *fptr; /* ponteiro para um arquivo */ fptr é um ponteiro para a estrutura FILE que será usado para referenciar o arquivo desejado dentro do programa. 7.2 ABRINDO ARQUIVOS: Para manipular arquivos na linguagem C é necessário, primeirament, abrir o arquivo, ou seja, deixá-lo disponível para leitura e/ou gravação. Para abrir um arquivo em C utiliza-se a função fopen, que devolve um ponteiro para a estrutura FILE associada ao arquivo: fptr = fopen(nomearq,modo); onde fptr: é o ponteiro para a estrutura FILE anteriormente declarado; nomearq: é o nome do arquivo a ser aberto e pode conter a especificação do drive e do diretório; pode ser um string literal entre aspas duplas ou um ponteiro para um string armazenado na memória; modo: especifica o modo em que o arquivo deve ser aberto, ou seja, se o arquivo estará em modo texto ou binário e se será

36 Linguagem de Programação C - notas de aula - parte 2 Página: 34 usado para leitura e/ou gravação de dados, conforme detalhado a seguir. Modos de abertura de arquivos: Modo texto Modo binário Significado r rb Abre o arquivo para leitura; se não existir, retorna null. w wb Abre o arquivo para gravação; se não existir, cria-o; se já existir, apaga os dados já gravados. a ab Abre o arquivo para acréscimo de dados (append); se não existir, cria-o; se já existir, acrescenta novos dados ao fim do arquivo. r+ rb+ Abre o arquivo para leitura e gravação; se não existir, cria-o; se já existir, acrescenta os novos dados no início deste arquivo, sobregravando os já existentes. w+ wb+ Abre o arquivo para leitura e gravação; se não existir, cria-o; se já existir, apaga os dados já existentes, sobregravando-os. a+ ab+ Abre o arquivo para leitura e acréscimo de dados; se não existir, cria-o; se já existir, acrescenta os novos dados no fim do arquivo. 7.3 FECHANDO ARQUIVOS: Ao encerrar o processamento do arquivo, devemos fechálo, isto é, indicar ao sistema operacional que o arquivo não está mais sendo utlizado. Para fechar um arquivo usa-se o seguinte procedimento: fclose(fptr); onde fptr: é o ponteiro para a estrutura FILE que foi usado para referenciar o arquivo na abertura.

37 Linguagem de Programação C - notas de aula - parte 2 Página: GRAVANDO ARQUIVOS, CARACTER A CARACTER: Após abrir o arquivo para gravação, pode-se escrever nele usando a função putc( ), como no exemplo abaixo: /* Primeiro, abre-se o arquivo p/ gravação */ fptr = fopen( C:\\TESTE.TXT, w ); /* Mais adiante,pode-se efetuar a gravação */ putc( A,fptr); Exemplo de gravação de arquivo em modo texto: 01: /* PROGRAMA EXEMPLO PARA GRAVAÇÃO DE UM ARQUIVO 02: TEXTO, CARACTER A CARACTER */ 03: 04: #include <stdio.h> 05: #include <conio.h> 06: 07: main() 08: { 09: FILE *fptr; 10: char ch; 11: 12: /* Abre o arquivo especialmente para gravação */ 13: fptr = fopen("c:\\luciana\\teste.txt","w"); 14: 15: /* Lê um caracter do teclado até ser digitado um 16: 'enter' (return) usando a função getche() */ 17: 18: while ((ch = getche())!= '\r') 19: putc(ch,fptr); // grava o caracter 20: 21: /* Fecha o arquivo */ 22: fclose(fptr); 23: }

38 Linguagem de Programação C - notas de aula - parte 2 Página: LENDO ARQUIVOS, CARACTER A CARACTER: Para ler dados anteriormente gravados num arquivo é preciso, primeiramente, abri-lo para leitura; em seguida, pode-se ler caracter a caracter, até encontrar o caracter de fim de arquivo (EOF). Para esta forma de leitura, pode-se usar a função getc( ), como no exemplo abaixo: /* Primeiro, abre-se o arquivo p/ leitura */ fptr = fopen( C:\\TESTE.TXT, r ); /* Mais adiante,pode-se efetuar a leitura */ getc(fptr); Exemplo de leitura de arquivo em modo texto: 01: /* PROGRAMA EXEMPLO PARA LEITURA DE UM ARQUIVO 02: TEXTO, CARACTER A CARACTER */ 03: 04: #include <stdio.h> 05: 06: main() 07: { 08: FILE *fptr; 09: int ch; 10: 11: /* Abre o arquivo especialmente para leitura */ 12: fptr = fopen("c:\\luciana\\teste.txt","r"); 13: 14: /* Lê um caracter do arquivo até ser encontrado um 15: caracter de 'fim de arquivo' (EOF) com getc() */ 16: 17: while ((ch = getc(fptr))!= EOF ) 18: putchar(ch); // imprime o caracter na tela 19: 20: /* Fecha o arquivo */ 21: fclose(fptr); 22: }

39 Linguagem de Programação C - notas de aula - parte 2 Página: ERROS AO ABRIR ARQUIVOS: Uma tentativa de abertura de arquivo pode resultar num erro. Por execmplo, você pode tentar abrir paa leitura um arquivo inexistente; pode não haver espaço em disco para gravação dos dados; pode ocorrer uma fallha na leitura do disco, etc. Por estes motivos, é importante que os programa que acessam arquivos em disco verifiquem se estes foram abertos com sucesso antes de tentar ler ou gravar informações. Para saber se houve um erro na abertura do arquivo, basta verificar se a função fopen retornou um caracter NULL: /* Checagem na abertura do arquivo p/ leitura */ if ((fptr = fopen( C:\\TESTE.TXT, r )) == NULL) puts( Erro ao abrir o arquivo ); /* Checagem na abertura do arquivo p/ gravação */ if ((fptr = fopen( C:\\TESTE.TXT, w )) == NULL) puts( Erro ao abrir o arquivo );

40 Linguagem de Programação C - notas de aula - parte 2 Página: GRAVANDO ARQUIVOS, LINHA A LINHA: É possível gravar strings diretamente num arquivo aberto para gravação através da função fputs( ). Para gerar um arquivo texto corretamente é necessário adicionar um caracter de fim de linha ( \n ) ao final de cada string. Exemplo de gravação de strings em arquivo em modo texto: 01: /* PROGRAMA EXEMPLO PARA GRAVAÇÃO DE UM ARQUIVO TEXTO, 02: LINHA A LINHA */ 03: 04: #include <stdio.h> 05: #include <string.h> 06: 07: main() 08: { 09: FILE *fptr; 10: char linha[80]; 11: 12: if ((fptr = fopen("c:\\teste.txt","w")) == NULL) 13: puts("erro na abertura do arquivo"); 14: else 15: { 16: do 17: { 18: puts("digite até 80 carateres para gravação no arquivo (deixe em branco para sair):"); 19: gets(linha); 20: if (strlen(linha)>0) /* se digitou algo */ 21: { 22: fputs(linha,fptr); // grava string no arq. 23: fputs("\n",fptr); // grava um fim de linha 24: } 25: } while (strlen(linha)>0); 26: } 27: 28: fclose(fptr); 29: }

41 Linguagem de Programação C - notas de aula - parte 2 Página: LENDO ARQUIVOS, LINHA A LINHA: Também é possível ler dados de um arquivo texto armazenando-os em strings através da função fgets( ). A função fgets( ) deve ser acompanhada de um valor que indica o número máximo de caracteres a serem lidos de cada vez. Exemplo de leitura de strings em arquivo em modo texto: 01: /* PROGRAMA EXEMPLO PARA LEITURA DE UM ARQUIVO TEXTO, 02: LINHA A LINHA */ 03: 04: #include <stdio.h> 05: #include <string.h> 06: 07: main() 08: { 09: FILE *fptr; 10: char linha[80]; 11: 12: if ((fptr = fopen("c:\\teste.txt","r")) == NULL) 13: puts("erro na abertura do arquivo"); 14: else 15: { 16: while (fgets(linha,80,fptr)!= NULL) 17: printf("%s",linha); 18: } 19: 20: fclose(fptr); 21: }

42 Linguagem de Programação C - notas de aula - parte 2 Página: ARQUIVOS BINÁRIOS 8.1 LENDO E GRAVANDO REGISTROS: A entrada e saída direta de arquivos é mais utlilizada para salvar dados que serão lidos posteriormente pelo mesmo programa ou por outro programa escrito em C. Esse modo de gravação/leitura só é usado em MODO BINÁRIO; As funções de entrada e saída direta são, respectivamente, fread( ) e fwrite( ), que serão detalhadas a seguir. Em arquivos binários, pode-se ainda efetuar acesso aleatório aos arquivos usando a função fseek( ), como será visto mais adiante. 8.2 GRAVAÇÃO DIRETA COM fwrite( ): A função fwrite( ) envia um bloco de dados da memória para um arquivo em modo binário, e é usada como abaixo: fwrite(endereço,tamanho,quantidade,ponteiro); onde: endereço é o endereço de memória onde se encontram os dados que devem ser gravados no arquivo (é um ponteiro do tipo void); tamanho corresponde ao número de bytes de cada item individual da dados que será gravado; quantidade especifica quantos itens individuais serão

43 Linguagem de Programação C - notas de aula - parte 2 Página: 41 gravados simultaneamente; ponteiro é o nome do ponteiro usado para indicar o arquivo conforme especificado na abertura do mesmo; A função fwrite( ) retorna o número de itens gravados com sucesso; se este número for menor que tamanho, isso significa que ocorreu algum erro. Exemplos do uso da função fwrite: /* Grava uma única variável do tipo int */ fwrite(&x,sizeof(int),1,fptr); /* Grava uma única variável do tipo double */ fwrite(&y,sizeof(float),1,fptr); /* Grava uma matriz denominada aluno contendo 50 estruturas do tipo registro */ fwrite(aluno,sizeof(registro),50,fptr); /* Grava a matriz anterior como um único bloco */ fwrite(matriz,sizeof(matriz),1,fptr); /* Grava uma variável do tipo int e testa o sucesso*/ if ( fwrite(&x,sizeof(int),1,fptr) =! 1)...// erro

44 Linguagem de Programação C - notas de aula - parte 2 Página: 42 Programa exemplo com gravação direta (modo binário): 01: /* PROGRAMA EXEMPLO DE GRAVAÇÃO DIRETA EM ARQUIVO BINÁRIO */ 02: #include <stdio.h> 03: #include <string.h> 04: 05: 06: struct data 07: { 08: int dia; 09: int mes; 10: int ano; 11: }; 12: 13: struct registro 14: { 15: char nome[20]; 16: char endereco[30]; 17: char fone[15]; 18: char cpf[11]; 19: struct data nasc; 20: } cliente; 21: 22: main() 23: { 24: FILE *fptr; 25: 26: fptr = fopen("c:\\cliente.bin","wb"); 27: 28: do 29: { 30: fflush(stdin); 31: puts("digite o nome do cliente ou <FIM> para sair:"); 32: gets(cliente.nome); 33: if ( strcmp ( cliente.nome, "FIM" )!= 0 ) 34: { 35: puts("digite o endereço do cliente:"); 36: gets(cliente.endereco); 37: puts("digite o telefone do cliente:"); 38: gets(cliente.fone); 39: puts("digite o CPF do cliente:"); 40: gets(cliente.cpf); 41: puts("digite dia, mes e ano de nasc. do cliente:"); 42: scanf("%d %d %d",&cliente.nasc.dia, &cliente.nasc.mes,&cliente.nasc.ano); 43: fwrite(&cliente,sizeof(registro),1,fptr); 44: } 45: } while ( strcmp ( cliente.nome, "FIM" )!= 0 ); 46: fclose(fptr); 47: }

45 Linguagem de Programação C - notas de aula - parte 2 Página: LEITURA DIRETA COM fread( ): A função fread( ) lê um bloco de dados de um arquivo em modo binário para a memória e é usada como abaixo: fread(endereço,tamanho,quantidade,ponteiro); onde: endereço é o endereço de memória onde os dados lidos serão armazenados (é um ponteiro do tipo void); tamanho corresponde ao número de bytes de cada item individual da dados que será lido; quantidade especifica quantos itens individuais serão lidos simultaneamente; ponteiro é o nome do ponteiro usado para indicar o arquivo conforme especificado na abertura do mesmo; A função fread( ) retorna o número de itens lidos que pode ser menor que tamanho se for lido um caractere de fim-de-arquivo ou se ocorrer algum erro na leitura. Exemplos do uso da função fwrite: /* Lê uma única variável do tipo int */ fread(&x,sizeof(int),1,fptr); /* Lê uma única variável do tipo double */ fread(&y,sizeof(float),1,fptr); /* Lê dados do arquivo e armazena-os numa matriz denominada aluno contendo 50 estruturas do tipo registro */ fread(aluno,sizeof(registro),50,fptr); /* Lê dados do arquivo e armazena-os na matriz anterior de uma só vez (como um único bloco) */ fread(matriz,sizeof(matriz),1,fptr); /* Lê uma variável do tipo int e testa o sucesso*/ if ( fread(&x,sizeof(int),1,fptr) =! 1)...// erro

46 Linguagem de Programação C - notas de aula - parte 2 Página: 44 Programa exemplo com leitura direta (modo binário): 01: /* PROGRAMA EXEMPLO DE LEITURA DIRETA EM ARQUIVO BINÁRIO */ 02: #include <stdio.h> 03: #include <string.h> 04: 05: struct data 06: { 07: int dia; 08: int mes; 09: int ano; 10: }; 11: 12: struct registro 13: { 14: char nome[20]; 15: char endereco[30]; 16: char fone[15]; 17: char cpf[11]; 18: struct data nasc; 19: } cliente; 20: 21: main() 22: { 23: FILE *fptr; 24: 25: fptr = fopen("c:\\cliente.bin","rb"); 26: 27: do 28: { 29: /* se leitura for feita com sucesso, imprima dados */ 30: if ( fread(&cliente,sizeof(registro),1,fptr) == 1 ) 31: { 32: printf("%s %s %s %s %d/%d/%d\n",cliente.nome, cliente.endereco,cliente.fone,cliente.cpf, cliente.nasc.dia,cliente.nasc.mes,cliente.nasc.ano); 33: } 34: } while (! feof(fptr) ); 35: 36: fclose(fptr); 37: }

47 Linguagem de Programação C - notas de aula - parte 2 Página: TIPOS DE ACESSO A ARQUIVOS: Todo arquivo aberto tem a ele associado um ponteiro de arquivo que aponta para a posição atual do arquivo, indicando qual o próximo byte que deve ser lido e/ou gravado; Esse ponteiro ou indicador de posição é especificado em termos de bytes a partir da posição inicial do arquivo, que é a posição 0 (zero); Quando um arquivo é novo, seu comprimento é zero e não há outra posição a ser indicada; ACESSO SEQÜENCIAL Nos exemplos vistos até agora, os arquivos eram acessados de forma seqüencial, com as seguintes características: Quando um arquivo já existe e é aberto, o indicador de posição aponta para o final do arquivo caso tenha sido especificado o modo de acréscimo de dados (append), ou para o seu início quando outro modo é usado; Quando é feita a leitura de dados, o indicador de posição é automaticamente movido para a próxima posição a ser lida, seqüencialmente. O mesmo ocorre durante a gravação, ou seja, após gravar os novos dados logo abaixo dos dados existentes, o indicador de posição é automaticamente movido para a posição subseqüente (seqüencialmente);

48 Linguagem de Programação C - notas de aula - parte 2 Página: CONTROLANDO O INDICADOR DE POSIÇÃO A função rewind( ) permite mover o indicador de posição do para o início do arquivo, independentemente de onde se encontre num dado momento; A sintaxe desta função é: rewind(fptr) onde fptr é o nome do ponteiro usado para indicar o arquivo conforme especificado na abertura do mesmo; A função ftell( ) indica o valor atual do indicador de posição de um arquivo. Esta função retorna um inteiro longo (que é o número do byte onde está localizado o indicador de posição ) e sua sintaxe é: ftell(fptr) onde fptr é o nome do ponteiro usado para indicar o arquivo conforme especificado na abertura do mesmo;

49 Linguagem de Programação C - notas de aula - parte 2 Página: ACESSO ALEATÓRIO O acesso aleatório, ao contrário do seqüencial, permite que a transferência de dados seja feita de/para qualquer posição do arquivo, sem que as informações anteriores precisem ser acessadas. A função que permite o acesso aleatório a um arquivo é fseek( ) e sua sintaxe é a seguinte: fseek(fptr,offset,origem) onde fptr é o nome do ponteiro usado para indicar o arquivo conforme especificado na abertura do mesmo; offset é o deslocamento, em bytes, contado a partir da origem; origem indica a origem do deslocamento e pode ser: 0 (início do arquivo) 1 (posição atual do indicador de posição ) 2 (fim do arquivo) Note que, quando a origem especificado for o fim do arquivo (valor 2), o deslocamento (offset) deve ser negativo;

50 Linguagem de Programação C - notas de aula - parte 2 Página: Funções de gerenciamento de arquivos: 9.1 Apagando um arquivo: /* Demonstra o uso da função remove().*/ #include <stdio.h> #include <stdlib.h> main() { char nomearq[80]; printf("digite o nome do arquivo a ser apagado:"); gets(nomearq); } if(remove(nomearq)==0) printf("o arquivo %s foi apagado.",nomearq); else printf("erro ao apagar o arquivo %s.",nomearq); 9.2 Mudando o nome de um arquivo: /* Mudando o nome de um arquivo usando rename().*/ #include <stdio.h> #include <stdlib.h> main(){ char oldname[80], newname[80]; printf("digite o nome atual:"); gets(oldname); printf("digite o novo nome:"); gets(newname); if (rename(oldname, newname) == 0) printf("o nome de %s foi mudado para %s.", oldname, newname); else printf("erro ao renomear %s.",oldname); }

51 Linguagem de Programação C - notas de aula - parte 2 Página: Copiando um arquivo: /* Copiando um arquivo.*/ #include <stdio.h> #include <stdlib.h> #include <string.h> int copia_arq(char *nomeorigem, char *nomedestino); main(){ char origem[80], destino[80]; /* Obtem os nomes dos arquivos de origem e de destino.*/ printf("\ndigite o nome do arquivo de origem:"); gets(origem); printf("\ndigite o nome do arquivo de destino:"); gets(destino); } if(copia_arq(origem, destino) == 0) puts("arquivo copiado sem problemas."); else printf("erro durante a operação de cópia."); int copia_arq(char *origem, char *destino){ FILE *forigem, *fdestino; int c; /*Abre o arq.de origem para leitura em modo binário.*/ if ((forigem = fopen(origem, "rb"))== NULL) return -1; /*Abre arq.de destino para gravação em modo binário.*/ if ((fdestino = fopen(destino, "wb"))== NULL){ } fclose(forigem); return -1; /* Le 1 byte de cada vez do arq. de origem. */

52 Linguagem de Programação C - notas de aula - parte 2 Página: 50 /* se o fim do arquivo ainda não foi atingido, */ /* grava o byte no arquivo de destino.*/ while(1) { c= fgetc(forigem); if (!feof(forigem)) fputc(c, fdestino); else break; } fclose(forigem); fclose(fdestino); } return 0; 9.4 Usando arquivos temporários: /* Demonstra o uso de arquivos temporarios.*/ #include <stdio.h> main(){ char buffer[10], *c; /*Obtem um nome temporario no buffer especificado.*/ tmpnam(buffer); /*Obtem outro nome, desta vez no buffer interno*/ /* da própria função.*/ c = tmpnam(null); /* Exibe os nome.*/ } printf("o nome temporario 1 e $\%s", buffer); printf("\no nome temporario 2 e %s", c);

Manipulação de Arquivos

Manipulação de Arquivos Manipulação de Arquivos Estrutura de Dados II Prof. Guilherme Tavares de Assis Universidade Federal de Ouro Preto UFOP Instituto de Ciências Exatas e Biológicas ICEB Departamento de Computação DECOM Tipo

Leia mais

Introdução. Manipulação de arquivos em C. Estrutura de Dados II Prof Jairo Francisco de Souza

Introdução. Manipulação de arquivos em C. Estrutura de Dados II Prof Jairo Francisco de Souza Introdução Manipulação de arquivos em C Estrutura de Dados II Prof Jairo Francisco de Souza Manipulação de Arquivo em C Existem dois tipos possíveis de acesso a arquivos na linguagem C : sequencial (lendo

Leia mais

Algoritmos e Programação _ Departamento de Informática

Algoritmos e Programação _ Departamento de Informática 16 ARQUIVOS Um arquivo corresponde a um conjunto de informações (exemplo: uma estrutura de dados-registro), que pode ser armazenado em um dispositivo de memória permanente, exemplo disco rígido. As operações

Leia mais

INF 1005 Programação I

INF 1005 Programação I INF 1005 Programação I Aula 12 Cadeia de Caracteres (Strings) Edirlei Soares de Lima Caracteres Até o momento nós somente utilizamos variáveis que armazenam números (int, float ou

Leia mais

LP II Estrutura de Dados. Introdução e Linguagem C. Prof. José Honorato F. Nunes [email protected]

LP II Estrutura de Dados. Introdução e Linguagem C. Prof. José Honorato F. Nunes honorato.nunes@ifbaiano.bonfim.edu.br LP II Estrutura de Dados Introdução e Linguagem C Prof. José Honorato F. Nunes [email protected] Resumo da aula Considerações Gerais Introdução a Linguagem C Variáveis e C Tipos de

Leia mais

Programação de Computadores I. Linguagem C Arquivos

Programação de Computadores I. Linguagem C Arquivos Linguagem C Arquivos Prof. Edwar Saliba Júnior Novembro de 2011 Unidade 12 Arquivos 1 Trabalhando com Arquivos Um arquivo em Linguagem C pode representar diversas coisas, como: arquivos em disco, uma impressora,

Leia mais

Capítulo 2: Introdução à Linguagem C

Capítulo 2: Introdução à Linguagem C Capítulo 2: Introdução à Linguagem C INF1005 Programação 1 Pontifícia Universidade Católica Departamento de Informática Programa Programa é um algoritmo escrito em uma linguagem de programação. No nosso

Leia mais

Algoritmos e Estruturas de Dados I 01/2013. Arquivos. Pedro O.S. Vaz de Melo

Algoritmos e Estruturas de Dados I 01/2013. Arquivos. Pedro O.S. Vaz de Melo Algoritmos e Estruturas de Dados I 01/2013 Arquivos Pedro O.S. Vaz de Melo Problema 1 Considere que um arquivo de dados contém os valores das dimensões (tam. max.: 100) e dos elementos de duas matrizes

Leia mais

Persistência de Dados

Persistência de Dados Persistência de s Universidade do Estado de Santa Catarina - Udesc Centro de Ciências Tecnológicas - CCT Departamento de Ciência da Computação Tecnologia de Sistemas de Informação Estrutura de s II - DAD

Leia mais

Algoritmos e Programação Estruturada

Algoritmos e Programação Estruturada Algoritmos e Programação Estruturada Virgínia M. Cardoso Linguagem C Criada por Dennis M. Ritchie e Ken Thompson no Laboratório Bell em 1972. A Linguagem C foi baseada na Linguagem B criada por Thompson.

Leia mais

INF 1005 Programação I

INF 1005 Programação I INF 1005 Programação I Aula 03 Introdução a Linguagem C Edirlei Soares de Lima Estrutura de um Programa C Inclusão de bibliotecas auxiliares: #include Definição de constantes:

Leia mais

2. OPERADORES... 6 3. ALGORITMOS, FLUXOGRAMAS E PROGRAMAS... 8 4. FUNÇÕES... 10

2. OPERADORES... 6 3. ALGORITMOS, FLUXOGRAMAS E PROGRAMAS... 8 4. FUNÇÕES... 10 1. TIPOS DE DADOS... 3 1.1 DEFINIÇÃO DE DADOS... 3 1.2 - DEFINIÇÃO DE VARIÁVEIS... 3 1.3 - VARIÁVEIS EM C... 3 1.3.1. NOME DAS VARIÁVEIS... 3 1.3.2 - TIPOS BÁSICOS... 3 1.3.3 DECLARAÇÃO DE VARIÁVEIS...

Leia mais

Introdução à Programação

Introdução à Programação Introdução à Programação Introdução a Linguagem C Construções Básicas Programa em C #include int main ( ) { Palavras Reservadas } float celsius ; float farenheit ; celsius = 30; farenheit = 9.0/5

Leia mais

V - Lista de Exercícios de SO e Lab. 1-) Escreva um programa em C para criar um arquivo texto, com informações fornecidas pelo usuário não formatadas.

V - Lista de Exercícios de SO e Lab. 1-) Escreva um programa em C para criar um arquivo texto, com informações fornecidas pelo usuário não formatadas. V - Lista de Exercícios de SO e Lab. Assunto: Ponteiros e Arquivos Prof. Ricardo W. Saad CTIG 1-) Escreva um programa em C para criar um arquivo texto, com informações fornecidas pelo usuário não formatadas.

Leia mais

Vetores. Vetores. Figura 1 Exemplo de vetor com 10 elementos

Vetores. Vetores. Figura 1 Exemplo de vetor com 10 elementos Vetores Nos capítulos anteriores estudamos as opções disponíveis na linguagem C para representar: Números inteiros em diversos intervalos. Números fracionários com várias alternativas de precisão e magnitude.

Leia mais

1 Funções básicas de implementação de arquivos

1 Funções básicas de implementação de arquivos 1 Funções básicas de implementação de arquivos 1.1 Definindo registros Depois de um objeto do mundo real ter sido modelado, ou seja, após seus atributos importantes (e relevantes) terem sido identificados,

Leia mais

Exercício 1. Tabela 1: Cadastro de usuários, senhas e privilégios (exemplo). Login Senha Privilégio Armamento

Exercício 1. Tabela 1: Cadastro de usuários, senhas e privilégios (exemplo). Login Senha Privilégio Armamento 1/5 Exercício 1 Um sistema de segurança militar, usado num submarino nuclear, controla o acesso de usuários a três subsistemas (armamento, navegação e comunicações) através da digitação do login do usuário

Leia mais

INTRODUÇÃO À LINGUAGEM C++

INTRODUÇÃO À LINGUAGEM C++ INTRODUÇÃO À LINGUAGEM C++ 1 - VARIÁVEIS Variáveis espaço de memória reservado para armazenar tipos de dados, com um nome para referenciar seu conteúdo. Observações importantes Todas as variáveis devem

Leia mais

Algoritmos e Estruturas de Dados I. Arquivos. Pedro O.S. Vaz de Melo

Algoritmos e Estruturas de Dados I. Arquivos. Pedro O.S. Vaz de Melo Algoritmos e Estruturas de Dados I Arquivos Pedro O.S. Vaz de Melo Problema 1 Considere que um arquivo de dados contém os valores das dimensões (tam. max.: 100) e dos elementos de duas matrizes de números

Leia mais

Estrutura da linguagem de programação C Prof. Tiago Eugenio de Melo [email protected]

Estrutura da linguagem de programação C Prof. Tiago Eugenio de Melo tiago@comunidadesol.org Estrutura da linguagem de programação C Prof. Tiago Eugenio de Melo [email protected] Breve Histórico A linguagem de programação C foi criada na década de 70, por Dennis Ritchie, que a implementou,

Leia mais

14. Arquivos. W. Celes e J. L. Rangel. Estruturas de Dados PUC-Rio 13-1

14. Arquivos. W. Celes e J. L. Rangel. Estruturas de Dados PUC-Rio 13-1 14. Arquivos W. Celes e J. L. Rangel Neste capítulo, apresentaremos alguns conceitos básicos sobre arquivos, e alguns detalhes da forma de tratamento de arquivos em disco na linguagem C. A finalidade desta

Leia mais

Conceitos básicos da linguagem C

Conceitos básicos da linguagem C Conceitos básicos da linguagem C 2 Em 1969 Ken Thompson cria o Unix. O C nasceu logo depois, na década de 70. Dennis Ritchie, implementou-o pela primeira vez usando o sistema operacional UNIX criado por

Leia mais

Linguagem de Programação I

Linguagem de Programação I Linguagem de Programação I Curso de Sistemas de Informação Karla Donato Fook [email protected] DESU / DAI 2016 Linguagem de Programação C 2 1 Linguagem de Programação C Os programas em C consistem em

Leia mais

Sistemas Operacionais e Introdução à Programação. Programação com linguagem C

Sistemas Operacionais e Introdução à Programação. Programação com linguagem C Sistemas Operacionais e Introdução à Programação Programação com linguagem C 1 Variáveis na linguagem C: tipo char O tipo char representa um caractere ASCII (ocupa só 1 byte) int main(int argc, char **

Leia mais

Componentes da linguagem C++

Componentes da linguagem C++ Componentes da linguagem C++ C++ é uma linguagem de programação orientada a objetos (OO) que oferece suporte às características OO, além de permitir você realizar outras tarefas, similarmente a outras

Leia mais

PROGRAMAÇÃO ESTRUTURADA. CC 2º Período

PROGRAMAÇÃO ESTRUTURADA. CC 2º Período PROGRAMAÇÃO ESTRUTURADA CC 2º Período PROGRAMAÇÃO ESTRUTURADA Aula 06: Ponteiros Declarando e utilizando ponteiros Ponteiros e vetores Inicializando ponteiros Ponteiros para Ponteiros Cuidados a serem

Leia mais

Orientação a Objetos

Orientação a Objetos 1. Domínio e Aplicação Orientação a Objetos Um domínio é composto pelas entidades, informações e processos relacionados a um determinado contexto. Uma aplicação pode ser desenvolvida para automatizar ou

Leia mais

17 - Funções e Procedimentos em C Programação Modular

17 - Funções e Procedimentos em C Programação Modular 17 - Funções e Procedimentos em C Programação Modular Unesp Campus de Guaratinguetá Curso de Programação Computadores Prof. Aníbal Tavares Profa. Cassilda Ribeiro Ministrado por: Prof. André Amarante 17

Leia mais

Armazenamento de Dados. Prof. Antonio Almeida de Barros Junior

Armazenamento de Dados. Prof. Antonio Almeida de Barros Junior Armazenamento de Dados Prof. Antonio Almeida de Barros Junior 1 Armazenamento de Dados Todos os dados que utilizamos até o momento, ficavam armazenados apenas na memória. Ao final da execução dos programas,

Leia mais

20 Caracteres - Tipo char

20 Caracteres - Tipo char 0 Caracteres - Tipo char Ronaldo F. Hashimoto e Carlos H. Morimoto Até agora vimos como o computador pode ser utilizado para processar informação que pode ser quantificada de forma numérica. No entanto,

Leia mais

MC102 Algoritmos e programação de computadores Aula 3: Variáveis

MC102 Algoritmos e programação de computadores Aula 3: Variáveis MC102 Algoritmos e programação de computadores Aula 3: Variáveis Variáveis Variáveis são locais onde armazenamos valores na memória. Toda variável é caracterizada por um nome, que a identifica em um programa,

Leia mais

Primeiro Curso de Programação em C 3 a Edição

Primeiro Curso de Programação em C 3 a Edição Edson Luiz França Senne Primeiro Curso de Programação em C 3 a Edição Visual Books Sumário Prefácio da Terceira Edição 9 Prefácio da Primeira Edição 11 Aula 1 13 Regras de sintaxe de uma linguagem de programação...

Leia mais

PROGRAMAÇÃO ESTRUTURADA. CC 2º Período

PROGRAMAÇÃO ESTRUTURADA. CC 2º Período PROGRAMAÇÃO ESTRUTURADA CC 2º Período PROGRAMAÇÃO ESTRUTURADA Aula 07: Funções O comando return Protótipo de funções O tipo void Arquivos-cabeçalho Escopo de variáveis Passagem de parâmetros por valor

Leia mais

Curso de C para Engenharias

Curso de C para Engenharias Aula 4 Cristiano Dalbem Dennis Balreira Gabriel Moreira Miller Biazus Raphael Lupchinski Universidade Federal do Rio Grande do Sul Instituto de Informática Grupo PET Computação Sintaxe Funções Exemplos

Leia mais

Lista de Exercícios da 3ª Unidade. ( Ponteiros, Alocação dinâmica, Arquivos, Estruturas de Dados)

Lista de Exercícios da 3ª Unidade. ( Ponteiros, Alocação dinâmica, Arquivos, Estruturas de Dados) Lista de Exercícios da 3ª Unidade ( Ponteiros, Alocação dinâmica, Arquivos, Estruturas de Dados) 1. (Seg. chamada - 2014.1) Construa um programa em C que realize as seguintes operações: a) Faça uma função

Leia mais

Estruturas II UFOP 1/1

Estruturas II UFOP 1/1 BCC 201 - Introdução à Programação I Estruturas II Guillermo Cámara-Chávez UFOP 1/1 Conceito de struct I Vetores e matrizes Estruturas de dados homegêneas Armazenam vários valores, mas todos de um mesmo

Leia mais

Fundamentos de Arquivos. SCC203 Algoritmos e Estruturas de Dados II

Fundamentos de Arquivos. SCC203 Algoritmos e Estruturas de Dados II Fundamentos de Arquivos SCC203 Algoritmos e Estruturas de Dados II Arquivos Informação mantida em memória secundária HD Disquetes Fitas magnéticas CD DVD 2 Discos X Memória Principal Tempo de acesso HD:

Leia mais

ARRAYS. Um array é um OBJETO que referencia (aponta) mais de um objeto ou armazena mais de um dado primitivo.

ARRAYS. Um array é um OBJETO que referencia (aponta) mais de um objeto ou armazena mais de um dado primitivo. Cursos: Análise, Ciência da Computação e Sistemas de Informação Programação I - Prof. Aníbal Notas de aula 8 ARRAYS Introdução Até agora, utilizamos variáveis individuais. Significa que uma variável objeto

Leia mais

Estrutura de Dados Básica

Estrutura de Dados Básica Estrutura de Dados Básica Professor: Osvaldo Kotaro Takai. Aula 4: Tipos de Dados O objetivo desta aula é apresentar os tipos de dados manipulados pela linguagem C, tais como vetores e matrizes, bem como

Leia mais

Operaçõe õ s c om o Strings Intr oduç ão a o Ponte iros o e Funçõe õ s

Operaçõe õ s c om o Strings Intr oduç ão a o Ponte iros o e Funçõe õ s Universidade de São Paulo São Carlos Instituto de Ciências Matemáticas e de Computação Operações com Strings Introdução a Ponteiros e Funções Profa Rosana Braga 1 Strings Strings são seqüências de caracteres

Leia mais

INF 1007 Programação II

INF 1007 Programação II INF 1007 Programação II Aula 05 Cadeias de Caracteres Edirlei Soares de Lima Caracteres Caracteres são representados através de códigos numéricos. Tabela de códigos: Define correspondência

Leia mais

Edwar Saliba Júnior. Dicas, Comandos e Exemplos Comparativos entre Linguagem Algorítmica e Linguagem C

Edwar Saliba Júnior. Dicas, Comandos e Exemplos Comparativos entre Linguagem Algorítmica e Linguagem C Edwar Saliba Júnior Dicas, Comandos e Exemplos Comparativos entre Linguagem Algorítmica e Linguagem C Belo Horizonte 2010 Sumário 1 Nota:... 2 2 Comandos e Palavras Reservadas:... 3 3 Dicas... 4 3.1 Strings

Leia mais

Manipulação de Arquivos

Manipulação de Arquivos 1 Manipulação de Arquivos Para realizar E/S em arquivo, você precisa incluir o arquivo-cabeçalho fstream.h nos programas. Esse arquivo define muitas classes e valores importantes. Abrindo e fechando um

Leia mais

1 Resumo: Strings e vetores de caracteres. Departamento de Ciência da Computação IME/USP

1 Resumo: Strings e vetores de caracteres. Departamento de Ciência da Computação IME/USP Departamento de Ciência da Computação MAC2166 Introdução a Computação IME/USP Strings e vetores de caracteres 1 Resumo: O uso de strings facilita a manipulação de palavras e textos. Strings são basicamente

Leia mais

Comunicação. O Modelo de Fluxo de Dados (Streams)

Comunicação. O Modelo de Fluxo de Dados (Streams) Comunicação O Modelo de Fluxo de Dados (Streams) Os programas escritos em C utilizam o conceito de fluxo de dados (em, inglês, eles são chamados de streams) para comunicarem-se com dispositivos do computador

Leia mais

Arquivos. Estruturas de Dados II Vanessa Braganholo

Arquivos. Estruturas de Dados II Vanessa Braganholo Arquivos Estruturas de Dados II Vanessa Braganholo Entidades } Aplicações precisam armazenar dados sobre as mais diversas entidades, que podem ser concretas ou abstratas } Funcionário de uma empresa (concreto)

Leia mais

Resumo da Matéria de Linguagem de Programação. Linguagem C

Resumo da Matéria de Linguagem de Programação. Linguagem C Resumo da Matéria de Linguagem de Programação Linguagem C Vitor H. Migoto de Gouvêa 2011 Sumário Como instalar um programa para executar o C...3 Sintaxe inicial da Linguagem de Programação C...4 Variáveis

Leia mais

Linguagens de Programação I

Linguagens de Programação I Linguagens de Programação I Tema # 8 Strings e Estruturas Susana M Iglesias 1 STRINGS - INTRODUÇÃO Strings (cadeia de caracteres): é uma serie de caracteres que podem ser tratados como uma unidade simples,

Leia mais

UFSM Introdução ao Dev-C++ Profa. Patrícia Pitthan. Introdução ao Dev-C++

UFSM Introdução ao Dev-C++ Profa. Patrícia Pitthan. Introdução ao Dev-C++ Introdução ao Dev-C++ O Dev-C++ oferece um ambiente que integra um editor de textos a um compilador para linguagem C. O compilador usado pelo Dev-C++ é o gcc (Gnu C Compiler). 1) Primeiro programa Para

Leia mais

Curso de Programação Computadores

Curso de Programação Computadores 3 O Primeiro Programa em C Unesp Campus de Guaratinguetá Curso de Programação Computadores Prof. Aníbal Tavares Profa. Cassilda Ribeiro 3 O Primeiro Programa em C 3.1 - Introdução Depois dos conceitos

Leia mais

AULA 2: INTRODUÇÃO A LINGUAGEM DE C. Curso: Ciência da Computação Profª.: Luciana Balieiro Cosme

AULA 2: INTRODUÇÃO A LINGUAGEM DE C. Curso: Ciência da Computação Profª.: Luciana Balieiro Cosme AULA 2: INTRODUÇÃO A LINGUAGEM DE C Curso: Ciência da Computação Profª.: Luciana Balieiro Cosme Agenda Introdução a linguagem C Compiladores Variáveis IDEs Exemplos Exercícios Introdução A Linguagem C

Leia mais

MC-102 Aula 17 Strings e Matrizes

MC-102 Aula 17 Strings e Matrizes MC-102 Aula 17 Strings e Matrizes Instituto de Computação Unicamp 5 de Maio de 2015 Roteiro 1 Strings Strings: Exemplos 2 Matrizes Exemplos com Matrizes 3 Exercícios (Instituto de Computação Unicamp) MC-102

Leia mais

Estruturas de Dados. Profa. Juliana Pinheiro Campos

Estruturas de Dados. Profa. Juliana Pinheiro Campos Estruturas de Dados Profa. Juliana Pinheiro Campos Arquivos ESTRUTURAS DE DADOS Técnicas para que possamos salvar e recuperar informações em arquivos de maneira estruturada. Assim será possível implementar

Leia mais

Curso de Linguagem C

Curso de Linguagem C Curso de Linguagem C 1 Aula 1 - INTRODUÇÃO...4 AULA 2 - Primeiros Passos...5 O C é "Case Sensitive"...5 Dois Primeiros Programas...6 Introdução às Funções...7 Introdução Básica às Entradas e Saídas...

Leia mais

JSP - ORIENTADO A OBJETOS

JSP - ORIENTADO A OBJETOS JSP Orientação a Objetos... 2 CLASSE:... 2 MÉTODOS:... 2 Método de Retorno... 2 Método de Execução... 2 Tipos de Dados... 3 Boolean... 3 Float... 3 Integer... 4 String... 4 Array... 4 Primeira:... 4 Segunda:...

Leia mais

1) Ao ser executado o código abaixo, em PHP, qual será o resultado impresso em tela?

1) Ao ser executado o código abaixo, em PHP, qual será o resultado impresso em tela? Exercícios sobre Linguagem PHP: 1) Ao ser executado o código abaixo, em PHP, qual será o resultado impresso em tela? 2) Considere a linguagem de programação PHP e seus operadores. A execução da sentença:

Leia mais

Algoritmos e Programação

Algoritmos e Programação Universidade Federal do Vale do São Francisco Curso de Engenharia da Produção / Elétrica Algoritmos e Programação Parte 05 Prof. Jorge Cavalcanti [email protected] www.univasf.edu.br/~jorge.cavalcanti

Leia mais

MC-102 Aula 19 Registros

MC-102 Aula 19 Registros MC-102 Aula 19 Registros Instituto de Computação Unicamp 4 de Maio de 2015 Roteiro 1 Registros 2 Redefinição de tipos (Instituto de Computação Unicamp) MC-102 Aula 19 4 de Maio de 2015 2 / 17 Registros

Leia mais

Unidade IV: Ponteiros, Referências e Arrays

Unidade IV: Ponteiros, Referências e Arrays Programação com OO Acesso em Java a BD Curso: Técnico em Informática Campus: Ipanguaçu José Maria Monteiro Pontifícia Universidade Católica do Rio de Janeiro PUC-Rio Departamento Clayton Maciel de Informática

Leia mais

UNIVERSIDADE FEDERAL DO RIO GRANDE DO SUL INSTITUTO DE INFORMÁTICA INFORMÁTICA APLICADA

UNIVERSIDADE FEDERAL DO RIO GRANDE DO SUL INSTITUTO DE INFORMÁTICA INFORMÁTICA APLICADA Responda 1) Quem desenvolveu a linguagem C? Quando? 2) Existe alguma norma sobre a sintaxe da linguagem C? 3) Quais são os tipos básicos de dados disponíveis na linguagem C? 4) Quais são as principais

Leia mais

Introdução a Programação. Ponteiros e Strings, Alocação Dinâmica

Introdução a Programação. Ponteiros e Strings, Alocação Dinâmica Introdução a Programação Ponteiros e Strings, Alocação Dinâmica Tópicos da Aula Hoje aprenderemos a relação entre ponteiros e strings Ponteiros para strings X Vetores de Caracteres Vetores de ponteiros

Leia mais

PIP/CA - Programa Interdisciplinar de Pós-Graduação em Computação Aplicada da UNISINOS ALGORITMOS & ESTRUTURAS DE DADOS

PIP/CA - Programa Interdisciplinar de Pós-Graduação em Computação Aplicada da UNISINOS ALGORITMOS & ESTRUTURAS DE DADOS PIP/CA - Programa Interdisciplinar de Pós-Graduação em Computação Aplicada da UNISINOS Disciplina de Nivelamento - 2000/1: ALGORITMOS & ESTRUTURAS DE DADOS Professor Responsável: Prof. Fernando Santos

Leia mais

SIMULADO Windows 7 Parte V

SIMULADO Windows 7 Parte V SIMULADO Windows 7 Parte V 1. O espaço reservado para a Lixeira do Windows pode ser aumentado ou diminuído clicando: a) Duplamente no ícone lixeira e selecionando Editar propriedades b) Duplamente no ícone

Leia mais

5 - Vetores e Matrizes Linguagem C CAPÍTULO 5 VETORES E MATRIZES

5 - Vetores e Matrizes Linguagem C CAPÍTULO 5 VETORES E MATRIZES CAPÍTULO 5 5 VETORES E MATRIZES 5.1 Vetores Um vetor armazena uma determinada quantidade de dados de mesmo tipo. Vamos supor o problema de encontrar a média de idade de 4 pessoas. O programa poderia ser:

Leia mais

Trabalho 3: Agenda de Tarefas

Trabalho 3: Agenda de Tarefas INF 1620 Estruturas de Dados Semestre 08.2 Trabalho 3: Agenda de Tarefas O objetivo deste trabalho é a implementação de um conjunto de funções para a manipulação de uma agenda de tarefas diárias, de forma

Leia mais

INFORMÁTICA APLICADA AULA 02 LINGUAGEM DE PROGRAMAÇÃO C++

INFORMÁTICA APLICADA AULA 02 LINGUAGEM DE PROGRAMAÇÃO C++ UNIVERSIDADE FEDERAL RURAL DO SEMI-ÁRIDO CURSO: Bacharelado em Ciências e Tecnologia INFORMÁTICA APLICADA AULA 02 LINGUAGEM DE PROGRAMAÇÃO C++ Profª ª Danielle Casillo COMPILADORES Toda linguagem de programação

Leia mais

Prof. Yandre Maldonado - 1 PONTEIROS. Prof. Yandre Maldonado e Gomes da Costa

Prof. Yandre Maldonado - 1 PONTEIROS. Prof. Yandre Maldonado e Gomes da Costa Prof. Yandre Maldonado - 1 PONTEIROS Prof. Yandre Maldonado e Gomes da Costa PONTEIROS Prof. Yandre Maldonado - 2 Ponteiro é uma variável que possui o endereço de outra variável; É um poderoso recurso

Leia mais

Linguagem C. Programação Estruturada. Fundamentos da Linguagem. Prof. Luis Nícolas de Amorim Trigo [email protected].

Linguagem C. Programação Estruturada. Fundamentos da Linguagem. Prof. Luis Nícolas de Amorim Trigo nicolas.trigo@ifsertao-pe.edu. Programação Estruturada Linguagem C Fundamentos da Linguagem Prof. Luis Nícolas de Amorim Trigo [email protected] Sumário Estrutura Básica Bibliotecas Básicas Tipos de Dados Básicos Variáveis/Declaração

Leia mais

UNIVERSIDADE FEDERAL DO AMAPÁ NÚCLEO DE TECNOLOGIA DA INFORMAÇÃO. Manual de Avaliação de Desempenho Cadastro

UNIVERSIDADE FEDERAL DO AMAPÁ NÚCLEO DE TECNOLOGIA DA INFORMAÇÃO. Manual de Avaliação de Desempenho Cadastro UNIVERSIDADE FEDERAL DO AMAPÁ NÚCLEO DE TECNOLOGIA DA INFORMAÇÃO Manual de Avaliação de Desempenho Cadastro UNIFAP MACAPÁ-AP 2013 S U M Á R I O 1 Tela de Login...2 2 Acessando ao submenu cadastro de avaliação

Leia mais

Iniciação à Informática

Iniciação à Informática Meu computador e Windows Explorer Justificativa Toda informação ou dado trabalhado no computador, quando armazenado em uma unidade de disco, transforma-se em um arquivo. Saber manipular os arquivos através

Leia mais

Alocação dinâmica de memória

Alocação dinâmica de memória Alocação dinâmica de memória Jander Moreira 1 Primeiras palavras Na solução de problemas por meio algoritmos ou programas, é comum surgir a necessidade de manter todo o conjunto de dados a ser processado

Leia mais

CAPÍTULO 3 - TIPOS DE DADOS E IDENTIFICADORES

CAPÍTULO 3 - TIPOS DE DADOS E IDENTIFICADORES CAPÍTULO 3 - TIPOS DE DADOS E IDENTIFICADORES 3.1 - IDENTIFICADORES Os objetos que usamos no nosso algoritmo são uma representação simbólica de um valor de dado. Assim, quando executamos a seguinte instrução:

Leia mais

Prof. Esp. Adriano Carvalho

Prof. Esp. Adriano Carvalho Prof. Esp. Adriano Carvalho O que é um Programa? Um arquivo contendo uma sequência de comandos em uma linguagem de programação especifica Esses comandosrespeitam regras de como serem escritos e quais

Leia mais

CAP. IX - MANIPULAÇÃO DE ARQUIVOS Generalidades sobre Arquivos. 9.2 Abertura e Fechamento de Arquivos. Operações com arquivos:

CAP. IX - MANIPULAÇÃO DE ARQUIVOS Generalidades sobre Arquivos. 9.2 Abertura e Fechamento de Arquivos. Operações com arquivos: CAP. IX - MANIPULAÇÃO DE ARQUIVOS 9.1 Generalidades sobre arquivos 9.2 Abertura e fechamento de arquivos 9.3 Arquivos textos e arquivos binários 9.4 Leitura e escrita em arquivos binários 9.5 Procura direta

Leia mais

Linguagem e Técnicas de Programação I Operadores, expressões e funções. Prof. MSc. Hugo Souza Material desenvolvido por: Profa.

Linguagem e Técnicas de Programação I Operadores, expressões e funções. Prof. MSc. Hugo Souza Material desenvolvido por: Profa. Linguagem e Técnicas de Programação I Operadores, expressões e funções Prof. MSc. Hugo Souza Material desenvolvido por: Profa. Ameliara Freire Operadores básicos Toda linguagem de programação, existem

Leia mais

OPERADORES E ESTRUTURAS DE CONTROLE

OPERADORES E ESTRUTURAS DE CONTROLE OPERADORES E ESTRUTURAS DE CONTROLE 3.1 Operadores Os operadores indicam o tipo de operação matemática que será executada gerando novos valores a partir de um ou mais operadores. São muito utilizados em

Leia mais

Edwar Saliba Júnior. Dicas, Comandos e Exemplos Comparativos entre Linguagem Algorítmica e Linguagem C / C++

Edwar Saliba Júnior. Dicas, Comandos e Exemplos Comparativos entre Linguagem Algorítmica e Linguagem C / C++ Edwar Saliba Júnior Dicas, Comandos e Exemplos Comparativos entre Linguagem Algorítmica e Linguagem C / C++ Belo Horizonte 2009 Sumário 1 Nota:... 2 2 Comandos e Palavras Reservadas:... 3 3 Dicas... 4

Leia mais

Aluísio Eustáquio da Silva

Aluísio Eustáquio da Silva 1 Aluísio Eustáquio da Silva SciLab Programável Material didático usado em aulas de Programação de Computadores, Algoritmos e Lógica de Programação Betim Maio de 2012 2 PROGRAMAÇÃO O SciLab permite que

Leia mais

Status. Barra de Título. Barra de Menu. Barra de. Ferramentas Padrão. Caixa de nomes. Barra de. Ferramentas de Formatação. Indicadores de Coluna

Status. Barra de Título. Barra de Menu. Barra de. Ferramentas Padrão. Caixa de nomes. Barra de. Ferramentas de Formatação. Indicadores de Coluna O que é uma planilha eletrônica? É um aplicativo que oferece recursos para manipular dados organizados em tabelas. A partir deles pode-se gerar gráficos facilitando a análise e interpretação dos dados

Leia mais

Introdução a Java. Hélder Nunes

Introdução a Java. Hélder Nunes Introdução a Java Hélder Nunes 2 Exercício de Fixação Os 4 elementos básicos da OO são os objetos, as classes, os atributos e os métodos. A orientação a objetos consiste em considerar os sistemas computacionais

Leia mais

5 Apresentando a linguagem C

5 Apresentando a linguagem C 5 Apresentando a linguagem C O criador da linguagem de programação C foi Dennis Ritchie que, na década de 70, programou-a por meio de um computador DEC PDP-11 rodando sistema operacional Unix. Entretanto,

Leia mais

SISTEMAS OPERACIONAIS ABERTOS Prof. Ricardo Rodrigues Barcelar http://www.ricardobarcelar.com

SISTEMAS OPERACIONAIS ABERTOS Prof. Ricardo Rodrigues Barcelar http://www.ricardobarcelar.com - Aula 2-1. PRINCÍPIOS DE SOFTWARE DE ENTRADA E SAÍDA (E/S) As metas gerais do software de entrada e saída é organizar o software como uma série de camadas, com as mais baixas preocupadas em esconder as

Leia mais

Sistema de Arquivos. Ambientes Operacionais. Prof. Simão Sirineo Toscani [email protected] www.inf.pucrs.br/~stoscani

Sistema de Arquivos. Ambientes Operacionais. Prof. Simão Sirineo Toscani stoscani@inf.pucrs.br www.inf.pucrs.br/~stoscani Sistema de Arquivos Ambientes Operacionais Prof. Simão Sirineo Toscani [email protected] www.inf.pucrs.br/~stoscani Gerência de Arquivos É um dos serviços mais visíveis do SO. Arquivos são normalmente

Leia mais

Registros. Técnicas de Programação. Rafael Silva Guimarães :p://:p.ci.ifes.edu.br/informa@ca/rafael_guimaraes

Registros. Técnicas de Programação. Rafael Silva Guimarães :p://:p.ci.ifes.edu.br/informa@ca/rafael_guimaraes Rafael Silva Guimarães :p://:p.ci.ifes.edu.br/informa@ca/rafael_guimaraes Registros Técnicas de Programação Baseado no material do Prof. Rafael Vargas Mesquita Conceito de Registro (Struct) Vetores e Matrizes

Leia mais

DEFINIÇÃO DE MÉTODOS

DEFINIÇÃO DE MÉTODOS Cursos: Análise, Ciência da Computação e Sistemas de Informação Programação I - Prof. Aníbal Notas de aula 2 DEFINIÇÃO DE MÉTODOS Todo o processamento que um programa Java faz está definido dentro dos

Leia mais

Programação de Computadores I. Ponteiros

Programação de Computadores I. Ponteiros Ponteiros Prof. Edwar Saliba Júnior Outubro de 2012 Unidade 13 Ponteiros 1 Identificadores e Endereços Na linguagem C, uma declaração de variável faz associação entre um identificador e endereços de memória;

Leia mais

MC-102 Algoritmos e Programação de Computadores

MC-102 Algoritmos e Programação de Computadores MC-102 Algoritmos e Programação de Computadores Prof. Ariel Vargas Unicamp Arquivos Binários Arquivos Arquivos Texto Podem ser manipulados por um editor de texto comum Os dados são gravados como caracteres

Leia mais

3. No painel da direita, dê um clique com o botão direito do mouse em qualquer espaço livre (área em branco).

3. No painel da direita, dê um clique com o botão direito do mouse em qualquer espaço livre (área em branco). Permissões de compartilhamento e NTFS - Parte 2 Criando e compartilhando uma pasta - Prática Autor: Júlio Battisti - Site: www.juliobattisti.com.br Neste tópico vamos criar e compartilhar uma pasta chamada

Leia mais

Criando um script simples

Criando um script simples Criando um script simples As ferramentas de script Diferente de muitas linguagens de programação, você não precisará de quaisquer softwares especiais para criar scripts de JavaScript. A primeira coisa

Leia mais

Aula 4 Pseudocódigo Tipos de Dados, Expressões e Variáveis

Aula 4 Pseudocódigo Tipos de Dados, Expressões e Variáveis 1. TIPOS DE DADOS Todo o trabalho realizado por um computador é baseado na manipulação das informações contidas em sua memória. Estas informações podem ser classificadas em dois tipos: As instruções, que

Leia mais

Introdução a Computação

Introdução a Computação Introdução a Computação Aula 02 Introdução a Linguagem C Edirlei Soares de Lima Lógica de Programação Lógica de Programação é a técnica de criar sequências lógicas de ações para

Leia mais

Menu Utilitários. Atualização do Banco de Dados Atualização e organização dos arquivos existentes

Menu Utilitários. Atualização do Banco de Dados Atualização e organização dos arquivos existentes Atualização do Banco de Dados Atualização e organização dos arquivos existentes Rotina responsável pelo rastreamento de possíveis arquivos não indexados, danificados ou inexistentes. Este processo poderá

Leia mais

P r o g r a m a ç ã o d e C o m p u t a d o r e s 1 o S e m - 2 0 1 3 P r o f. A n d r é A m a r a n t e L u i z L A B 5 tag %2d while printf PE1:

P r o g r a m a ç ã o d e C o m p u t a d o r e s 1 o S e m - 2 0 1 3 P r o f. A n d r é A m a r a n t e L u i z L A B 5 tag %2d while printf PE1: Inteligência É a faculdade de criar objetos artificiais, especialmente ferramentas para fazer ferramentas. Henri Bergson. WHILE Além dos comandos if-else e switch, o controle de fluxo de um programa pode

Leia mais

Capacidade = 512 x 300 x 20000 x 2 x 5 = 30.720.000.000 30,72 GB

Capacidade = 512 x 300 x 20000 x 2 x 5 = 30.720.000.000 30,72 GB Calculando a capacidade de disco: Capacidade = (# bytes/setor) x (méd. # setores/trilha) x (# trilhas/superfície) x (# superfícies/prato) x (# pratos/disco) Exemplo 01: 512 bytes/setor 300 setores/trilha

Leia mais