SlideShare uma empresa Scribd logo
Linguagens
de
Programação
Professor:

Vítor Souza

Grupo:

Gustavo Tavares
Linicker Harison
Rodrigo Barcellos
Seminário
Histórico e Paradigma
•
•
•
•
•
•
•

Criad apelo Google
Lançada em novembro de 2007
Código livre em 2009
Primeira versão estável em 2012 (Go1)
Linguagem compilada (não usa VM ou interpretador)
Foco na eficiência, legibilidade e concorrência
Possui coletor de lixo
Por que foi criada?
•

Criada parare solver problemas do Google com:

•
•
•
•
•
•

C++, Python e Java
Muitas linhas de código
Sistema distribuído
Uma única árvore (um makefile na raiz para compilar tudo)
Númeroe norme de máquinas (concorrência)

•

O desenvolvimento no Google pode ser lento, mas é eficiente!

•

Objetivos:

•
•
•

Ter eficiência em seus softwares
Ter um código simples de construir
Poder fazer softwares confiáveis
Tipos de dados
•

Go é fortemente tipada
Tipos de dados
Primitivos
Tipos de dados
Compostos
Structs

•
•
•

A struct é uma coleção de campos.
Uma declaração type define um novo tipo de dado.
Os campos de uma struct é acessado através de um ponto.
Tipos de dados
Compostos
Ponteiros

•

Go tem ponteiros, mas não há aritmética de ponteiros.

●

Campos struct podem ser acessados através de um ponteiro struct.
Tipos de dados
Slices (arrays)

•
•
•

Compostos

Um slice aponta para uma matriz de valores e também inclui um comprimento.
[]Té um slice com elementos do tipo T.
Slices podem ser fatiados gerando novos slices que apontam para a mesma matriz
Tipos de dados
Maps (dicionários)

Compostos

●

Inserir ou atualizar um elemento no map:

•

Recuperar um elemento:

•

Excluir um elemento:

•

Testar que uma chave está presente com dois valores:
Definição de variáveis
•
•

A instrução var declara uma lista de variáveis
O tipo deve ser passado.
Definição de variáveis
•

A declaração var pode incluir inicializadores, um por variável. Se um inicializador está presente, o tipo pode
ser omitido; a variável terá o tipo do inicializador.
Definição de variáveis
•

Dentro de uma função a instrução de atribuição curta := pode ser utilizada em lugar de uma declaração var
com o tipo implícito.

•

Fora de uma função cada estrutura começa com uma palavra-chave e não é possível usar o :=
Declaração de Constantes
•
•

Constantes são declaradas como variáveis, mas com a palavra-chave const.
Constantes podem serseqüências de caracteres, booleanos, ou valores numéricos.
Declaração de Constantes
Constantes Numéricas

•
•

As constantes numéricas são valores de alta precisão.
Uma constante sem tipo tem o tipo necessário para o seu contexto.
Keywords
Operadores
Pacotes
●

Cada programa Go é composto de pacotes.

•

Programas começam rodando pelo pacote main.
Gerenciamento de memória
•
•

Utiliza coletor de lixo
Mecanismo de Parallel Mark and Sweep
Expressões e Comandos
Comandos Condicionais
If

•

O if básico parece com o que o de C ou Java fazem, exceto que as ( ) se foram (não são nem mesmo opcionais) e os {
} são obrigatórios.
Expressões e Comandos
Comandos Condicionais
If

•
•

A instrução if pode começar com uma breve declaração antes de executar a condição.
Variáveis ​declaradas pela instrução são válidas somente no escopo até o final do if.
Expressões e Comandos
Comandos Iterativos
For

•
•

Go tem apenas uma estrutura de laço, o for.
O for básico parece com o que o de C ou Java fazem, exceto que as ( ) se foram (não são nem mesmo opcionais) e
os { } são obrigatórios.

•

O while do C é escrito com for em Go.
Expressões e Comandos
Comandos Iterativos
For

•

O range do laço for itera sobre uma slice ou map.

•

Pode-se ignorar o índice ou o valor atribuindo _.
Modularização
Funções
●

•
•

A função pode ter zero ou mais argumentos.
O tipo vem após o nome da variável (facilita a leitura).
Quando dois ou mais consecutivos parâmetros da função nomeados compartilhar um tipo,pode-se omitir o
tipo de todos, menos o último.
Modularização
Funções

•

Uma função pode retornar qualquer número de resultados

•

O resultados retornados podem ser nomeados
Modularização
Funções

•

Funções também são valores.
Modularização
Funções
●

Funções também tem closures completos.
Go Não Possui Classes
•

