Modulo 12: alocação dinâmica de memória
|
|
|
- Júlia Galvão Fialho
- 8 Há anos
- Visualizações:
Transcrição
1 PROGRAMAÇÃO DE COMPUTADORES V - TCC Modulo 12: alocação dinâmica de memória Aura - Erick [email protected], [email protected]
2 Roteiro porque e como utilizar a alocação dinâmica funções: malloc ( ), calloc ( ), realloc ( ) e free ( ). Trabalho 8 2
3 A alocação é estática As declarações abaixo alocam espaço de memória 3 variáveis. A alocação é estática (nada a ver com a palavrachave static), ou seja, acontece antes que o programa comece a ser executado: char c; int i; int v[10];
4 funções malloc e free de stdlib. Às vezes, a quantidade de memória a alocar só se torna conhecida durante a execução do programa. Para lidar com essa situação é preciso recorrer à alocação dinâmica de memória. A alocação dinâmica é gerenciada pelas funções malloc e free, que estão na biblioteca stdlib. Para usar esta biblioteca, você deve incluir a correspondente interface no seu programa por meio de #include <stdlib.h>
5 Alocação dinâmica é o processo que obter memória em tempo de execução (quando o programa está sendo usado). Ela é utilizada quando não se sabe ao certo quanto de memória será necessário para o armazenamento das informações, podendo ser determinadas em tempo de execução conforme a necessidade do programa. Dessa forma evita-se o desperdício de memória.
6 No C padrão existem 4 funções para alocações dinâmica pertencentes a biblioteca stdlib.h. São elas : malloc ( ), calloc ( ), realloc ( ) e free ( ). Sendo mais utilizadas são malloc ( ) e free ( ). As funções malloc() e calloc() são responsáveis por alocar memória, a realloc() por realocar a memória e por último a free() fica responsável por liberar a memória alocada.
7 A alocação dinâmica é muito utilizada em casos que usam muito volume de dados. A sintaxe da função malloc() é : void * malloc ( size_t size ) esta função recebe como parâmetro size que é o número de bytes de memória que se deseja alocar. O tipo size_t é definido em stdlib.h como sendo um inteiro sem sinal. Esta função retorna um ponteiro do tipo void podendo assim ser atribuído a qualquer tipo de ponteiro.
8 Como se faz? Suponha que seja necessário no meio do código alocar uma memória com 1500 bytes, para isto seria necessário apenas digitar as seguintes linhas de código: cha * str ; str = malloc ( 1500 ) ; ( o nome é uma abreviatura de memory allocation )
9 A função malloc aloca um bloco de bytes consecutivos na memória do computador e devolve o endereço desse bloco. O número de bytes é especificado no argumento que voce vai passar para a função. O endereço devolvido por malloc é do tipo genérico: void *. O programador, você, armazena esse endereço num ponteiro de tipo apropriado, para seu programa e caso!
10 Alocação dinâmica é muito utilizada em casos que não se sabe antes o volume de dados.
11 Quando não se sabe antes a quantidade de elementos a serem utilizados deve-se utilizar a alocação dinâmica. O exemplo anterior é muito simples, mas mostra em que situação se deve utilizar alocação dinâmica. Vemos que não se sabe a quantidade de valores que vai ser inserido no vetor, por esse motivo declaramos um vetor de 99 posições. Mas e se a pessoa, por exemplo, deseja colocar apenas 3 elementos no vetor. Como o vetor foi declarado com o tamanho igual a 99, o que acontece é o desperdício de memória. Mas, e caso passe de 100 haverá um estouro. Portanto a melhor solução é utilizar alocação dinâmica.
12 O mesmo exemplo mostrado anteriormente com o uso de alocação dinâmica (usando a função malloc() ) :
13 Heap é a região de memória livre do seu computador. Agora o usuário pode digitar o tamanho do vetor que quiser que não haverá desperdício de memória e o vetor a ser alocado será do tamanho digitado pelo usuário. A função malloc() utilizada no programa, devolve um ponteiro do tipo void, desta forma pode-se ser atribuído a qualquer tipo de ponteiro (no exemplo é atribuído a um ponteiro do tipo inteiro). A memória alocada pela função malloc(), como também por outras funções com o mesmo fim que vamos ver no decorrer desta aula, deve ser obtida do heap.
14 Há espaço? É necessário verificar se a memória livre ( heap ) é suficiente para o armazenamento e isto pode ser feito como mostrado na segunda seta no exemplo anterior : Caso a função malloc() devolver o valor nulo significa que não há memória suficiente e nesse caso o programa apresenta na tela a mensagem : Memória insuficiente e imediatamente termina o programa através da função exit().
15 Perigo!!! As variáveis alocadas estaticamente dentro de uma função desaparecem quando a execução da função termina. Já as variáveis alocadas dinamicamente continuam a existir mesmo depois que a execução da função termina. Se for necessário liberar a memória ocupada por essas variáveis, é preciso recorrer à função free.
16 free ( ) ; A função free ( ) usada neste exemplo, na terceira seta, e que você deve usar com as demais funções de alocação dinâmica serve para liberar a memória alocada. E sua sintaxe é a seguinte: void free ( void *p ) ; O p é um ponteiro que aponta para a memória alocada anteriormente, no programa anterior, o ponteiro vet.
17 dangling pointers?? A função free libera a porção de memória alocada. A instrução free (ptr) avisa ao sistema que o bloco de bytes apontado por ptr está livre. A próxima chamada de alocação poderá tomar posse desses bytes. A função free não deve ser aplicada a uma parte de um bloco de bytes alocado: aplique free apenas ao bloco todo.
18 Convém não deixar ponteiros soltos (= dangling pointers) no seu programa, pois isso pode ser explorado por hackers para atacar o seu computador. Portanto, depois de cada free (ptr), atribua NULL a ptr: free (ptr); ptr = NULL;
19 OBS. Cada invocação de malloc aloca um bloco de bytes consecutivos maior que o solicitado: os bytes adicionais são usados para guardar informações administrativas sobre o bloco de bytes (essas informações permitem que o bloco seja corretamente desalocado, mais tarde, pela free. O número de bytes adicionais pode ser grande, e maior que o número de bytes solicitado no argumento de malloc. Não é ineficiente, portanto, alocar pequenos blocos de bytes; é preferível alocar um grande bloco por vez.
20 outras funções padrões de alocação dinâmica: calloc ( ) Esta função também tem como objetivo alocar memória e possui a seguinte sintaxe: void *calloc ( unsigned int num, unsigned int size); num representa a quantidade de memória a ser alocada e size é o seu tamanho. Esta função inicia o espaço alocado com 0. Podemos usar, no exemplo anterior, calloc ( ) só alterando na segunda seta:
21 O mesmo exemplo: A função sizeof( ) retorna o tamanho em bytes do tipo de dado, que no nosso exemplo é inteiro, int, isto é importante para que o programa seja portável.
22 realloc ( ) Esta função é responsável por realocar a memória cuja a sintaxe é: void * realloc ( void * p, size_t size ) Desta forma pode-se alterar o tamanho da memória anteriormente alocado por *p para o tamanho especificado por um novo valor (size).
23 exemplo de realloc ( )
24 Obs. Neste último programa usamos a função strcpy() que copia a string entre aspas para a string destino, que no nosso caso é uma variável com o nome de string. Para utilizar esta função foi necessário inserir no cabeçalho #include <string.h>. Nos exemplos mostrados system( Pause ) tem o mesmo papel que o getch() e serve para que o programa dê uma pausa. Para se utilizar o system( Pause ) é necessário inserir no cabeçalho #include<stdlib.h>.
25 Referencias
26 8º Trabalho - Entrega: 11 / 03 /2016 Escreva duas novas versões do 7º Trabalho onde seja usada : malloc ( ) e free ( ), calloc ( ) e free ( ), para um vetor que tenha em cada elemento a estrutura produtos_supermercado e cujo número de elementos seja definido pelo usuário apenas em tempo de execução.
Alocação dinâmica de Memória
Alocação dinâmica de Memória Vetores e Arrays A variável vetor é uma variável que armazena outras variáveis, no caso tem que ser do mesmo tipo. Exemplo Criar um cont Declarar um vet com o tamanho Laço
Estrutura de Dados. Aula 07 Alocação Dinâmica
Estrutura de Dados Aula 07 Alocação Dinâmica 2 ALOCAÇÃO DINÂMICA Existem três modos de reservar espaço de memória para o armazenamento de informações: 1ª - através do uso de variáveis globais (e estáticas).
a) Preencher um vetor com os números 0 a 10, e depois mostrar somente os elementos pares.
Instituto Federal de Santa Catarina - Câmpus Chapecó Ensino Médio Integrado em Informática - Módulo IV Unidade Curricular: Programação Estruturada Professora: Lara Popov Zambiasi Bazzi Oberderfer Plano
Algoritmos e Estruturas de Dados. Prof. Marcelo Zorzan Profa. Melissa Zanatta
Algoritmos e Estruturas de Dados Prof. Marcelo Zorzan Profa. Melissa Zanatta Assuntos da Aula Alocação de Memória Alocação estática de memória Alocação dinâmica de memória Malloc, Calloc, Free, Realloc
Exercício. Alocação Dinâmica. Alocação dinâmica de memória. Alocação de memória. Alocação da Memória Principal. Alocação da Memória Principal
Exercício Crie uma função que recebe o número de dias até um determinado evento e calcula e retorna o equivalente em meses, semanas e dias, sem usar vetor ou o conceito de vetor. Considerar que todos os
Universidade Federal de Uberlândia Faculdade de Computação. Linguagem C: ponteiros e alocação dinâmica
Universidade Federal de Uberlândia Faculdade de Computação Linguagem C: ponteiros e alocação dinâmica Prof. Renato Pimentel 1 Ponteiros 2 Prof. Renato Pimentel 1 Ponteiros: introdução Toda a informação
LINGUAGEM C: ALOCAÇÃO DINÂMICA
LINGUAGEM C: ALOCAÇÃO DINÂMICA Prof. André Backes DEFINIÇÃO Sempre que escrevemos um programa, é preciso reservar espaço para as informações que serão processadas. Para isso utilizamos as variáveis Uma
1/34 GESTÃO DINÂMICA DE MEMÓRIA
1/34 GESTÃO DINÂMICA DE MEMÓRIA Memória Estática 2/34 Memória Estática Exemplo #include main() { int V[300], N; do{ printf ( N =? ); scanf ( %d, &N); while ((N < 0) (N > 300); for (i = 0; i
Ponteiros. Introdução e Alocação Dinâmica
Ponteiros Introdução e Alocação Dinâmica Conceito Um PONTEIRO ou APONTADOR é uma variável usada para armazenar um endereço de memória. Normalmente, o endereço armazenado em um PONTEIRO é a posição de uma
A linguagem C permite dois tipos de alocação de memória: Alocação estática e alocação dinâmica.
Alocação de Memória Todo programa precisa utilizar memória para ser executado. Quando um programa inicia sua execução, ele começa a solicitar memória ao sistema operacional, ou seja, faz a alocação de
Estruturas de Dados Aulas 3 e 4: Uso da. 14/03/2011 e 16/03/2011
Estruturas de Dados Aulas 3 e 4: Uso da memória e Vetores 14/03/2011 e 16/03/2011 Uso da memória Existem 3 maneiras de reservar o espaço da memória: Variáveis globais (estáticas) Espaço existe enquanto
Alocação Estática e Dinâmica. Prof. M.Sc. Mariella Berger
Alocação Estática e Dinâmica Prof. M.Sc. Mariella Berger http://www.inf.ufes.br/~mberger [email protected] [email protected] Alocação Estática Estratégia de alocação de memória na qual toda a
Exercícios. Alocação Dinâmica. Alocação dinâmica de memória. Alocação de memória. Alocação da Memória Principal. Alocação da Memória Principal
Exercícios 1) Crie uma função que recebe os coeficientes de uma função do 2o. grau e retorna as raízes sem usar vetor. 2) Faça um programa que acha o maior e o menor inteiro dentro de um vetor de 10 inteiros,
Alocação Dinâmica em C
Universidade de São Paulo São Carlos Instituto de Ciências Matemáticas e de Computação Alocação Dinâmica em C Profa Rosana Braga Adaptado de material preparado pela profa Silvana Maria Affonso de Lara
Introdução a Programação. Ponteiros e Vetores, Alocação Dinâmica
Introdução a Programação Ponteiros e Vetores, Alocação Dinâmica Tópicos da Aula Hoje aprenderemos que existe uma forte relação entre ponteiros e vetores Associação entre ponteiros e vetores Ponteiros constantes
Introdução à Ciência da Computação I. Alocação Dinâmica. Prof. Claudio Fabiano Motta Toledo
Introdução à Ciência da Computação I Alocação Dinâmica Prof. Claudio Fabiano Motta Toledo Sumário Funções para alocação de memória Ponteiros para ponteiros 8/12/16 2 Funções para alocação de memória malloc(),
Ponteiros - Parte I. Ponteiros, Ponteiros e Vetores, Algoritmo Bubble Sort, Alocação Dinâmica de Memória
Ponteiros - Parte I Ponteiros, Ponteiros e Vetores, Algoritmo Bubble Sort, Alocação Dinâmica de Memória Ponteiros Um ponteiro é uma variável que contém um endereço de memória. Esse endereço é normalmente
Aula 17: Ponteiros e Alocação Dinâmica em C
Aula 17: Ponteiros e Alocação Dinâmica em C Fernanda Passos Universidade Federal Fluminense Programação de Computadores IV Fernanda Passos (UFF) Ponteiros e Alocação Dinâmica Programação de Computadores
Estruturas de Dados. Introdução Definição de Ponteiros Declaração de Ponteiros em C Manipulação de Ponteiros em C
Estruturas de Dados Revisão de Ponteiros Prof. Ricardo J. G. B. Campello Sumário Introdução Definição de Ponteiros Declaração de Ponteiros em C Manipulação de Ponteiros em C Operações Ponteiros e Arranjos
Estruturas Dinâmicas - Ponteiros
SSC0800 - ICC1 Teórica Introdução à Ciência da Computação I Estruturas Dinâmicas - Ponteiros Prof. Claudio Fabiano Motta Toledo: [email protected] Sumário Ponteiros Ponteiros e Vetores Funções para alocação
ALOCAÇÃO DINÂMICA DE MEMORIA Lista 10. A linguagem C/C++ possui recursos para alocação dinâmica de memoria.
ALOCAÇÃO DINÂMICA DE MEMORIA Lista 10 A linguagem C/C++ possui recursos para alocação dinâmica de memoria. As funções que trabalham com alocação de memoria se encontram na biblioteca void *calloc(int
ALGORITMOS E ESRUTRA DE DADOS I. Ponteiros Passagem por Valor e Referência Alocação de Memória
ALGORITMOS E ESRUTRA DE DADOS I Ponteiros Passagem por Valor e Referência Alocação de Memória 2 Agenda Ponteiros Conceitos gerais O que é Ponteiro? Declaração de Ponteiros Operadores para Ponteiros Exemplos
Alocação Dinâmica de Memória - Exercício
Alocação Dinâmica de Memória - Exercício Construa um programa que leia da entrada padrão o número de linhas e de colunas de uma matriz de floats, aloque espaço dinamicamente para esta e a inicialize, com
O que é um apontador em C (type pointer in C)?
O que é um apontador em C (type pointer in C)? Um apontador é uma variável que contém um endereço de outra variável. int x = 10;//variável inteira iniciada com o valor 10 int *px = &x;//variável apontadora
DAS5102 Fundamentos da Estrutura da Informação
Ponteiros e Funções Funções ou sub-rotinas são parcelas de código que podem ser invocadas a partir do programa principal ou até mesmo por outras sub-rotinas. Elas têm como objetivo a execução de uma tarefa
PONTEIROS E LISTAS. Kalinka Regina Lucas Jaquie Castelo Branco
PONTEIROS E LISTAS Kalinka Regina Lucas Jaquie Castelo Branco [email protected] ALOCAÇÃO DINÂMICA DE MEMÓRIA Pode-se assumir que as variáveis declaradas na cláusula variável do pseudo-código do algoritmo
1 Exercícios com ponteiros
Computação para Informática - Prof. Adriano Joaquim de Oliveira Cruz Oitava Aula Prática - 29 de outubro de 2010 O objetivo desta aula prática é exercitar ponteiros e funções. 1 Exercícios com ponteiros
Curso de Programação C em Ambientes Linux Aula 05
Curso de Programação C em Ambientes Linux Aula 05 Centro de Engenharias da Mobilidade - UFSC Professores Gian Berkenbrock e Giovani Gracioli http://www.lisha.ufsc.br/c+language+course+resources Conteúdo
Módulo 5 Vetores e Alocação Dinâmica
Estruturas de Dados Módulo 5 Vetores e Alocação Dinâmica 1/9/2005 (c) Dept. Informática - PUC-Rio 1 Referências Waldemar Celes, Renato Cerqueira, José Lucas Rangel, Introdução a Estruturas de Dados, Editora
1 Exercícios com ponteiros
Computação para Informática Funções e Ponteiros1 EXERCÍCIOS COM PONTEIROS Computação para Informática - Prof. Adriano Joaquim de Oliveira Cruz Aula Prática - Funções e ponteiros O objetivo desta aula prática
Alocação de Memória. Lucas Ferrari de Oliveira Professor Adjunto Universidade Federal do Paraná (UFPR)
Alocação de Memória Linguagem de Programação Estruturada 1 Alocação dinâmica e ponteiros Lucas Ferrari de Oliveira Professor Adjunto Universidade Federal do Paraná (UFPR) Sumario Introdução Alocação Estática
BCC202 - Estrutura de Dados I
BCC202 - Estrutura de Dados I Aula 02: Alocação Dinâmica de Memória Reinaldo Fortes Universidade Federal de Ouro Preto, UFOP Departamento de Ciência da Computação, DECOM Website: www.decom.ufop.br/reifortes
A sintaxe para se declarar uma variável do tipo ponteiro é dada por:
Pense duas vezes e faça uma vez. Provérbio Chinês. PONTEIROS Um ponteiro nada mais é que uma variável capaz de armazenar um número hexadecimal que corresponde a um endereço de memória de outra variável.
Programação Estruturada Prof. Rodrigo Hausen Organização e Gerenciamento de Memória
Programação Estruturada Prof. Rodrigo Hausen http://progest.compscinet.org Organização e Gerenciamento de Memória 1 AULA PASSADA - vetores ou arrays Declaração de um vetor (array) em C: tipo nome[tamanho];
Métodos Computacionais. Vetores e Matrizes Dinâmicas
Métodos Computacionais Vetores e Matrizes Dinâmicas Vetores Um programa para o cálculo da média Média m n i= = 1 n x i Variância v n i= = 1 ( x i n m) 2 A forma mais simples de estruturar um conjunto de
Programação de Computadores II. Cap. 5 Alocação Dinâmica
Programação de Computadores II Cap. 5 Alocação Dinâmica Livro: Waldemar Celes, Renato Cerqueira, José Lucas Rangel. Introdução a Estruturas de Dados, Editora Campus (2004) Slides adaptados dos originais
Função "malloc" e "calloc":
Função "malloc" e "calloc": São funções utilizadas para fazer a alocação dinâmica de memória. Essas funções alocam o endereço de memória e retornam esse endereço a uma variável do tipo ponteiro. Com essas
5. Vetores e alocação dinâmica
5. Vetores e alocação dinâmica W. Celes e J. L. Rangel 5.1. Vetores A forma mais simples de estruturarmos um conjunto de dados é por meio de vetores. Como a maioria das linguagens de programação, C permite
Ponteiros em C. Adriano Joaquim de Oliveira Cruz 21 de julho de Instituto de Matemática Departamento de Ciência da Computação UFRJ
Ponteiros em C Adriano Joaquim de Oliveira Cruz 21 de julho de 2017 Instituto de Matemática Departamento de Ciência da Computação UFRJ 1 Resumo da Seção Introdução Declaração Incrementando e Decrementando
Tipos Abstratos de Dados. Estrutura de Dados
Tipos Abstratos de Dados Tipo Abstrato de Dados ou TAD Idéia principal: desvincular o tipo de dado (valores e operações) de sua implementação: O que o tipo faz e não como ele faz! Vantagens da desvinculação:
