Marco Antonio Montebello Júnior

Slides:



Advertisements
Apresentações semelhantes
Laboratório de programação III Linguagem C
Advertisements

Marco Antonio Montebello Júnior
TECNOLOGIA EM REDES DE COMPUTADORES Algoritmos e programação de computadores Aula /08/2011 Professor Leomir J. Borba-
Nivelamento de C: Ponteiros e Alocação Dinâmica
Programação II Estruturas de Dados
Programação II Estruturas de Dados
Alocação Dinâmida de Memória
Algoritmos e Estrutura de Dados I
1 Tipos definidos O programador pode definir seus próprios tipos de dados tipos complexos usados da mesma forma que os simples declaram-se variáveis utilizando-se.
Alocação Dinâmica de Memória
Linguagem C LPG-I – Variáveis Estruturadas – Vetores
LPG - I: Alocação Dinâmica de Memória - Ponteiros
Ponteiros em C.
LPG - I: Ponteiros e Vetores/Matrizes UDESC - SBS
Universidade de Brasília
Curso de C/C++ Avançado
Linguagem C Strings.
Ponteiros em Linguagem C
Slides Prof. Jean SIMÃO Revisão: Prof. João FABRO
Fundamentos de Programação 1
Ponteiros.
Escola Secundária c/ 3º CEB da Batalha
Listas Encadeadas.
Revisão da Linguagem C.
APRESENTAÇÃO: GIANCARLO DE GUSMÃO GONÇALVES CURSO DE C AULA 08: Tipos Estruturados.
Prof.° Jean Daniel Henri Merlin Andreazza Estrutura de Dados
Professor Reverton de Paula Faculdade Anhanguera de Indaiatuba
Alocação Dinâmica de Memória Professor Mário Dantas
Aula prática 9 Alocação Dinâmica Monitoria de Introdução à Programação
Aula prática 8 Ponteiros Monitoria de Introdução à Programação
Aula prática 8 Ponteiros Monitoria de Introdução à Programação.
Aula prática 6 Vetores e Matrizes
Aula prática 9 Alocação Dinâmica Monitoria de Introdução à Programação
Linguagem de Programação II Parte IX
Definição de Tipos Estruturas e Ponteiros
Ordenação e Pesquisa de Dados Marco Antonio Montebello Júnior
Estrutura de dados II Carlos Oberdan Rolim Ciência da Computação Sistemas de Informação.
Linguagem de programação I A Carlos Oberdan Rolim Ciência da Computação Sistemas de Informação.
PROGRAMAÇÃO I PONTEIROS.
Alocação Dinâmica de Memória
UNIDADE 5 ESTRUTURAS DE DADOS HOMOGÊNEAS
Professor Mário Dantas
Prof. Ricardo Santos PONTEIROS
Linguagem C : Ponteiros
Estruturas de Dados Aula 5: Matrizes
Educação Profissional Técnica de Nível Médio Curso Técnico de Informática
Aula P.02 – BCC202 Revisão sobre Ponteiros Túlio Toffolo
1 Alocação Dinâmica Quando se declara arrays o tamanho deve ser fixo e definido primeiramente –Alocação estática Pode-se alocar dinamicamente o espaço.
Algoritmos e Estruturas de Dados
Joaquim José Hangalo  Podemos entender a memória do computador como um conjunto de células que armazenam informações.  Cada célula.
Estruturas de Dados Aulas 3 e 4: Uso da memória e Vetores
Linguagem de programação I A Carlos Oberdan Rolim Ciência da Computação Sistemas de Informação Versão: _01.
Linguagem C.
CES-10 INTRODUÇÃO À COMPUTAÇÃO
Algoritmos e Programação MC102 Prof. Paulo Miranda IC-UNICAMP Aula 15 Ponteiros.
Programação de Computadores I – Ponteiros Profa. Mercedes Gonzales Márquez.
Leandro Almeida  As declarações abaixo alocam memória para diversas variáveis.  A alocação é estática, pois acontece antes que o programa.
Ponteiros em C Prof. Kariston Pereira
Linguaguem de Programação II
Estrutura de Dados Revisão Professor Luiz José Hoffmann Filho
Ponteiros. Programação II Professora: Mai-Ly vanessa horário: ter 9h-11h; sex 11h-13h Aula 1.
Algoritmo e Estrutura de Dados I Aulas 15 – Linguagem C Alocação Dinâmica de Memória Márcia Marra
Linguagem de Programação
COMPILADORES 07 Prof. Marcos.
Programação em C Aula 9.
ponteiros Estrutura de Dados Prof. André Cypriano M. Costa
Aula Prática 6 Ponteiros Monitoria  Quando declaramos uma matriz:  tipo meuArray[tam];  O compilador aloca a matriz em uma região de memória.
Alocação Dinâmica Dilvan Moreira. Objetivos  Entender o que são e como usar:  Gerenciamento de Memória  Alocação Dinâmica em C.
Jean Carlo Mendes
FUNÇÕES Dilvan Moreira (baseado em material de Z. Liang)
Transcrição da apresentação:

Marco Antonio Montebello Júnior marco.antonio@aes.edu.br Ponteiros Lab. de Programação de Computadores Marco Antonio Montebello Júnior marco.antonio@aes.edu.br

Definição Proporciona um modo de acesso a variáveis sem referenciá-las diretamente, utilizando para isto o endereço da variável. A declaração “*” indica que uma variável é um ponteiro Ps.: O uso descuidado de ponteiros pode levar a sérios bugs e a dores de cabeça terríveis :-).

Ponteiros Constantes Não podem ser alterados e permanecem imutáveis durante a execução do programa. Ex: int iNotas[10]; Para acessa a 1ª. posição do vetor pode-se usar: iNotas ou &iNotas[0] 2ª. Posição: &iNotas[1] E assim sucessivamente...

Criando um Ponteiro Criar uma variável para armazenar o endereço da variável iVar1, a qual iremos chamar de ipVar1 Nesse momento a variável ipVar1 não foi inicializada, apenas foi reservado um espaço para ela.

Criando um Ponteiro Devemos armazenar o endereço de iVar1 na variável ipVar1. Nesse momento podemos dizer que ipVar1 aponta para iVar1 ou é um ponteiro para iVar1 Ps.: Ponteiro é uma variável que contém o endereço de outra variável.

Declaração de Ponteiro <tipo> * <pnome_variavel>; <tipo> Tipo da variável para a qual o ponteiro estará apontando (int, float, char, ...) * Operador de indireção e indica que a variavel é um ponteiro para o <tipo> declarado <nome_variavel> Nome da variável, seguindo as regras de criação de nomes anteriores

Declaração de Ponteiro <tipo> * <pnome_variavel>; Antes do nome da variável deve existir o *. É declarado junto com as outras variáveis Exemplos int *ipPonteiro; float *fpPonteiro; char *cpPonteiro;

Inicializando um Ponteiro int iNum, *ipNum; int iVet[10], &ipVet; int iMat[5][7], &ipMat; //Atribuindo os endereços ipNum =&iNum; ipVet = iVet; //ipVetor = iVetor[0]; ipMat = iMat; //ipMat = iMat[0];

Ponteiros e Strings Declarando uma mensagem como um ponteiro constante char cMsg [10] = “Saudacoes”; Declarando uma mensagem como ponteiro variável char *cpMsg = “Saudacoes”;

