Notas de Aulas (parte 2)
|
|
|
- Lúcia Botelho Teves
- 10 Há anos
- Visualizações:
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, ®.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, ®.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 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
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
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
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
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 [email protected] Resumo da aula Considerações Gerais Introdução a Linguagem C Variáveis e C Tipos de
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,
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
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
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
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.
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:
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...
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
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.
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.
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,
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
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
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
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 [email protected] Breve Histórico A linguagem de programação C foi criada na década de 70, por Dennis Ritchie, que a implementou,
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
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
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
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 **
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
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
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
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
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,
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,
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,
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...
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
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
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
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
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:
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
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
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
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
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
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
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
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
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)
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
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,
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
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
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
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
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
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...
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:...
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:
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
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
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
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
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
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
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
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:
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
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
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
Linguagem C. Programação Estruturada. Fundamentos da Linguagem. Prof. Luis Nícolas de Amorim Trigo [email protected].
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
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
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
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
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:
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
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
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
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
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
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
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
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
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,
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
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 [email protected] www.inf.pucrs.br/~stoscani Gerência de Arquivos É um dos serviços mais visíveis do SO. Arquivos são normalmente
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
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
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;
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
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
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
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
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
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á
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
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
