Skip to content

crgimenes/grupo-estudos-golang

Repository files navigation

Grupo de Estudos de Golang Licença Creative Commons

Exemplos antigos

Os exemplos estão sendo reescritos, muita coisa antiga precisa ser ajustada e melhorada. Os exemplos antigos estão no diretório "nao_tratados".


Sobre o Grupo de Estudos de Go

Ementa do Curso de Programação em Go

Módulo: Introdução ao Go

Bem-vindo ao Go

Fundamentos da Linguagem

Funções

Estruturas de Dados

Módulo: Intermediário

Programação Orientada a Objetos em Go

Manipulação de Erros

Concorrência em Go

Input e Output

Módulo: Avançado

Rede e Web

Banco de Dados

Testes em Go

Ferramentas e Boas Práticas

Módulo: Projetos Práticos

Projeto Aplicação CLI

Projeto API RESTful

Projeto Web Application

Projeto Integrações com APIs

Módulo: Tópicos Especiais

Desenvolvimento para Microserviços

Integração Contínua e Deploy Contínuo (CI/CD)

Segurança em Aplicações Go

Performance e Escalabilidade

Recursos Adicionais


Um pouco de história

Por volta de 2015 eu estava procurando uma linguagem de programação moderna que atendesse a alguns critérios que considero importantes, deveria ser simples, compilada, abrangente e com uma boa comunidade. Com capacidade para criar executáveis multiplataforma e que aproveitasse as características de multi-processamento das máquinas modernas.

Go caiu como uma luva e comecei a usar nos meus projetos. No início de 2016 no ABC Makerspace criei um pequeno curso, o Go-Hands-On e de lá iniciamos o que acabaria se tornando o grupo de estudos.

Desde aquela época os objetivos do grupo continuam praticamente os mesmos, estudar a linguagem de programação Go e tecnologias relacionadas, dar apoio para quem está iniciando assim como manter atualizados os programadores mais experientes, criar conteúdo em português falado no Brasil.

No dia 11 de maio de 2016 criei o repositório do Grupo de Estudos de Golang no GitHub, essa se tornou nossa data de início oficial. De lá para cá fizemos centenas de encontros, praticamente toda semana, escrevemos muitos exemplos, gravamos muitos vídeos, mas o mais importante é que conhecemos muita gente boa disposta a ajudar e compartilhar o que sabe.

Esse material doi criado com ajuda de inumeras pessoas, sinta-se a vontade para usar, compartilhar e melhorar.

CRG


Bem-vindo ao Go

História e filosofia do Go

Go, foi criado no Google em 2007 por Robert Griesemer, Rob Pike e Ken Thompson.

A primeira versão estável, Go 1.0, foi lançada em março de 2012.

O objetivo do Go é ser uma linguagem simples, eficiente e com uma curva de aprendizado suave, mantendo um equilíbrio entre desempenho e facilidade de uso.

Go foi projetado para resolver problemas encontrados em linguagens tradicionais como C++ e Java, oferecendo concisão, simplicidade e segurança na concorrência.

Os mantenedores da linguagem Go se comprometem a manter a retrocompatibilidade com a versão 1.0, garantindo que programas escritos para versões anteriores continuem funcionando sem alterações. Esse compromisso é uma das razões pelas quais Go é uma linguagem popular para desenvolvimento de sistemas de larga escala.

Outro ponto importante para lembrar é que a retrocompatibilidade não é binária, ou seja, não é garantido que um programa escrito em Go 1.0 gere o mesmo binário em versões futuras. O que é garantido é que o código fonte continuará compilando. Um exemplo onde retrocompatibilidade do binário é importante é se você precisar suportar versões antigas de sistemas operacionais ou hardware, seu programa continua compilando sem erros mas não funciona na plataforma antiga.

Instalação e configuração do ambiente

A instalação do Go é bastatnte simples, o caminho mais direto é baixar o instalador para a sua plataforma e executá-lo, ou se preferir baixar os binarios.

Em ambienes UNIX/Linux geralmente é comum instalar o Go em /usr/local/go ou $HOME/go, e em ambientes Windows em C:\Go.

Apos a instalação é necessário configurar a variável PATH para que o sistema operacional possa encontrar o compilador.

Versõs antigas do Go exigiam que outras variaveis fossem condiguradas, hoje essas configurações são opcionais.

Lembre! Caso esteja usando algum anti-virus, é necessário adicionar o diretório de instalação do Go e seu diretório de projetos na lista de exceções. É comum que o anti-virus bloqueie a execução de programas compilados com Go e as vezes de forma silenciosa.

Download

Faça o download do instalador correspondente ao seu sistema operacional ou dos binarios em https://go.dev/dl/.

Microsoft Windows

Apos executar o instalador, Go estará instalada em

C:\Go

Anti-virus

Caso esteja usando algum anti-virus, é necessário fazer ajustes para que o compilador não seja bloqueado, é comum que o anti-virus bloqueie a execução de programas compilados com Go e as vezes de forma silenciosa.

Ajuste do PATH

Existem várias formas de configurar a variável PATH no Windows, uma das formas mais simples é usar o Painel de Controle. Você precisa que o diretório C:\Go\bin seja adicionado ao PATH.

No Windows 11, você pode usand a tecla de atalho Win + R e digitar sysdm.cpl e clicar em OK. Na janela que abrir, clique na aba Avançado e depois no botão Variáveis de Ambiente. Na janela que abrir, clique duas vezes na variável Path e adicione o diretório C:\Go\bin no final da lista.

Mac OS X

Apos executar o instaldor, Go estará instalada em:

/usr/local/go

Mac OS X - Alternativa - Usando Homebrew

Preferencialmente use o instalador oficial.

Ajuste do PATH

Adicione o diretório bin do Go ao PATH. Abra o arquivo ~/.bash_profile ou ~/.zshrc e adicione a seguinte linha:

export PATH=$PATH:/usr/local/go/bin

Mac OS X - Alternativa - Usando Homebrew

Se você usa o Homebrew, o Go pode ser instalado com dois simples comandos:

brew update
brew install go

No caso da instalação via Homebrew, o PATH é configurado automaticamente.

Linux

Você pode descompactar o arquivo tar.gz em /usr/local ou $HOME e configurar a variável PATH.

tar -C /usr/local -xzf go1.22.0.linux-amd64.tar.gz

Ajuste do PATH

Adicione o diretório bin do Go ao PATH. Abra o arquivo ~/.bashrc ou ~/.zshrc e adicione a seguinte linha:

export PATH=$PATH:/usr/local/go/bin

Uma dica importante, quando você quiser atualizar o Go é bom remover a versão antiga antes de instalar a nova, os instaladores para Mac e Windows fazem isso automaticamente, mas no Linux é necessário fazer manualmente.

Como super usuário, execute o comando:

rm -rf /usr/local/go && tar -C /usr/local -xzf go1.22.0.linux-amd64.tar.gz

Isso ira remover a versão antiga e instalar a nova.

Verificando a instalação

Para verificar se a instalação foi bem sucedida, abra um terminal e execute o comando:

go version

Você deve ver algo como:

go version go1.22.0 linux/amd64

Primeiro programa em Go: "Hello, World!"

"Hello, World!" é um clássico primeiro programa, é extremamente simples, mas é ótimo para comprovar que o ambiente de desenvolvimento está funcionando corretamente.

Em Go o programa inicia na função main e o pacote principal é main.

package main

func main() {
    println("Hello, World!")
}

A primeira linha do programa é o pacote, em Go os programas são organizados em pacotes, o pacote principal é main, e o nome do pacote deve ser o mesmo que o nome do diretório.

A segunda linha é a função main, ela é a função chamada quando o programa é executado.

E finalmente, terceira linha é a chamada para a função println, que imprime a mensagem "Hello, World!" no terminal.

Para executar o programa, salve o código em um arquivo chamado hello.go e execute o comando:

go run hello.go

Você deve ver a mensagem "Hello, World!" impressa no terminal.

Go não tem versão interpretada, mesmo esse teste usando go run é compilado antes de ser executado, o executável é temporário e é removido após a execução.


Fundamentos da Linguagem

Go é conhecida por sua simplicidade e eficiência.

Alguns de seus fundamentos incluem:

  • Concorrência: Utiliza goroutines e channels para facilitar a programação concorrente de forma simples e segura.
  • Tipagem Estática e Compilada: Oferece verificação de tipos em tempo de compilação, garantindo maior performance e segurança.
  • Sintaxe Simples: Facilita a leitura e manutenção do código, promovendo a produtividade dos desenvolvedores.
  • Gerenciamento de Memória: Implementa garbage collection automático, reduzindo a complexidade no gerenciamento de memória.
  • Ferramentas Integradas: Inclui ferramentas como go fmt para formatação de código e go build para compilação, agilizando o desenvolvimento.
  • Modularidade: Suporta módulos e pacotes, permitindo a organização eficiente de projetos grandes.
  • Desempenho: Compilado para código nativo, oferece alta performance semelhante a linguagens como C.
  • Retrocompatibilidade: Go mantém a compatibilidade com versões anteriores, garantindo que programas escritos para Go 1.0 continuem funcionando sem alterações, isso traz muita confiabilidade para os desenvolvedores.

