SlideShare ist ein Scribd-Unternehmen logo
1 von 17
Funções Inline 
e 
Funções 
Recursivas 
Kadzua 
Chakupadedza Kuyeri
Funções Inline 
 As funções inline servem como 
códigos a serem copiados ao lugar 
que são chamados. 
 Quando chamamos uma função inline 
em um programa, o compilador 
substitui a chamada de função pelo 
próprio código da função, adaptando 
automaticamente os parâmetros e 
retorno da função.
Sintaxe de declaração de uma 
função Inline 
 Para criar uma função inline basta fazer 
a mesma coisa que faríamos para criar 
uma função normal, a única diferença é 
que antes de começar a escrever a 
função devemos utilizar a palavra 
reservada inline. 
 Palavra _chave tipo_de_retorno nome_da_função (parâmetros) 
Exemplo:inline int kaddy(){ 
}
Funções Inline 
 A palavra-chave inline é usada em 
C++ e aplicada a uma função. Ela 
indica ao compilador que cada 
chamada para a função inline deve 
ser substituída pelo corpo desta 
função.
Exemplo de uso de Funções Inline 
 #include <iostream> 
 #include <math.h> 
 using namespace std; 
 long int quadrado (int x); 
 inline void opcao(); 
 main() { 
 int y,z; 
 cout<<"Introduza o numero para calcular o seu 
quadradon"; 
 cin>>y; 
 cout<<"O quadrado de "<<y<<" e 
t"<<quadrado(y)<<"nn"; 
 
 
 opcao(); 
 return 0; 
 }
Exemplo de uso de Funções Inline 
long int quadrado (int x){ 
return(x=pow(x,2)); 
} 
inline void opcao(){ 
int k; 
cout<<"Pretende efectuar mais um 
calculo?n1.Simt2.Naon"; 
cin>>k; 
switch(k){ 
case 1: 
main(); 
break;
Exemplo de uso de Funções Inline 
case 2: 
cout<<"Obrigado!!!"; 
break; 
default: 
cout<<"Opcao invalidann"; 
main();} 
}
Vantagem/Desvantagem do uso de 
Funções Inline 
 A vantagem é o aumento de 
desempenho (ganha-se velocidade 
com as funções inline), pois o 
programa não precisa se deslocar até 
achar a função. 
 Mas esse aumento de desempenho 
vem com um aumento no custo de 
espaço em memória.
Funções Recursivas 
 Uma função é recursiva se um 
comando no corpo da função chama 
ela mesma. 
 Qualquer função em linguagem C/C++ 
pode ser chamada de um modo 
recursivo, isto é, uma função pode 
chamar-se a si própria. 
 Para uma linguagem ser recursiva, 
uma função deve estar apta a chamar 
a si própria.
Criar Funções Recursivas 
 Para criar uma função recursiva basta 
escrever no código da função, a 
função que está sendo criada como 
se ela já tivesse sido criada antes, isto 
é, por exemplo, temos um programa 
em que sabemos que o código do 
programa está todo dentro da função 
main, se quisermos reiniciar o 
programa basta chamarmos a função 
main novamente.
Funcionamento da função 
recursiva 
 Início do programa: Chama 
automaticamente a função MAIN 
 Processos e comandos dentro do 
código: Contas com variáveis, 
condições, atribuições, etc... 
 Chama-se a função MAIN: Sem 
fechar o programa, ele chama ele 
mesmo de novo (reinicia).
Funções Recursivas 
 Dada uma função recursiva, sempre é 
possível escrever uma função 
equivalente, sem recursão.
Comparação entre função recursiva e a função 
equivalente sem recursão 
Função recursiva Código equivalente sem recursão 
#include <iostream> 
#include <math.h> 
using namespace std; 
long int quadrado (int x); 
main() { 
int y; 
cout<<"Introduza o numero para 
calcular o seu quadradon"; 
cin>>y; 
cout<<"O quadrado de "<<y<<" e 
t"<<quadrado(y); 
return 0; } 
long int quadrado (int x){ 
return x=pow(x,2); } 
#include <iostream> 
#include <math.h> 
using namespace std; 
long int quadrado (int x); 
main() { 
int y; 
cout<<"Introduza o numero para 
calcular o seu quadradon"; 
cin>>y; 
cout<<"O quadrado de "<<y<<" e 
t"<<quadrado(y); 
return 0; } 
long int quadrado (int x){ 
x=pow(x,2); 
return x; }
Exemplo de uso de Funções Recursivas 
#include <iostream> 
using namespace std; 
int main() { 
int x; 
cout<<"Veiculo:n1.Ligeiron2.Ligeiro de 
Cargan3.Pesado de passageiro e cargan4.Pesado de 
carga com atreladonn"; 
cin>>x; 
switch(x){ 
case 1: 
cout<<"Ligeiro:t10,00 meticais"; 
break;
Exemplo de uso de Funções 
Recursivas 
case 2: 
cout<<"Ligeiro de carga:t20,00 meticais"; 
break; 
case 3: 
cout<<"Pesado de passageiro e carga:t40,00 meticais"; 
break; 
case 4: 
cout<<"Pesado de carga e atrelado:t100,00 
meticais"; 
break; 
default: 
cout<<"Operacao invalidannnn"; 
main(); } 
cout<<"nnttObrigado!!!n"; 
cout<<"ttBoa viagem!"; 
return 0; }
Vantagem/Desvantagem do uso de 
Funções Recursivas 
 Usar a função recursiva torna o 
algoritmo simples. Quem faz toda a 
conta é a função. 
 Mas toda facilidade tem seu custo. 
Apesar de nosso algoritmo estar 
curto, toda vez que chamamos uma 
função leva um certo tempo para ser 
processada (a chamada de uma 
função consome tempo de 
processamento).
Fim 
Obrigado!

Weitere ähnliche Inhalte

Was ist angesagt?

Laboratório de Programação II: Uso do ponteiro void *
Laboratório de Programação II: Uso do ponteiro void *Laboratório de Programação II: Uso do ponteiro void *
Laboratório de Programação II: Uso do ponteiro void *Alex Camargo
 
Aula 7 profmat - numeros primos e especiais - 06 10-17
Aula 7   profmat - numeros primos e especiais - 06 10-17Aula 7   profmat - numeros primos e especiais - 06 10-17
Aula 7 profmat - numeros primos e especiais - 06 10-17Aline Guedes
 
Aula 3 revisão em matemática básica
Aula 3    revisão em matemática básicaAula 3    revisão em matemática básica
Aula 3 revisão em matemática básicaJosé Vitor Alves
 
Aula 4 - Teste de mesa
Aula 4 - Teste de mesaAula 4 - Teste de mesa
Aula 4 - Teste de mesaPacc UAB
 
Apresentaçao final planilhas eletrônica sv230511
Apresentaçao final planilhas eletrônica sv230511Apresentaçao final planilhas eletrônica sv230511
Apresentaçao final planilhas eletrônica sv230511juhpardo
 
Banco de Dados - Modelo Lógico, Chave primária e Chave estrangeira
Banco de Dados - Modelo Lógico, Chave primária e Chave estrangeiraBanco de Dados - Modelo Lógico, Chave primária e Chave estrangeira
Banco de Dados - Modelo Lógico, Chave primária e Chave estrangeiraNatanael Simões
 
Função de 1º Grau.
Função de 1º Grau.Função de 1º Grau.
Função de 1º Grau.carolgouvea
 
Excel fórmulas básicas
Excel fórmulas básicasExcel fórmulas básicas
Excel fórmulas básicasAfonso Lima
 
Metodos de ordenação estrutura de dados
Metodos de ordenação   estrutura de dadosMetodos de ordenação   estrutura de dados
Metodos de ordenação estrutura de dadosThalita Chaves
 
Aula sobre matrizes - Linguagem C
Aula sobre matrizes - Linguagem CAula sobre matrizes - Linguagem C
Aula sobre matrizes - Linguagem Cprofjr
 
Classificação das equações do 1º grau com uma
Classificação das equações do 1º grau com umaClassificação das equações do 1º grau com uma
Classificação das equações do 1º grau com umaAlexandre Cirqueira
 

Was ist angesagt? (20)

Árvores Rubro Negra
Árvores Rubro NegraÁrvores Rubro Negra
Árvores Rubro Negra
 
Laboratório de Programação II: Uso do ponteiro void *
Laboratório de Programação II: Uso do ponteiro void *Laboratório de Programação II: Uso do ponteiro void *
Laboratório de Programação II: Uso do ponteiro void *
 