Go não possui classes ou objetos. Para fazer programas orientados a objetos deve-se utilizar de artifícios
disponibilizado pela linguagem, como:
●

Estruturas, como classes

●

Interfaces, para herança.
Métodos
•
•

Go não tem classes. No entanto, pode-se definir métodos em com tipo struct.
O método receptor aparece em sua lista de argumentos entre a própria palavra-chave func e o nome do
método.
Métodos
•
•

Pode-se definir métodos em qualquer tipo definido dentro do package, não apenas em structs.
Não se pode definir um método em um tipo de outro pacote, ou em um tipo básico.
Métodos
Ponteiro receptor
•
•
•

Métodos podem ser associados a um tipo nomeado ou um ponteiro para um tipo nomeado
Evita copiar o valor em cada chamada de método
O método passa a modificar o valor que seu receptor aponta
Interfaces
•
•

Um tipo de interface é definida por um conjunto de métodos.
Um valor de tipo de interface pode conter qualquer valor que implementa esses métodos.
Interfaces
Polimorfismo
Coerção

•
•
•

Não possui polimorfismo de coerção.
Conversões de tipo devem ser explicitadas pelo programador.
Exceção para constantes, que caso não tenham tipo explicitamente definido, é tipada baseada no contexto
que é utilizada.
Polimorfismo
Sobrecarga

•
•

Possui sobrecarga em seus operadores.
Não possui sobrecarga de funções.
Polimorfismo
Paramétrico

•
•

Não possui polimorfismo paramétrico.
Solução: utilizar uma interface que aceite todos os tipo desejados.
Polimorfismo
Inclusão

•
•

Não possui polimorfismo de inclusão.
Todo o tipo que implementa um conjunto de métodos definidos em uma interface, satisfaz esta interface.
Polimorfismo
Inclusão
Sequenciadores
•
•
•

Desvios incondicionais
Escapes
Exceções
Desvios Incondicionais

•
•

Para fazer desvios incondicionais em go usa-se a palavra reservada goto.
Não se pode fazer desvios incondicionais para pontos externos do programa, somente dentro do mesmo
escopo.
Escape

•
•

Go utiliza a palavras reservadas break e continue como formas de escape.
Escape não rotulado apenas finaliza a iteração corrente.
Escape
Rotulado

•

Para fazer um escape rotulado utiliza-se a palavra break mais o rótulo.
Tratamento de exceções
•
•

Não utiliza blocos try/catch.
As funções podem possuir múltiplos retornos,assim, quando necessário, deve-se incluir um retorno do tipo
error.

•

O programador é responsável por tratar o retorno e verificar se a variável de erro foi preenchida.
Tratamento de exceções
Persistência de Memória

•

Variáveis persistentes em go são do tipo FILE
Concorrência
•
•
•

Goroutines
Canais
Select
●

Selection Default
Goroutines
•
•
•

Uma goroutine é um segmento leve e gerenciado pelo runtime de Go.
go f(x, y, z) // Inicia uma nova execução goroutine
f(x, y, z) // A avaliação de f, x, y, e z acontece na goroutine corrente e para a execução de f acontece em uma
goroutine nova.

•

Goroutines executam no mesmo espaço de endereço, para que o acesso à memória compartilhada seja
sincronizada.
Goroutines
Canais
•

Canais são um conduto tipado através do qual você pode enviar e receber valores com o operador de canal,
<-.

•
•
•
•
•

ch<- v // v envia para o canal ch.
v:= <-ch // Recebe do ch, e atribui o valor de v (os dados fluem na direção da seta).
Como maps e slices, os canais devem ser criados antes de se usar:
ch:=make(chanint)
Por padrão, enviam e recebem bloco até o outro lado estar pronto. Isso permite que goroutines sincronizem
sem bloqueios explícitos ou variáveis ​de condição.
Canais
Canais
Bufferizados
•

Os canais podem ser bufferizados. Fornecendo o tamanho do buffer como o segundo argumento
para make para inicializar um canal bufferizado:

•
•

ch:=make(chanint, 100)
Envia para um bloco de canais bufferizados apenas quando o buffer está cheio. Recebe bloco quando o buffer
está vazio.
Canais
Bufferizados
Canais
Range e Close
●

Um remetente pode dar close em um canal para indicar que os valores não serão mais enviados. Receptores
podem testar se um canal foi fechado através da atribuição de um segundo parâmetro para a expressão de
recepção: depois

•
•
•
•

