A LINGUAGEM DE PROGRAMAÇÃO C
|
|
|
- Paula Sabrosa Godoi
- 9 Há anos
- Visualizações:
Transcrição
1 Seminário de Linguagens de Programação A LINGUAGEM DE PROGRAMAÇÃO C Guilherme Pina Cardim Ruben de Best Prof. Dr. Rogério Eduardo Garcia
2 A Linguagem C C é uma linguagem de programação de finalidade geral que permite economia de expressão, modernos fluxos de controle e estruturas de dados e um rico conjunto de operadores. Sua falta de restrições e sua generalidade tornam-na mais conveniente e eficaz para muitas tarefas do que linguagens supostamente mais poderosas. Ritchie e Kernighan. Guilherme P. Cardim e Ruben de Best 2
3 Tópicos Histórico; Classificação; A que área se destina; Critérios de Avaliação; Outras Características; Mapa de Memória de um Programa C; Identificadores; Tipos de Dados e Tamanhos; Guilherme P. Cardim e Ruben de Best 3
4 Tópicos (...) Variáveis; Vinculações; Variáveis Estáticas; Variáveis Dinâmicas de Pilha; Variáveis Dinâmicas de Monte Explícitas; Escopo; Variável Extern; Register; Guilherme P. Cardim e Ruben de Best 4
5 Tópicos (...) Char; Strings; Struct; Union; Tipo Ordinal; Matrizes; Estruturas de Controle; Processo de Compilação; Guilherme P. Cardim e Ruben de Best 5 Bibliografia.
6 Histórico Desenvolvida por Dennis Ritchie nos laboratórios da BELL (AT&T Bell Labs) por volta dos anos 70 ( ), visando a implementação do Unix. Foi derivada da linguagem B, a qual se originou a partir da linguagem BCPL (Linguagem de Programação Básica Compilada). Descrito por Ritchie e Kernighan em 1978, porém somente em 1983 o ANSI (American National Standards Institute) definiu um padrão para a linguagem C. Guilherme P. Cardim e Ruben de Best 6
7 Classificação Médio Nível; Combina elementos de alto nível com funcionalidades de baixo nível da linguagem Assembly. Terceira Geração; Linguagem orientada ao usuário; Subclassificação: Procedimental. Paradigma Imperativo Estruturado. Centrado no conceito de um estado e ações que o manipulam; Instruções agrupadas em blocos. Guilherme P. Cardim e Ruben de Best 7
8 A que área se destina? A linguagem C não se destina a nenhuma área em específico. É uma linguagem de propósito geral. Ela é utilizada para diversos fins, inclusive para escrever compiladores de outras linguagens. É uma linguagem potente e flexível. Guilherme P. Cardim e Ruben de Best 8
9 Critérios de Avaliação Legibilidade; Capacidade de Escrita; Confiabilidade; Custo. Guilherme P. Cardim e Ruben de Best 9
10 Legibilidade Simplicidade Global: número de operadores e palavras reservadas é pequeno. Sobrecarga de operadores e multiplicidade de recursos. Exemplo: Incrementar uma variável inteira: cont = cont +1; cont += 1; cont++; ++cont; Guilherme P. Cardim e Ruben de Best 10
11 Legibilidade (...) Ortogonalidade: Existe falta de ortogonalidade em alguns aspectos de C. Um registro pode ser retornado de uma função, mas um array não. Parâmetros podem ser passados por valor, exceto array que deve ser passado por referência. Um elemento de uma estrutura não pode ser void, ou uma estrutura do mesmo tipo. Um elemento de um array não pode ser void ou uma função. Guilherme P. Cardim e Ruben de Best 11
12 Legibilidade (...) Instruções de Controle: Programação estruturada (while, for,...) reduzindo o uso do goto e consequentemente melhorando a legibilidade. Tipos de Dados e Estruturas: Possui facilidades para definir tipos e estruturas de dados adequadas para determinado problema. Guilherme P. Cardim e Ruben de Best 12
13 Legibilidade (...) Sintaxe: três fatores de sintaxe: Formas de Identificadores: o limite para identificadores em C não é pequeno, permitindo expressar o nome do identificador mais adequadamente. Palavras reservadas: C não permite utilizar palavras reservadas como variáveis. Guilherme P. Cardim e Ruben de Best 13
14 Legibilidade (...) Sintaxe: três fatores de sintaxe: Forma e significado: Instruções que a aparência indica a finalidade. Em C: -> (Ponteiro) Violação em C: A palavra reservada static possui diferentes significados: Definição de variável dentro da função: variável é criada no momento da compilação; Definição de variável fora de funções: é visível apenas no arquivo onde ocorre a definição. Em relação a variáveis static globais, Schildt (1996) afirma que esta é reconhecida apenas no arquivo no qual a mesma foi declarada. Guilherme P. Cardim e Ruben de Best 14
15 Legibilidade (...) Violação em C do static: Testes efetuados com os compiladores gcc 4.6.3, Borland C e Turbo C 3.0. Saída: Valor de i[1] A ideia descrita pela literatura de que uma variável static não é vista por outros arquivos não foi comprovada em nenhum dos compiladores testados (gcc 4.6.3; Borland C e Turbo C 3.0). Todos estes compiladores permitiram que a variável static declarada no arquivo c.c fosse vista e utilizada pelo arquivo principal. Guilherme P. Cardim e Ruben de Best 15
16 Capacidade de Escrita Simplicidade e Ortogonalidade: demasiada ortogonalidade pode prejudicar a capacidade de escrita. A linguagem C possui poucos construtores e um pequeno conjunto de regras para combiná-los. Suporte para Abstração: C permite a abstração de problemas reais com a utilização de tipos de dados existentes ou definidos juntamente com a definição de funções e seus comportamentos diante da abstração proposta. Guilherme P. Cardim e Ruben de Best 16
17 Capacidade de Escrita (...) Expressividade: C possui instruções expressivas, como: cont++; ao invés de cont = cont + 1; cont -= x; ao invés de cont = cont x; for(i=0; i<100; i++){} para laços de contagem ao invés de while. Guilherme P. Cardim e Ruben de Best 17
18 Confiabilidade Verificações de Tipos: em C ANSI os tipos dos parâmetros passados para uma função não eram verificados de acordo com os tipos definidos pela função. Atualmente os compiladores já fazem esta verificação. Manipulação de exceções: praticamente não existe manipulação de exceções ocorridas em tempo de execução em C. Inclui facilidades que permitem a implementação de uma funcionalidade similar. Guilherme P. Cardim e Ruben de Best 18
19 Confiabilidade (...) Aliasing: em C pode-se utilizar o conceito de aliasing facilmente pela criação de dois ponteiros apontando para o mesmo local de memória, ou pelo uso do tipo union. Legibilidade e Capacidade de Escrita: Descritas e especificadas anteriormente. Guilherme P. Cardim e Ruben de Best 19
20 Custo Treinamento; Escrita; Compilação; Execução; Sistemas de Implementação da linguagem; Confiabilidade; Manutenção. Guilherme P. Cardim e Ruben de Best 20
21 Critérios de Avaliação (...) Característica Legibilidade Capacidade de Escrita Confiabilidade Simplicidade/Ortogonalidade X X X Estruturas de controle X X X Tipos de dados e estruturas X X X Projeto de sintaxe X X X Suporte para abstração X X Expressividade X X Verificação de tipos X Manipulação de exceções X Apelido restrito X Guilherme P. Cardim e Ruben de Best 21
22 Outras Características Desenvolvimento em Unix: é a linguagem oficial deste sistema operacional; Flexível: de propósito geral, não é limitada para nenhum tipo de aplicação; Eficiente: possuindo funcionalidades de baixo nível, consegue obter performances semelhantes ao Assembly; Simples: com um número pequeno de palavras reservadas, tipos de dados e operadores; Guilherme P. Cardim e Ruben de Best 22
23 Outras Características (...) Popular: internacionalmente conhecida e utilizada. Além de muito bem documentada, existem compiladores para praticamente todas as plataformas e arquiteturas de computadores; Portabilidade: sendo definida por uma padrão ANSI, de modo geral o código escrito em uma máquina pode ser transportado e compilado em outra máquina sem maiores complicações. Guilherme P. Cardim e Ruben de Best 23
24 Mapa de Memória de um Programa C Guilherme P. Cardim e Ruben de Best 24
25 Identificadores Identificadores devem iniciar com uma letra ou um underscore, sendo seguidos por mais letras, underscores, ou números. Podem ter no máximo 31 caracteres. Linguagem case-sensitive. Palavras reservadas não podem ser utilizadas como outros identificadores. Guilherme P. Cardim e Ruben de Best 25
26 Identificadores Relação de palavras reservadas no padrão ANSI: auto double int struct break else long switch case enum register typedef char extern return union const float short unsigned continue for signed void default goto sizeof volatile do if static while Guilherme P. Cardim e Ruben de Best 26
27 Tipos de Dados e Tamanhos Há poucos tipos primitivos de dados em C. void; char; int; float; double. Podem ser aplicados qualificadores a estes tipos primitivos, disponibilizando tamanhos diferentes quando isto por necessário. short; long; signed; unsigned. Guilherme P. Cardim e Ruben de Best 27
28 Variáveis Variáveis são abstrações de uma célula de memória. Aumentam muito a legibilidade e facilitam a manutenção do código. Caracterizados pela sêxtupla: Nome, endereço, valor, tipo, tempo de vida e escopo. É necessária a declaração de todas as variáveis. Guilherme P. Cardim e Ruben de Best 28
29 Vinculação de Atributos a Variáveis Relembrando Uma vinculação é estática se ela ocorre pela primeira vez antes do tempo de execução e permanece intocada ao longo da execução do programa. Uma vinculação é dinâmica se ela ocorre pela primeira vez durante a execução do programa ou se ela pode ser alterada durante o tempo de execução. Guilherme P. Cardim e Ruben de Best 29
30 Vinculações de Tipos Em C a vinculação de tipos e estática e é feita uma declaração explícita, ou seja, existe uma sentença no programa que lista os nomes das variáveis e seu tipo. Guilherme P. Cardim e Ruben de Best 30
31 Vinculações de Armazenamento e Tempo de Vida O tempo de vida de uma variável é o tempo durante o qual ela está vinculada a uma posição específica da memória. Variáveis estáticas. Variáveis dinâmicas de pilha. Variáveis dinâmicas de monte explícitas. Obs: Variáveis dinâmicas de monte implícitas não existem em C. Guilherme P. Cardim e Ruben de Best 31
32 Variáveis estáticas Vantagens Endereçamento direto. Sensíveis ao histórico. Desvantagens Não podem ser utilizadas em recursão. Redução da flexibilidade. Desperdício de memória. Teste efetuado com o compilador gcc Guilherme P. Cardim e Ruben de Best 32
33 Variáveis dinâmicas de pilha Vantagens Permitem recursão. Melhor utilização de memória. Desvantagens Não sensíveis ao histórico. Endereçamento indireto. Sobrecarga em tempo de execução de alocação e liberação. Teste efetuado com o compilador gcc Guilherme P. Cardim e Ruben de Best 33
34 Variáveis Dinâmicas de Monte Explícitas Células de memória alocadas e liberadas por instruções explícitas tem tempo de execução pelo programador. Necessidade de utilização de ponteiros. Vantagens Armazenamento dinâmico Uso otimizado de memória. Desvantagens Em C existe a necessidade de liberação da memória pelo programador. Ineficiente. Altamente sujeito a erros. Guilherme P. Cardim e Ruben de Best 34
35 Variáveis Dinâmicas de Monte Explícitas Teste efetuado com o compilador gcc Guilherme P. Cardim e Ruben de Best 35
36 Escopo O escopo de uma variável é a faixa de sentenças nas quais ela é visível. Variáveis podem ser: Locais Globais Em C a o escopo das variáveis é estático, ou seja, pode ser definido antes da execução. Guilherme P. Cardim e Ruben de Best 36
37 Escopo Local São declaradas em funções ou em blocos. Podem ser acessadas dentro da função ou do bloco onde foram declaradas. Teste efetuado com o compilador gcc Guilherme P. Cardim e Ruben de Best 37
38 Escopo Global São reconhecidas em todo o programa. Se uma variável local utilizar o mesmo nome, a variável global não poderá ser referenciada. Teste efetuado com o compilador gcc Guilherme P. Cardim e Ruben de Best 38
39 Variável extern Apenas o tipo e o nome da variável são definidos, e se referem a uma variável declarada em outro arquivo. Na compilação esta dependência é resolvida. Quando o compilador encontrar duas variáveis possíveis (com mesmo nome) para linkar a uma variável definida como extern o compilador avisa o usuário de uma dupla declaração da variável. Guilherme P. Cardim e Ruben de Best 39
40 Escopo / extern Saída: Teste efetuado com o compilador Guilherme gcc P Cardim e Ruben de Best 40
41 register Utilizados para aumento de desempenho. Só podem ser declarados localmente. Armazenamento em registradores da CPU ao invés de na memória. Guilherme P. Cardim e Ruben de Best 41
42 register real user sys Teste efetuado com o compilador gcc Teste efetuado com o compilador gcc m6.252s real 0m20.130s 0m6.252s user 0m20.133s 0m0.000s sys 0m0.000s Guilherme P. Cardim e Ruben de Best 42
43 char É um inteiro de 1 byte. Podemos fazer aritmética sobre char como fazemos sobre inteiros. Letras e símbolos são exibidos utilizando-se a codificação ASCII. Esta tabela pode ser encontrada em Guilherme P. Cardim e Ruben de Best 43
44 char Teste efetuado Guilherme com P. o compilador Cardim e gcc Ruben de Best 44
45 char Teste efetuado com o compilador gcc Guilherme P. Cardim e Ruben de Best 45
46 Strings String não é um tipo primitivo do C. Pode ser implementado através de array de char. Existe a biblioteca string.h que é padrão ANSI e foi criada para fazer a manipulação desses arrays de char. Guilherme P. Cardim e Ruben de Best 46
47 struct Uma struct consiste de uma lista de campos. O tamanho total de uma struct é calculado pela soma dos tamanhos dos seus campos. Em alguns compiladores existe a necessidade de um padding de controle. Este padding é feito para garantir o correto alinhamento. Guilherme P. Cardim e Ruben de Best 47
48 struct sizeof(struct exemplo)=32 sizeof(struct exemplo2)=20 Teste efetuado com o compilador gcc e Borland C sizeof(struct exemplo)=12 sizeof(struct exemplo2)=12 Teste efetuado com o compilador Turbo C 3.0 Guilherme P. Cardim e Ruben de Best 48
49 union Uma union é uma coleção de variáveis de tipos diferentes, sendo que só é possível guardar informações em uma variável por vez. Uma union tem o tamanho da maior variável nela presente. Melhor aproveitamento de memória. Dificuldade de utilização e altamente sujeito a erros. Guilherme P. Cardim e Ruben de Best 49
50 union Teste efetuado com o compilador gcc Guilherme P. Cardim e Ruben de Best 50
51 Tipo Ordinal Tipo enumerado: Utilizado principalmente para aumentar legibilidade do código. Exemplo: enum week {Mon = 1, Tue, Wed, Thu, Fri, Sat, Sun}; Tipo sub-faixa não existe em C. Vantagem sobre #define é que enum tem escopo. Guilherme P. Cardim e Ruben de Best 51
52 Matrizes Formato básico: tipo array [dim], onde: tipo: tipo de dado array: nome do array dim: dimensão do array. Deve ser inteiro. Alocação de um bloco contínuo de memória. Tamanho (array) = sizeof(tipo) * dim Guilherme P. Cardim e Ruben de Best 52
53 Matrizes Matriz estática Matriz dinâmica da pilha fixa Matriz dinâmica da pilha Matriz dinâmica do monte fixa Guilherme P. Cardim e Ruben de Best 53
54 Matriz Estática Vinculação estática de índices. Alocação de armazenamento estática, feita antes da execução. Vantagem: Eficiente: Nenhuma alocação ou liberação dinâmica é necessária. Desvantagens: Armazenamento vinculado por toda a execução. Guilherme P. Cardim e Ruben de Best 54
55 Matriz Estática Teste efetuado com o compilador gcc Guilherme P. Cardim e Ruben de Best 55
56 Matriz Dinâmica da Pilha Fixa Vinculação estática de índices. Alocação de armazenamento feita em tempo de execução. Vantagens: Uso de memória mais eficiente. Desvantagens: Tempo necessário para a alocação e liberação. Guilherme P. Cardim e Ruben de Best 56
57 Matriz Dinâmica da Pilha Fixa Guilherme P. Cardim e Ruben de Best 57 Teste efetuado com o compilador gcc 4.6.3
58 Matriz Dinâmica da Pilha Faixas de índices e a alocação de armazenamento vinculadas em tempo de elaboração. Vantagens: Utilização ainda mais eficiente de memória. Desvantagens: Tempo necessário para a alocação e liberação. Guilherme P. Cardim e Ruben de Best 58
59 Matriz Dinâmica da Pilha Este código executou perfeitamente no compilador gcc No entanto os compiladores Borland C e Turbo C 3.0 um erro é apresentado. Para estes compiladores é necessário uma constante, impedindo assim o uso de uma Matriz Dinâmica de Pilha. Guilherme P. Cardim e Ruben de Best 59 Teste efetuado com o compilador gcc 4.6.3
60 Matriz Dinâmica de Monte Fixa Faixas de índices e a alocação de armazenamento vinculadas em tempo de elaboração. Diferentemente das anteriores, neste caso a memória alocada é do monte e não da pilha. Utilização das funções da biblioteca padrão stdlib.h: free malloc Guilherme P. Cardim e Ruben de Best 60
61 Matriz Dinâmica de Monte Fixa Vantagens: Flexibilidade tamanho da matriz sempre se encaixa no problema. Desvantagens: Tempo necessário para a alocação e liberação no monte é maior do que na pilha. Necessidade de liberação manual de memória através do comando free. Guilherme P. Cardim e Ruben de Best 61
62 Matriz Dinâmica de Monte Fixa Teste efetuado com o compilador gcc Guilherme P. Cardim e Ruben de Best 62
63 Matrizes e Aritmética de Ponteiros int arr[3] Em C: arr[i] = * (arr + i) Em bytes: endereço(arr[i]) = endereço(arr) + [ tamanho(int) * i] Guilherme P. Cardim e Ruben de Best 63
64 Matrizes e Aritmética de Ponteiros Teste efetuado com o compilador gcc Teste efetuado com o compilador gcc Guilherme P. Cardim e Ruben de Best 64
65 Matrizes Multidimensionais Arrays possuem apenas uma dimensão, mas elementos podem ser outros arrays. Formato básico: tipo array [dim1]...[dimn], onde: tipo: tipo de dado array: nome do array dim1,...,dimn: dimensões Alocação de um bloco contínuo de memória. Tamanho (array) = sizeof(tipo) * dim1 *... * dimn Guilherme P. Cardim e Ruben de Best 65
66 Matrizes Multidimensionais (...) int arr[numlinhas][numcolunas] Em C: arr[i][j] = * (arr + i * numcolunas + j) Em bytes: endereço(arr[i][j]) = endereço(arr) + [sizeof (int) * i * numcolunas + j * sizeof (int)] Guilherme P. Cardim e Ruben de Best 66
67 Matrizes Multidimensionais (...) Teste efetuado com o compilador gcc Guilherme P. Cardim e Ruben de Best 67
68 Estruturas de Controle Testes: if: Operador Ternário: switch: Guilherme P. Cardim e Ruben de Best 68
69 Estruturas de Controle (...) Loops: while: do_while: for: = Guilherme P. Cardim e Ruben de Best 69
70 Estruturas de Controle (...) Comandos de Desvio: return: encerra o fluxo em uma função e retorna para o local onde foi chamada; exit: encerra o fluxo do programa, ou seja, finaliza o programa imediatamente; Guilherme P. Cardim e Ruben de Best 70
71 Estruturas de Controle (...) Comandos de Desvio: break: Finalizar um case na decisão de um switch, ou interromper imediatamente um loop. continue: salta imediatamente para a próxima iteração do loop. Guilherme P. Cardim e Ruben de Best 71
72 Estruturas de Controle (...) Comandos de Desvio: goto: é um comando de salto incondicional. Realiza um salto para um local especificador por um rótulo. Guilherme P. Cardim e Ruben de Best 72
73 Estruturas de Controle (...) Comandos de Desvio: break X continue X goto Guilherme P. Cardim e Ruben de Best 73
74 Testes efetuado com o compilador gcc Estruturas de Controle (...) Comandos de Desvio: break X continue X goto Guilherme P. Cardim e Ruben de Best 74
75 Processo de Compilação O processo de Compilação em C envolve três passos principais: Pré Processador; Compilação; Linkagem. Código Fonte Código Intermediário Código Objeto Pré Processador Compilador Código Executável Linker Bibliotecas Externas Guilherme P. Cardim e Ruben de Best 75
76 Pré Processador É responsável por processar as linguagem. As principais são: #include #define #undef #ifdef #ifndef #if #else #elif #endif diretivas da Guilherme P. Cardim e Ruben de Best 76
77 Pré Processador (...) As diretivas são processadas nesta etapa e geram um novo código para o compilador. Pré Processador Testes efetuado com o compilador gcc Pré Processador Guilherme P. Cardim e Ruben de Best 77
78 Compilador Recebe o código intermediário e gera as instruções de máquina em um código objeto. Trata cada arquivo fonte como uma unidade de compilação. Na verdade ele gera um código Assembly e logo em seguida executa um montador Assembler para gerar o código de máquina. Guilherme P. Cardim e Ruben de Best 78
79 Compilador (...) Código Assembly Código Intermediário Assembly Código Objeto Ling. de Máquina Montador Guilherme P. Cardim e Ruben de Best 79
80 Linker Reune todos os códigos objetos em um único arquivo executável; Substitui todas as chamadas de funções e acessos a variáveis ao seu real endereço na memória; Organiza cada função e variável dentro do espaço da memória. Guilherme P. Cardim e Ruben de Best 80
81 Linker (...) Códigos Objeto Linker Arquivo Executável error LNK2019: unresolved external symbol _proc referenced in function _main Guilherme P. Cardim e Ruben de Best 81
82 Considerações Finais Linguagem robusta; Permite desenvolver aplicações para praticamente todos os tipos de problemas; Permite a manipulação direta de memória; Rápida; Características de baixo nível permitindo performances semelhantes ao Assembly; Flexível; Altamente sujeita a erros por parte do programador. Guilherme P. Cardim e Ruben de Best 82
83 Bibliografia nharia/avaliacao_da_linguagem.pdf as/topico%202%20- %20Linguagens%20de%20Programa%E7%E3o%20Conceitos%20B%E1sicos.pdf _incondicionais:_goto estruturas-de-controle Guilherme P. Cardim e Ruben de Best 83
84 Bibliografia (...) 0de%20Compilacao.pdf %C3%A3o processador#usos_comuns_das_diretivas ml Guilherme P. Cardim e Ruben de Best 84
85 Bibliografia (...) AX/enum.html Kernighan, B. W. C Linguagem de Programação Padrão ANSI. Editora Campus Ed 2. Damas, L. Linguagem C. LTC Ed 10. Sebesta, R. W. Conceitos de Linguagens de Programação. Bookman Ed 5. Schildt, H. C Completo e Total. Makron Books Ed 3. GARCIA, R. E. Linguagem de Programação. Notas de Aula, Unesp-FCT Guilherme P. Cardim e Ruben de Best 85
#include <stdio.h> Void main() { printf( Cheguei!\n"); } INTRODUÇÃO A LINGUAGEM C
#include Void main() { printf( Cheguei!\n"); } INTRODUÇÃO A LINGUAGEM C ANTES DO C ERA A LINGUAGEM B B foi essencialmente uma simplificação da linguagem BCPL. B só tinha um tipo de dado, que
Linguagem C Princípios Básicos (parte 1)
Linguagem C Princípios Básicos (parte 1) Objetivos O principal objetivo deste artigo é explicar alguns conceitos fundamentais de programação em C. No final será implementado um programa envolvendo todos
Programação de Computadores I Introdução ao C PROFESSORA CINTIA CAETANO
Programação de Computadores I Introdução ao C PROFESSORA CINTIA CAETANO Introdução Criada em 1972, por Dennis Ritchie; Centro de Pesquisas da Bell Laboratories; Para utilização no S.O. UNIX; C é uma linguagem
Linguagem de Programação. Thiago Leite Francisco Barretto
Linguagem de Programação Thiago Leite Francisco Barretto SCHILDT, H. C Completo e Total. 3ª Edição. São Paulo: Makron, 1997. Bibliografia Ementa
3. Linguagem de Programação C
Introdução à Computação I IBM1006 3. Linguagem de Programação C Prof. Renato Tinós Departamento de Computação e Matemática (FFCLRP/USP) 1 Principais Tópicos 3.2. Estrutura de Programas e Representação
Estruturas da linguagem C. 1. Identificadores, tipos primitivos, variáveis e constantes, operadores e expressões.
1 Estruturas da linguagem C 1. Identificadores, tipos primitivos, variáveis e constantes, operadores e expressões. Identificadores Os identificadores seguem a duas regras: 1. Devem ser começados por letras
Capítulo 5. Nomes, Vinculações e Escopos
Capítulo 5 Nomes, Vinculações e Escopos Tópicos do Capítulo 5 Introdução Nomes Variáveis O conceito de vinculação Escopo Escopo e tempo de vida Ambientes de referenciamento Constantes nomeadas Introdução
Fundamentos de Programação. Linguagem C++ Introdução, identificadores, tipos de dados. Prof. Bruno E. G. Gomes IFRN
Fundamentos de Programação Linguagem C++ Introdução, identificadores, tipos de dados Prof. Bruno E. G. Gomes IFRN 1 Linguagem de Programação Constituída por símbolos e por regras para combinar esses símbolos
PLANO DE UNIDADE DIDÁTICA- PUD
Professor: Marcus Vinícius Midena Ramos Coordenação: Ricardo Argenton Ramos Data: 03/08/2010 Página: 1 de 5 EMENTA: Conceitos básicos de linguagens. Histórico, classificação e principais aplicações de
Universidade Estadual de Mato Grosso do Sul Ciência da Computação Algoritmos e Estruturas de Dados I (AED-I) Prof. Nilton
Universidade Estadual de Mato Grosso do Sul Ciência da Computação Algoritmos e Estruturas de Dados I (AED-I) Prof. Nilton [email protected] Introdução A linguagem C foi inventada por Dennis Ritchie e
Nomes, vinculações e escopos
Nomes, vinculações e escopos Marco A L Barbosa malbarbo.pro.br Departamento de Informática Universidade Estadual de Maringá cba Este trabalho está licenciado com uma Licença Creative Commons - Atribuição-CompartilhaIgual
Cláudio C. Rodrigues Faculdade da Computação - UFU. Faculdade da Computação - UFU 1
Cláudio C. Rodrigues Faculdade da Computação - UFU LINGUAGEM C - 01: TIPOS, VARIÁVEIS E E/S PADRÃO Faculdade da Computação - UFU 1 A Linguagem C Linguagem de alto nível, genérica. Foi desenvolvida por
Programação I A Linguagem C. Prof. Carlos Alberto
Programação I A Linguagem C Prof. Carlos Alberto [email protected] [email protected] 2 Origem A linguagem C foi desenvolvida em 1972, nos Laboratórios Bell, por Dennis Ritchie. Implementada
Linguagens de Programação
Linguagens de Programação 128 13 129 Linguagens de Programação Uma linguagem de programação é um vocabulário e um conjunto de regras gramaticais usadas para escrever programas de computador. Esses programas
Programação Estruturada
Programação Estruturada Introdução à linguagem C Professores Emílio Francesquini e Carla Negri Lintzmayer 2018.Q3 Centro de Matemática, Computação e Cognição Universidade Federal do ABC Programação estruturada
Nomes, vinculações e escopos
Nomes, vinculações e escopos Marco A L Barbosa malbarbo.pro.br Departamento de Informática Universidade Estadual de Maringá cba Este trabalho está licenciado com uma Licença Creative Commons - Atribuição-CompartilhaIgual
Introdução à Linguagem C
Engenharia de CONTROLE e AUTOMAÇÃO Introdução à Linguagem C Aula 02 DPEE 1038 Estrutura de Dados para Automação Curso de Engenharia de Controle e Automação Universidade Federal de Santa Maria [email protected]
Linguagens de Programação PROGRAMAÇÃO DE COMPUTADORES. Linguagem C. Linguagem C Estrutura Básica. Constante (literais) Linguagem C Primeiro Programa
Linguagens de Programação PROGRAMAÇÃO DE COMPUTADORES Linguagem C - Introdução Linguagens de Máquina Representação numérica Difícil utilização e compreensão Específica para cada máquina Linguagens Simbólicas(Assembly)
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
Entender o problema Encontrar um algoritmo para resolvê-lo. Implementar o algoritmo numa linguagem de programação
Entender o problema Encontrar um algoritmo para resolvê-lo Implementar o algoritmo numa linguagem de programação Permitem implementar um algoritmo Expressar o algoritmo numa forma que o computador entenda
Algoritmos e Programação
Algoritmos e Programação Aula 3 Introdução a Linguagem C Profa. Marina Gomes [email protected] 1 Aula de Hoje - Criar programas simples em C utilizando a estrutura básica; - Declarar variáveis;
Programação 1. Atribuição, operadores aritméticos, entrada de dados. Técnico em Eletrônica Semestre 5 02
Programação 1 Atribuição, operadores aritméticos, entrada de dados Técnico em Eletrônica Semestre 5 02 Armazenando na memória tipo de variável #include #include main() { int ano; Declaração
Carlos Eduardo Batista. Centro de Informática - UFPB
Linguagem de Programação I Carlos Eduardo Batista Centro de Informática - UFPB [email protected] Complexidade dos sistemas de software Estrutura Decomposição Abstração Hierarquia Projeto de sistemas complexos
Anhanguera Educacional S.A. Centro Universitário Ibero-Americano
O C++ foi inicialmente desenvolvido por Bjarne Stroustrup durante a década de 1980 com o objetivo de melhorar a linguagem de programação C, mantendo a compatibilidade com esta linguagem. Exemplos de Aplicações
Programação Estruturada I
Programação Estruturada I Introdução a Linguagem C Prof. Thiago Caproni Tavares 1 Prof. Mateus dos Santos 2 1 [email protected] 2 [email protected] Última Atualização:
INTRODUÇÃO À LINGUAGEM PASCAL PREFÁCIO
INTRODUÇÃO À LINGUAGEM PASCAL CESAR BEZERRA TEIXEIRA,MSC PREFÁCIO A linguagem C foi desenvolvida no início da década de 70 por dois pesquisadores do Bell Laboratories, Brian Kernihgan e Dennis Ritchie,
MCTA028 Programação Estruturada Aula 01: - Introdução à linguagem C - Teste de avaliação
MCTA028 Programação Estruturada Aula 01: - Introdução à linguagem C - Teste de avaliação Prof. João Henrique Kleinschmidt Material elaborado pelo Prof. Jesús P. Mena-Chalco 3Q-2018 Linguagens de programação
Revisão C++ - Parte 1
Revisão C++ - Parte 1 Prof. Gustavo Leitão Campus Natal Central Disciplina Programação para Ambiente de Redes 5/3/2010 Objetivo da Aula 5/3/2010 5/3/2010 OBJETIVO DA AULA Revisar os principais comandos
Revisão Linguagem C Parte 1
Revisão Linguagem C Parte 1 Comentários: Os comentários aparecem em verde e podem iniciados com /* e encerrados com */ quando utilizase várias linhas ou coloca-se // quando forem colocados em apenas uma
Introdução à Linguagem C
Introdução à Linguagem C Eduardo Simões de Albuquerque Instituto de Informática UFG 13/03/2006 1 História Inventada e desenvolvida por Dennis Ritchie em um DEC- PDP 11 Originária de: BCPL desenvolvida
Métodos Computacionais
Métodos Computacionais Objetivos da Disciplina e Introdução a Linguagem C Construções Básicas Objetivos da Disciplina Objetivo Geral Discutir técnicas de programação e estruturação de dados para o desenvolvimento
Algoritmos e Introdução à Programação. Lógica e Linguagem de Programação
Algoritmos e Introdução à Programação Lógica e Linguagem de Programação Prof. José Honorato Ferreira Nunes [email protected] http://softwarelivre.org/zenorato/honoratonunes Linguagem C Prof.
A Linguagem C. A forma de um programa em C
A Linguagem C Criada em 1972 por D. M. Ritchie e K. Thompson. Tornou-se uma das mais importantes e populares, principalmente pela portabilidade e flexibilidade. Foi projetada para o desenvolvimento de
# Estrutura de Dados # Aula - Revisão de C/C++ na Prática. Prof. Leinylson Fontinele Pereira
# Estrutura de Dados # Aula - Revisão de C/C++ na Prática Prof. Leinylson Fontinele Pereira Na aula anterior... Ponteiros Funções Introdução 3 O que vamos aprender? Preparação do ambiente de testes Conceitos
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
Programação II. Introdução à Linguagem C
Programação II Introdução à Linguagem C Um Pouco da História da Linguagem C Origem: década de 70 (Dennis Ritchie) BCPL B C. Prover acesso de baixo nível ao hardware (CPU, I/Os e periféricos) e se entender
Tipos Básicos. Operadores de Incremento e Decremento. Operador Sizeof. Estruturas de Dados Aula 2: Estruturas Estáticas
Tipos Básicos Quantos valores distintos podemos representar com o tipo char? Estruturas de Dados Aula 2: Estruturas Estáticas 03/03/2010 Operadores de Incremento e Decremento ++ e -- Incrementa ou decrementa
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
Paradigmas de Linguagens de Programação. Nomes, Vinculações, Verificação de Tipos e Escopos
Nomes, Vinculações, Verificação de Tipos e Escopos Cristiano Lehrer Nomes (1/6) Um nome é uma string de caracteres usada para identificar alguma entidade de um programa. O termo identificador é utilizado
LINGUAGEM C: VARIÁVEIS E EXPRESSÕES
LINGUAGEM C: VARIÁVEIS E EXPRESSÕES Prof. André Backes LINGUAGENS DE PROGRAMAÇÃO Linguagem de Máquina Computador entende apenas pulsos elétricos Presença ou não de pulso 1 ou 0 Tudo no computador deve
Programação científica C++
Programação científica C++ NIELSEN CASTELO DAMASCENO Slide 2 Expressões Combinação de dados e operadores que resulta em um valor. expressão x = 2 * y + 4; variável operador constante Memória do computador
Conceitos de Linguagens de Programação - Características. Paavo Soeiro
Conceitos de Linguagens de Programação - Características Paavo Soeiro Motivação Para que possa escolher uma linguagem apropriada ao problema. Melhorar o entendimento da linguagem utilizada. Facilitar o
Introdução à Programação. Introdução a Linguagem C. Prof. José Honorato F. Nunes
Introdução à Programação Introdução a Linguagem C Prof. José Honorato F. Nunes [email protected] Resumo da aula Introdução Variáveis Tipos de dados Operadores e Expressões: Operadores
Linguagem de Programação C
Linguagem de Programação C Aula 08 Diogo Pinheiro Fernandes Pedrosa Universidade Federal Rural do Semiárido Departamento de Ciências Exatas e Naturais 13 de novembro de 2009 Introdução O que é uma linguagem
Linguagens de Programação I
Linguagens de Programação I Tema # 4 Operadores em C Susana M Iglesias FUNÇÕES ENTRADA-SAÍDA I/O printf(), utilizada para enviar dados ao dispositivo de saída padrão (stdout), scanf(), utilizada para ler
4. Estruturas Fundamentais de Programação em C
4. Estruturas Fundamentais de Programação em C 4.1. Imprimindo Mensagens e Valores no Monitor de Vídeo A biblioteca de entrada e saída (stdio.h) possui a função printf que imprime mensagens e valores diretamente
Revisão da Linguagem C Prof. Evandro L. L. Rodrigues
SEL0433 Aplicação de Microprocessadores I Revisão da Linguagem C Prof. Evandro L. L. Rodrigues Estrutura de um programa C Diretivas de pré processamento Declaração de variáveis globais Declaração de protótipos
PROGRAMAÇÃO I E N T R A DA E S A Í DA D E DA D O S
PROGRAMAÇÃO I VA R I Á V E I S, C O N S TA N T E S, O P E R A D O R E S E N T R A DA E S A Í DA D E DA D O S Variáveis 2 Variáveis são locais onde são armazenados os valores na memória. Toda variável é
ALGORITMOS AULA 01. Baseado nas aulas do Prof. Jorgiano Vidal
ALGORITMOS AULA 01 Baseado nas aulas do Prof. Jorgiano Vidal LINGUAGEM C Uma das grandes vantagens do C é que ele possui tanto caracterìsticas de "alto nìvel" quanto de "baixo nìvel". Linguagem de propósito
Algoritmos e Estruturas de Dados I IEC012. Linguagem C - Guia de bolso - Prof. César Melo
Algoritmos e Estruturas de Dados I IEC012 Linguagem C - Guia de bolso - Prof. César Melo Histórico A linguagem C é uma linguagem de programação inventada na década de 1970 por Dennis Ritchie Brian Kennigaham.
Linguagens de Programação. Introdução. Carlos Bazilio
Linguagens de Programação Introdução Carlos Bazilio [email protected] http://www.ic.uff.br/~bazilio/cursos/lp ??? Pascal aux := 0 for i:=1 to 10 do aux := aux + i 10: i = 1 20: if i > 10 goto 60
Algoritmo e Técnica de Programação - Linguagem C
Algoritmo e Técnica de Programação Linguagem C Gilbran Silva de Andrade 5 de junho de 2008 Introdução A liguagem C foi inventada e implementada por Dennis Ritchie em um DEC PDP-11 que utilizava o sistema
Introdução à linguagem C
MCTA028 Programação Estruturada Introdução à linguagem C Material preparado a partir de slides dos profs. Jesús MenaChalco e Fabrício Olivetti Prof. Guilherme Mota Q3-2018 1 Linguagens de programação 2
4 Variáveis. Unesp Campus de Guaratinguetá
4 Variáveis Unesp Campus de Guaratinguetá Curso de Programação Computadores Prof. Aníbal Tavares Profa. Cassilda Ribeiro Ministrado por: Prof. André Amarante Composição do Hardware MEMÓRIA UNIDADES FUNCIONAIS
Hello World. Linguagem C. Tipos de Dados. Palavras Reservadas. Operadores Aritméticos. Pré e pós incremento e pré e pós decremento
Hello World Linguagem C printf("hello world!\n"); main é a função principal, a execução do programa começa por ela printf é uma função usada para enviar dados para o vídeo Palavras Reservadas auto double
Linguagem C. Eliane Pozzebon
Linguagem C Eliane Pozzebon Material de Apoio de C Site da disciplina: http://www.univasf.edu.br/~eliane.pozzebon Slides de aulas Exercícios Dev-C++: um ambiente de programação interativo e gratuito para
Linguagem C. Brian W. Kernighan, Dennis Ritchie (K&R) Slides adaptados, inspirados, muitos copiados dos slides do professor Pedro Pereira
Linguagem C Brian W. Kernighan, Dennis Ritchie (K&R) Slides adaptados, inspirados, muitos copiados dos slides do professor Pedro Pereira Centro de Cálculo Instituto Superior de Engenharia de Lisboa João
Capítulo 1. Aspectos Preliminares
Capítulo 1 Aspectos Preliminares Tópicos do Capítulo 1 Razões para estudar conceitos de linguagens de programação Domínios de programação Critérios de avaliação de linguagens Influências no projeto de
DELEGAÇÃO REGIONAL DO ALENTEJO CENTRO DE FORMAÇÃO PROFISSIONAL DE ÉVORA REFLEXÃO 5
REFLEXÃO 5 Módulos 0782, 0783, 0784 e 0785 1/5 23-05-2013 Esta reflexão tem como objectivo partilhar e dar a conhecer o que aprendi nos módulos 0782 Programação em C/C++ - Estrutura Básica e Conceitos
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
Estrutura de Programas e Tipos de Dados Simples
SSC0101 - ICC1 Teórica Introdução à Ciência da Computação I Estrutura de Programas e Tipos de Dados Simples Prof. Vanderlei Bonato: [email protected] Prof. Claudio Fabiano Motta Toledo: [email protected]
LINGUAGEM C PARA O 8051
LINGUAGEM C PARA O 8051 Disciplina de Microcontroladores Prof. Ronnier e Rubão VARIÁVEIS E TIPOS DE DADOS SIMPLES Char 8 bits Short e int 16 bits Long 32 bits Float 32 bits Unsigned int 16 bits Unsigned
Conteúdo programático
Introdução à Linguagem C Conteúdo programático Introdução à Linguagem C Estrutura de Programas Variáveis, Constantes Operadores, Entrada e Saída de Dados Estruturas de Desvio Estrutura de Múltipla Escolha