Aula 7 profmat - numeros primos e especiais - 06 10-17
Aula 7   profmat - numeros primos e especiais - 06 10-17Aula 7   profmat - numeros primos e especiais - 06 10-17
Aula 7 profmat - numeros primos e especiais - 06 10-17
 
JAVA - Tratamento de Erros
JAVA - Tratamento de ErrosJAVA - Tratamento de Erros
JAVA - Tratamento de Erros
 
Aula 3 revisão em matemática básica
Aula 3    revisão em matemática básicaAula 3    revisão em matemática básica
Aula 3 revisão em matemática básica
 
Linguagem C - Ponteiros
Linguagem C - PonteirosLinguagem C - Ponteiros
Linguagem C - Ponteiros
 
Aula 4 - Teste de mesa
Aula 4 - Teste de mesaAula 4 - Teste de mesa
Aula 4 - Teste de mesa
 
torno cnc
 torno cnc torno cnc
torno cnc
 
Apresentaçao final planilhas eletrônica sv230511
Apresentaçao final planilhas eletrônica sv230511Apresentaçao final planilhas eletrônica sv230511
Apresentaçao final planilhas eletrônica sv230511
 
Aulas Word E Excel
Aulas   Word E ExcelAulas   Word E Excel
Aulas Word E Excel
 
Banco de Dados - Modelo Lógico, Chave primária e Chave estrangeira
Banco de Dados - Modelo Lógico, Chave primária e Chave estrangeiraBanco de Dados - Modelo Lógico, Chave primária e Chave estrangeira
Banco de Dados - Modelo Lógico, Chave primária e Chave estrangeira
 
Função de 1º Grau.
Função de 1º Grau.Função de 1º Grau.
Função de 1º Grau.
 
EXCEL 2019
EXCEL 2019EXCEL 2019
EXCEL 2019
 
O compilador dev c++
O compilador dev c++O compilador dev c++
O compilador dev c++
 
Excel fórmulas básicas
Excel fórmulas básicasExcel fórmulas básicas
Excel fórmulas básicas
 
Aula 11
Aula 11Aula 11
Aula 11
 
Metodos de ordenação estrutura de dados
Metodos de ordenação   estrutura de dadosMetodos de ordenação   estrutura de dados
Metodos de ordenação estrutura de dados
 
Aula sobre matrizes - Linguagem C
Aula sobre matrizes - Linguagem CAula sobre matrizes - Linguagem C
Aula sobre matrizes - Linguagem C
 
LP1 P01 - Python.pdf
LP1 P01 - Python.pdfLP1 P01 - Python.pdf
LP1 P01 - Python.pdf
 
Classificação das equações do 1º grau com uma
Classificação das equações do 1º grau com umaClassificação das equações do 1º grau com uma
Classificação das equações do 1º grau com uma
 

Ähnlich wie Funções inline e Recursivas

Algoritmos e Estrutura de Dados - Aula 03
Algoritmos e Estrutura de Dados - Aula 03Algoritmos e Estrutura de Dados - Aula 03
Algoritmos e Estrutura de Dados - Aula 03thomasdacosta
 
mod3-programação-estruturada
mod3-programação-estruturadamod3-programação-estruturada
mod3-programação-estruturadadiogoa21
 
Programação Estruturada 2 - Aula 02
Programação Estruturada 2 - Aula 02Programação Estruturada 2 - Aula 02
Programação Estruturada 2 - Aula 02thomasdacosta
 
RevisãoCompactaFuncoesPonteiro.pptx
RevisãoCompactaFuncoesPonteiro.pptxRevisãoCompactaFuncoesPonteiro.pptx
RevisãoCompactaFuncoesPonteiro.pptxClaudia Ferlin
 
Aula 8 - Modularização e Funções.pptx
Aula 8 - Modularização e Funções.pptxAula 8 - Modularização e Funções.pptx
Aula 8 - Modularização e Funções.pptxItamarGoncalves2
 
Aula - Funções (Curso de Python Básico -- FATEC SENAI MT)
Aula - Funções (Curso de Python Básico -- FATEC SENAI MT)Aula - Funções (Curso de Python Básico -- FATEC SENAI MT)
Aula - Funções (Curso de Python Básico -- FATEC SENAI MT)Filipe Chagas Ferraz
 
Linguagem C - Funções e ponteiros
Linguagem C - Funções e ponteiros Linguagem C - Funções e ponteiros
Linguagem C - Funções e ponteiros Karoline Tavares
 