v, ok := <-ch
ok é false se não há mais valores a receber e o canal está fechado.
O laço for i := range c recebe valores do canal repetidamente até que seja fechado.
Nota: Apenas o remetente deve fechar um canal, nunca o receptor. O envio em um canal fechado irá causar
um pânico.

•

Outra nota: Canais não são como arquivos, você geralmente não precisa fechá-los. O encerramento só é
necessário quando o receptor precisa saber que não há mais valores chegando, como para terminar um
laço range.
Canais
Range e Close
Select
●

A instrução select permite uma espera na goroutine sobre as operações de comunicação múltiplas.

•

O bloco select aguarda até que um de seus cases possam executar, então ele executa esse case. Ele escolhe
um ao acaso se vários estiverem prontos.
Select
Select
Selection Default
●

•
•

O case default em um select é executado se nenhum outro caso está pronto.
Utilize um case default para tentar um enviar ou receber sem bloqueio:
Exemplo:
select{
casei := <-c:
// usei
default: // recebendo c bloquearia
}
Select
Selection Default
Curiosidades
●

•
•

cgo, Go importando o C todo pra ele
Playgound Go, uma forma de testar/criar programas simples á complexos direto do site da GO
No site da GO existe um passo-a-passo que ensina por meio de texto mais o Playground Go todos os conceitos
da linguagem (em português inclusive)

•

Possui várias IDEs (ou plugins para IDEs) como por exemplo: Eclipse, NetBeans, LiteIDE, Zeus, etc
Conclusão
•
•
•

Go é uma linguagem completa porém brilha quando o assunto é concorrência.
Prioriza eficiência e legibilidade
Sacrifica principalmente a confiabilidade
Fontes
•

http://golang.org/

•

http://www.infoq.com/presentations/Go-Google

Mais conteúdo relacionado

PDF
TechEd Brasil 2011: WEB 302 - Presente e futuro da linguagem de programação J...
PDF
TechEd Brasil 2011: DEV 303 - Atualizando suas habilidades de programação com...
PDF
Notas deaulas
PPTX
Trabalho de Paradigmas Da Linguagem De Programação - Python
PDF
Apresentação python fábio jr alves
DOCX
Trabalho linguagem python
PPTX
C#4 - Parte 1 - Dinamismo E Argumentos opcionais e nomeados
TechEd Brasil 2011: WEB 302 - Presente e futuro da linguagem de programação J...
TechEd Brasil 2011: DEV 303 - Atualizando suas habilidades de programação com...
Notas deaulas
Trabalho de Paradigmas Da Linguagem De Programação - Python
Apresentação python fábio jr alves
Trabalho linguagem python
C#4 - Parte 1 - Dinamismo E Argumentos opcionais e nomeados

Mais procurados (20)

PDF
Introdução à linguagem Python
PDF
Linguagem C (UFRPE)
PPTX
TDD na Prática
PDF
Introdução ao paradigma imperativo
DOCX
Compiladores
PPTX
Geração de código linguagem c
PPTX
Programação aula001
PDF
Python - Introdução
PPT
Gerador de Código-Objeto - Compiladores
PDF
Paradigmas de Programação - Imperativo, Orientado a Objetos e Funcional
PPT
Introdução ao Java 5
PPTX
Palestra: LINQ via C#
PDF
Apostila de Introdução ao C#.net
PPTX
2016/01/27 - Aprendendo a programar com Python
PDF
Python - Guia de bolso
PDF
Curso básico de Algoritmos com Python
PPTX
TDC2014 SP - C/C++ - Modularização de Código C
PDF
Pi1415 tudo
PPT
Sincronização - Glêdson Elias
PPT
Principios e paradigmas_de_computacao2
Introdução à linguagem Python
Linguagem C (UFRPE)
TDD na Prática
Introdução ao paradigma imperativo
Compiladores
Geração de código linguagem c
Programação aula001
Python - Introdução
Gerador de Código-Objeto - Compiladores
Paradigmas de Programação - Imperativo, Orientado a Objetos e Funcional
Introdução ao Java 5
Palestra: LINQ via C#
Apostila de Introdução ao C#.net
2016/01/27 - Aprendendo a programar com Python
Python - Guia de bolso
Curso básico de Algoritmos com Python
TDC2014 SP - C/C++ - Modularização de Código C
Pi1415 tudo
Sincronização - Glêdson Elias
Principios e paradigmas_de_computacao2
Anúncio

Semelhante a Seminário sobre GO (20)