Esses fundamentos fazem do Go uma escolha popular.

Sintaxe básica

Tipos de dados primitivos

Variáveis e constantes

Estruturas de controle (if, else, switch)

Funções

Declaração e chamada de funções

Parâmetros e retorno de funções

Funções anônimas e closures

Estruturas de Dados

Arrays e slices

Mapas

Structs

Módulo: Intermediário

Programação Orientada a Objetos em Go

Structs e métodos

Interfaces

Manipulação de Erros

Tratamento de erros

Padrões de erro

Customização de erros

Concorrência em Go

Goroutines

Canais (channels)

Select e sincronização

Input e Output

Leitura e escrita de arquivos

Manipulação de JSON e XML

Uso de pacotes padrão para I/O

Módulo Avançado

Rede e Web

Desenvolvimento de servidores HTTP

Construção de APIs RESTful

Manipulação de sockets e comunicação em rede

Banco de Dados

Conexão e manipulação de bancos de dados SQL

Transações e migrações

Testes em Go

Testes unitários

Benchmarking

Profiling

Ferramentas e Boas Práticas

Uso do Go Modules

Linters e formatação de código

Módulo Projetos Práticos

Projeto Aplicação CLI

Desenvolvimento de uma aplicação de linha de comando

Parsing de argumentos e flags

Automação de tarefas

Projeto Web Application

Construção de uma aplicação web completa

Templates HTML e manipulação de formulários

Autenticação e autorização

Projeto API RESTful

Integrações com APIs

Criação e configuração de um bot do Telegram

Uso da API do ChatGPT

Módulo Tópicos Especiais

Desenvolvimento para Microserviços

Arquitetura de microserviços

Comunicação entre serviços

Deploy e escalabilidade

Integração Contínua e Deploy Contínuo (CI/CD)

Ferramentas de CI/CD

Automação de builds e testes

Deploy automático

Segurança em Aplicações Go

Práticas de segurança

Proteção contra vulnerabilidades comuns

Uso de pacotes seguros

Performance e Escalabilidade

Otimização de código

Estratégias de escalabilidade

Recursos Adicionais

Perguntas frequentes

Qual framework, ORM, banco de dados, etc. usar?

  • Go é uma linguagem de programação minimalista, não possui um framework padrão como Django, Rails ou Laravel. Antes de procurar algo externos tente usar as bibliotecas padrão, elas são muito boas e completas.

  • ORM é um conceito que não é muito usado em Go, idealmente você deve usar um banco de dados que tenha um driver nativo para Go, como PostgreSQL, MySQL, SQLite, etc. e escrever seus proprios SQLs.

  • Frameworks web são muitos, alguns populares são o Gin, Echo, Fiber, Beego, etc. mas você pode usar o pacote net/http da biblioteca padrão, ele provavelmente vai resolver seu problema sem adicionar complexidade ou dependências.

O que é migration?

  • Migration é uma ferramenta que permite que você controle as mudanças no banco de dados, geralmente é usado para criar tabelas, adicionar colunas, etc. Existem muitas ferramentas de migration, você pode usar uma delas ou escrever suas proprias migrations.

Qual paradigma/padrão de projeto usar em Go.

  • Go esta mais para programação estruturada/procedural. Go não possui um padrão de projeto como MVC, MVVM, etc. Você pode usar o que achar melhor. Orientação a objetos é possivel em Go, mas não é muito comum.

Porque o tratamento de erro é tão verborragico?

  • Go não possui exceções, o tratamento de erro é feito com o retorno de um erro, isso é uma escolha de design da linguagem. O tratamento de erro é explicito e isso é uma das coisas que torna Go uma linguagem simples e fácil de entender. Os erros são tratados imediatamente onde eles acontecem tornando o debug mais fácil. Uma dica importante é sempre tratar todos os erros, muitas vezes um erro que parece impossível de acontecer, acontece.

Leituras recomendadas

Exercícios práticos e desafios

Como contribuir

Primeiros passos

De uma olhada nas issues e veja se o que você quer fazer já não esta sendo discutido, se estiver ótimo, participe da discussão e de suas ideias caso não esteja você pode criar uma nova issue para discutirmos ou se preferir pode também mandar diretamente um pull request, só não esqueça de descrever muito bem o que você quer mudar/adicionar.

Formato