Matriz de Ponteiros Matriz constante char cLista[5][10] = {"Katarina", "Diogo", "Gustavo", "Francisco", "Airton"}; Matriz variável char *cpLista[5] = {"Katarina", " Gustavo",

Matriz de Ponteiros (1)

Matriz de Ponteiros (2)

Dicas sobre Ponteiro Acessar o endereço da variável ponteiro fpPonteiro printf(“Endereço %f.”, fpPonteiro); Acessar o conteúdo da variável ponteiro *fpPonteiro printf(“Conteúdo: %f.”, *fpPonteiro);

Dicas sobre Ponteiro Acessar o próximo endereço de um ponteiro fpVet++; fpVet = fpVet + n;//n=num de bytes a percorrer fpVet += n; Acessar o endereço anterior de um ponteiro fpVet--; fpVet = fpVet - n;//n=num de bytes a percorrer fpVet -= n;

Dicas sobre Ponteiro Operações equivalentes fVet[2] == *(fpVet + 2)

Alocação Dinâmica Aloca espaço na memória durante a execução do programa (em tempo de execução) Existem funções para alocar, desalocar, realocar e limpar a memória que foi alocada Usuar a biblioteca stdlib.h #include <stdlib.h>

Função: Sizeof Indica o tamanho em bytes de uma variável. sizeof(<tipo>); Tipo: char, int, float, ... printf(“Tam. int: %i.”, sizeof(int)); //4 bytes printf(“Tam. float: %i.”, sizeof(float)); //4 bytes printf(“Tam. double: %i.”, sizeof(double));//8 bytes printf(“Tam. char: %i.”, sizeof(char)); //1 byte

Heap Área de Alocação Dinâmica Consiste de toda a memória disponível que não foi usada para outro propósito. “É o resto da memória” É possível alocar ou liberar dinamicamente a memória do heap através da funções: malloc() calloc() realloc() free()

Função: Malloc Aloca a quantidade de bytes desejada pelo usuário. malloc(<tamanho>); int *ipNum1, *ipNum2; ipNum1 = (int *) malloc(4); //Aloca 4 bytes //5 variáveis inteiras = 5 * 4 = 20 bytes ipNum2 = malloc(5 * sizeof(int));

Função: Malloc A expressão (int *) é utilizado pois a função malloc(), retorna um ponteiro para o tipo void, portanto esse ponteiro deve ser moldado para o tipo de dado apropriado. É um operador unário chamado de operador molde ou cast.

Função: Calloc Aloca memória para um grupo de objetos calloc(<tamanho>, <tam_obj); int *ipNum1, *ipNum2; ipNum1 = (int *) calloc(2, 4); //Aloca 8 bytes //5 variáveis inteiras = 5 * 4 = 20 bytes ipNum2 = (int *) calloc(5, sizeof(int));

Função: Realloc Altera o tamanho de um bloco de memória que foi alocado através do malloc() ou do calloc() realloc(<*ptr>, <tamanho>); int *ipNum1, *ipNum2; ipNum1 = (int *) calloc(2, 4); //Aloca 8 bytes //5 variáveis inteiras = 5 * 4 = 20 bytes ipNum2 = (int *) calloc(5, sizeof(int)); ipNum2 = (int *) realloc(ipNum2, sizeof(int) * 10);

Função: Free Limpa um espaço de memória que foi alocado free(<*ptr>) int *ipNum1, *ipNum2; ipNum1 = (int *) calloc(2, 4); //Aloca 8 bytes //5 variáveis inteiras = 5 * 4 = 20 bytes ipNum2 = (int *) calloc(5, sizeof(int)); //Liberando a memória alocada para ipNum1 e ipNum2 free(ipNum1); free(ipNum2);

Exercício Alocar espaço para um vetor inteiro com 10 posições. Receber do usuário, os valores do vetor. Mostrar o endereço e o respectivo valor de cada elemento da matriz. Em seguida, alterar esses valores, somando 10 a cada elemento. Mostrar novamente o endereço (que deve ser o mesmo) com o novo valor. Utilizar alocação dinâmica e ponteiros, não declarar vetor.

Exercício Aloque espaço para uma seqüência de 5 números reais. Receba do usuário os valores e imprima-os em ordem inversa. Utilizar alocação dinâmica e ponteiros, não declarar vetor. Altere o exercício anterior de maneira que o usuário indique a quantidade de elementos que ele deseja alocar.