Comandos de Controle de Programa em C
Comandos de Controle de Programa em CComandos de Controle de Programa em C
Comandos de Controle de Programa em CElaine Cecília Gatto
 
Funções PHP - Criação de sites II
Funções PHP - Criação de sites II Funções PHP - Criação de sites II
Funções PHP - Criação de sites II info_cimol
 
aula intro de Python sobre Funcoes.pdf
aula intro de  Python sobre  Funcoes.pdfaula intro de  Python sobre  Funcoes.pdf
aula intro de Python sobre Funcoes.pdfGabrielEduardo16342
 
Introdução à Linguagem de Programação C
Introdução à Linguagem de Programação CIntrodução à Linguagem de Programação C
Introdução à Linguagem de Programação CJose Augusto Cintra
 

Ähnlich wie Funções inline e Recursivas (20)

Algoritmos e Estrutura de Dados - Aula 03
Algoritmos e Estrutura de Dados - Aula 03Algoritmos e Estrutura de Dados - Aula 03
Algoritmos e Estrutura de Dados - Aula 03
 
Funções em C
Funções em CFunções em C
Funções em C
 
mod3-programação-estruturada
mod3-programação-estruturadamod3-programação-estruturada
mod3-programação-estruturada
 
Programação Estruturada 2 - Aula 02
Programação Estruturada 2 - Aula 02Programação Estruturada 2 - Aula 02
Programação Estruturada 2 - Aula 02
 
Apostila de-arduino
Apostila de-arduinoApostila de-arduino
Apostila de-arduino
 
Modularização
ModularizaçãoModularização
Modularização
 
RevisãoCompactaFuncoesPonteiro.pptx
RevisãoCompactaFuncoesPonteiro.pptxRevisãoCompactaFuncoesPonteiro.pptx
RevisãoCompactaFuncoesPonteiro.pptx
 
Aula 4
Aula 4Aula 4
Aula 4
 
Funções em C
Funções em CFunções em C
Funções em C
 
Aula 8 - Modularização e Funções.pptx
Aula 8 - Modularização e Funções.pptxAula 8 - Modularização e Funções.pptx
Aula 8 - Modularização e Funções.pptx
 
Linguagem C - Funções
Linguagem C - FunçõesLinguagem C - Funções
Linguagem C - Funções
 
Aula09 traducaosin110
Aula09 traducaosin110Aula09 traducaosin110
Aula09 traducaosin110
 
Aula - Funções (Curso de Python Básico -- FATEC SENAI MT)
Aula - Funções (Curso de Python Básico -- FATEC SENAI MT)Aula - Funções (Curso de Python Básico -- FATEC SENAI MT)
Aula - Funções (Curso de Python Básico -- FATEC SENAI MT)
 
Linguagem C - Funções e ponteiros
Linguagem C - Funções e ponteiros Linguagem C - Funções e ponteiros
Linguagem C - Funções e ponteiros
 
Comandos de Controle de Programa em C
Comandos de Controle de Programa em CComandos de Controle de Programa em C
Comandos de Controle de Programa em C
 
Funções PHP - Criação de sites II
Funções PHP - Criação de sites II Funções PHP - Criação de sites II
Funções PHP - Criação de sites II
 
aula intro de Python sobre Funcoes.pdf
aula intro de  Python sobre  Funcoes.pdfaula intro de  Python sobre  Funcoes.pdf
aula intro de Python sobre Funcoes.pdf
 
Funções e procedimentos
Funções e procedimentosFunções e procedimentos
Funções e procedimentos
 
apostila C++
apostila C++apostila C++
apostila C++
 
Introdução à Linguagem de Programação C
Introdução à Linguagem de Programação CIntrodução à Linguagem de Programação C
Introdução à Linguagem de Programação C
 