PPTX
Clean code em C#
PDF
Introdução à Linguagem de Programação GO
PDF
PDF
Codigo limpo
PPT
Python tdc2019
PPTX
Curso Java Básico - Aula 01
PDF
UFCG.JCert Reunião 1 - Declarações e Controle de Acesso
PPT
Java cert programmer
PPTX
PDF
Aula01 introducao operacoes
PPTX
PDF
Clean code part 2
PDF
Introdução a lógica de Programação Aula-01
PPTX
Introdução_a_linguagem C _pare1_(1).pptx
PDF
Curso de Groovy
PDF
01-Paradigmas.pdf
ODP
Produtividade com Eclipse IDE
PDF
Programação de Macros com LibreOffice Basic
PDF
Programacao de macros_com_libre_office_basic_slideshare
PDF
Programação de Macros com LibreOffice Basic
Clean code em C#
Introdução à Linguagem de Programação GO
Codigo limpo
Python tdc2019
Curso Java Básico - Aula 01
UFCG.JCert Reunião 1 - Declarações e Controle de Acesso
Java cert programmer
Aula01 introducao operacoes
Clean code part 2
Introdução a lógica de Programação Aula-01
Introdução_a_linguagem C _pare1_(1).pptx
Curso de Groovy
01-Paradigmas.pdf
Produtividade com Eclipse IDE
Programação de Macros com LibreOffice Basic
Programacao de macros_com_libre_office_basic_slideshare
Programação de Macros com LibreOffice Basic
Anúncio

Último (20)

PPTX
INTRODUÇÃO AO ESTUDO DA ANATOMIA HUMANA [Salvo automaticamente].pptx
PDF
Extintores e Acessórios por Francisco Borges.pdf
PDF
Historia-da-Psicologia-Rumos-e-percursos.pdf
PPTX
Slides Lição 8, Betel, Jesus e a Mulher Adúltera, 3Tr25.pptx
PPTX
1. A Cultura do Palco - muitos palcos, um espetáculo.pptx
PPTX
Programa Nacional de Saúde do Adulto.pptx
PDF
Uma Introdução às Ciências do Alcorão (Islam)
PDF
Pecados desdenhados por muita gente (islamismo)
PDF
[Slides] A Literatura no ENEM 2017 (1).pdf
PPTX
2. A Cultura do Salão - o fim das trevas.pptx
PDF
edital-de-chamamento-publico-no-3-2025.pdf
PDF
EXPRESSÕES IDIOMÁTICAS - LÍNGUA PORTUGUESA
PPSX
A epistemologia de Wilheim G Leibniz.ppsx
DOCX
Apresentação Lapbook.doc para trabalhos.
DOC
PPP 2024 (2) (2) feito EM REELABORAÇÃO MORENA ( ABRIL 2024).doc
PDF
HORÁRIO GERAL SIGAA 2025_PRÉVIA_SIGAA-1.pdf
PDF
Historia da Gastronomia Mundial por Daianna Marques dos Santos
PPTX
5. A cultura do mundo virtual - globalidade.pptx
PPTX
"BPF, PPHO e APPCC na Indústria de Alimentos"
PPT
br-a-1692841480-passeio-pela-historia-da-arte-apresentacao-em-powerpoint_ver_...
INTRODUÇÃO AO ESTUDO DA ANATOMIA HUMANA [Salvo automaticamente].pptx
Extintores e Acessórios por Francisco Borges.pdf
Historia-da-Psicologia-Rumos-e-percursos.pdf
Slides Lição 8, Betel, Jesus e a Mulher Adúltera, 3Tr25.pptx
1. A Cultura do Palco - muitos palcos, um espetáculo.pptx
Programa Nacional de Saúde do Adulto.pptx
Uma Introdução às Ciências do Alcorão (Islam)
Pecados desdenhados por muita gente (islamismo)
[Slides] A Literatura no ENEM 2017 (1).pdf
2. A Cultura do Salão - o fim das trevas.pptx
edital-de-chamamento-publico-no-3-2025.pdf
EXPRESSÕES IDIOMÁTICAS - LÍNGUA PORTUGUESA
A epistemologia de Wilheim G Leibniz.ppsx
Apresentação Lapbook.doc para trabalhos.
PPP 2024 (2) (2) feito EM REELABORAÇÃO MORENA ( ABRIL 2024).doc
HORÁRIO GERAL SIGAA 2025_PRÉVIA_SIGAA-1.pdf
Historia da Gastronomia Mundial por Daianna Marques dos Santos
5. A cultura do mundo virtual - globalidade.pptx
"BPF, PPHO e APPCC na Indústria de Alimentos"
br-a-1692841480-passeio-pela-historia-da-arte-apresentacao-em-powerpoint_ver_...

Seminário sobre GO