Material novo idealmente deve ser organizados em diretórios e ter três arquivos, um README.md descrevendo como executar o exemplo, um exemplo.go contendo o exemplo propriamente dito e um exemplo_test.go. (alternativamente você pode usar main.go e main_test.go). Também é necessário fazer uma descrição do exemplo no arquivo README.md do diretório principal.

exemplo/README.md
exemplo/exemplo.go
exemplo/exemplo_test.go

Cuidado com o código

Antes de mandar um pull request formate seu código com go fmt. Também é uma boa ideia passar uma ferramenta de analize estatica como golint por exemplo.

Não se prolongue demais

Uma das características que é importante manter são exemplos curtos e de fácil entendimento, tenta fazer com que os exemplos caibam em uma tela, tudo bem se não for possível, apenas mantenha isso em mente.

Exemplos rápidos, curtos, diretos e de fácil entendimento são nossa meta.

Inclua seus exemplos no The Go Playground

Inclua um link sob os exemplos que você escrever apontando para o https://play.golang.org, dessa fora o leitor pode testar seu exemplo imediatamente. Obviamente isso não é possivel com qualquer exemplo, mas onde for possivel é bom colocar.

Arquivo README.md

Discuta com os outros desenvolvedores o melhor lugar para colocar o seu tutorial na lista do arquivo README.md, a ideia é que os tutoriais estejam em ordem complexidade.

Enviando uma contribuição

  • Faça um fork do projeto.
  • Crie uma branch com as suas modificações git checkout -b exemplo-fantastico.
  • Faça commit das suas alterações git commit -m 'Implementação do novo exemplo fantástico'.
  • Faça um push na sua branch git push origin exemplo-fantastico.
  • Faça um pull request com suas alterações.

Como fazer boas perguntas e dar boas respostas

Algumas dicas para melhorar a interação com o grupo quando for enviar perguntas ou respostas.

Especifique o Problema:

  • Deixe claro qual é o problema que você está enfrentando. Uma descrição precisa auxiliará os outros a entenderem e oferecerem soluções.

Demonstração do Código:

  • Forneça um trecho de código, e inclua a saída esperada e atual. Isso dará aos outros uma ideia melhor do que está acontecendo.

  • Você pode usar o The Go Playground para compartilhar exemplos de código. ou então use o markdown para formatar o código. Geralmente basta colocar o código entre três crases.

Ambiente de Desenvolvimento:

  • Mencione a versão do Go que você está usando e outras configurações de ambiente que possam ser relevantes para o problema, como o sistema operacional, por exemplo.

Formato é importante:

  • Formate sua pergunta de maneira clara e legível, com uso adequado de marcações, para facilitar a leitura por outros membros do grupo.

Revise o Texto:

  • Antes de perguntar utilize as ferramentas de busca. Mesmo que não encontre a resposta, isso ajudará a formular sua dúvida de maneira mais clara.

  • Consulte nosso FAQ e o código de conduta.

  • Ao formular uma pergunta, inclua as etapas que já tentou para resolver o problema.

  • Mantenha a pergunta concisa; perguntas mais curtas tendem a ser respondidas mais rapidamente.

  • É útil demonstrar o problema com um trecho de código. Evite enviar imagens da tela; em vez disso, crie um pequeno exemplo que ilustre a dúvida ou problema em poucas linhas.

  • Se desejar, use o The Go Playground. No entanto, esteja ciente de que o playground grava os exemplos compartilhados, então evite colocar dados ou códigos sensíveis.

  • Se ninguém responder sua pergunta, não se preocupe. Pode ser que ninguém tenha a resposta no momento. Não leve para o lado pessoal.

  • Respeite a opinião dos outros. Nós programadores temos fortes opiniões sobre o que é melhor e adoramos discutir o melhor de tudo: melhor procedimento, melhor editor, melhor sistema operacional, etc. Seja objetivo e não prolongue discussões.

  • Quando escrever, evite anglicismos mas tente se manter próximo da forma popular da língua. Por exemplo: nós adotamos alguns anglicismos como mouse, kernel, etc. são comuns e aceitáveis. Aqui tem algumas substituições úteis.

  • Quando responder ao grupo, seja exemplar e lembre-se de que você é a referência que outros programadores seguirão.


Comunidade de desenvolvedores Go


Sessões de mentoria


Licença de uso

Este material é livre, sob a licença Creative Commons e CC BY-SA. Você pode usar da maneira que preferir, mas lembre-se de citar a fonte. Não copie, acrescente, melhore e compartilhe. Assim todos ganham.

Cesar Gimenes