Funções inline e Recursivas

  • 1. Funções Inline e Funções Recursivas Kadzua Chakupadedza Kuyeri
  • 2. Funções Inline  As funções inline servem como códigos a serem copiados ao lugar que são chamados.  Quando chamamos uma função inline em um programa, o compilador substitui a chamada de função pelo próprio código da função, adaptando automaticamente os parâmetros e retorno da função.
  • 3. Sintaxe de declaração de uma função Inline  Para criar uma função inline basta fazer a mesma coisa que faríamos para criar uma função normal, a única diferença é que antes de começar a escrever a função devemos utilizar a palavra reservada inline.  Palavra _chave tipo_de_retorno nome_da_função (parâmetros) Exemplo:inline int kaddy(){ }
  • 4. Funções Inline  A palavra-chave inline é usada em C++ e aplicada a uma função. Ela indica ao compilador que cada chamada para a função inline deve ser substituída pelo corpo desta função.
  • 5. Exemplo de uso de Funções Inline  #include <iostream>  #include <math.h>  using namespace std;  long int quadrado (int x);  inline void opcao();  main() {  int y,z;  cout<<"Introduza o numero para calcular o seu quadradon";  cin>>y;  cout<<"O quadrado de "<<y<<" e t"<<quadrado(y)<<"nn";    opcao();  return 0;  }
  • 6. Exemplo de uso de Funções Inline long int quadrado (int x){ return(x=pow(x,2)); } inline void opcao(){ int k; cout<<"Pretende efectuar mais um calculo?n1.Simt2.Naon"; cin>>k; switch(k){ case 1: main(); break;
  • 7. Exemplo de uso de Funções Inline case 2: cout<<"Obrigado!!!"; break; default: cout<<"Opcao invalidann"; main();} }
  • 8. Vantagem/Desvantagem do uso de Funções Inline  A vantagem é o aumento de desempenho (ganha-se velocidade com as funções inline), pois o programa não precisa se deslocar até achar a função.  Mas esse aumento de desempenho vem com um aumento no custo de espaço em memória.
  • 9. Funções Recursivas  Uma função é recursiva se um comando no corpo da função chama ela mesma.  Qualquer função em linguagem C/C++ pode ser chamada de um modo recursivo, isto é, uma função pode chamar-se a si própria.  Para uma linguagem ser recursiva, uma função deve estar apta a chamar a si própria.
  • 10. Criar Funções Recursivas  Para criar uma função recursiva basta escrever no código da função, a função que está sendo criada como se ela já tivesse sido criada antes, isto é, por exemplo, temos um programa em que sabemos que o código do programa está todo dentro da função main, se quisermos reiniciar o programa basta chamarmos a função main novamente.
  • 11. Funcionamento da função recursiva  Início do programa: Chama automaticamente a função MAIN  Processos e comandos dentro do código: Contas com variáveis, condições, atribuições, etc...  Chama-se a função MAIN: Sem fechar o programa, ele chama ele mesmo de novo (reinicia).
  • 12. Funções Recursivas  Dada uma função recursiva, sempre é possível escrever uma função equivalente, sem recursão.
  • 13. Comparação entre função recursiva e a função equivalente sem recursão Função recursiva Código equivalente sem recursão #include <iostream> #include <math.h> using namespace std; long int quadrado (int x); main() { int y; cout<<"Introduza o numero para calcular o seu quadradon"; cin>>y; cout<<"O quadrado de "<<y<<" e t"<<quadrado(y); return 0; } long int quadrado (int x){ return x=pow(x,2); } #include <iostream> #include <math.h> using namespace std; long int quadrado (int x); main() { int y; cout<<"Introduza o numero para calcular o seu quadradon"; cin>>y; cout<<"O quadrado de "<<y<<" e t"<<quadrado(y); return 0; } long int quadrado (int x){ x=pow(x,2); return x; }
  • 14. Exemplo de uso de Funções Recursivas #include <iostream> using namespace std; int main() { int x; cout<<"Veiculo:n1.Ligeiron2.Ligeiro de Cargan3.Pesado de passageiro e cargan4.Pesado de carga com atreladonn"; cin>>x; switch(x){ case 1: cout<<"Ligeiro:t10,00 meticais"; break;
  • 15. Exemplo de uso de Funções Recursivas case 2: cout<<"Ligeiro de carga:t20,00 meticais"; break; case 3: cout<<"Pesado de passageiro e carga:t40,00 meticais"; break; case 4: cout<<"Pesado de carga e atrelado:t100,00 meticais"; break; default: cout<<"Operacao invalidannnn"; main(); } cout<<"nnttObrigado!!!n"; cout<<"ttBoa viagem!"; return 0; }
  • 16. Vantagem/Desvantagem do uso de Funções Recursivas  Usar a função recursiva torna o algoritmo simples. Quem faz toda a conta é a função.  Mas toda facilidade tem seu custo. Apesar de nosso algoritmo estar curto, toda vez que chamamos uma função leva um certo tempo para ser processada (a chamada de uma função consome tempo de processamento).