sexta-feira, 19 de fevereiro de 2021

Explicações, despedida e um novo começo

Saudações a você que estiver lendo esta postagem. Faz um tempo que não escrevo, não é verdade ?! Caso você faça parte daquela minúscula parcela do meu público que me acompanhava deve estar estranhando ou até se sentindo surpreso pelo fato de eu estar escrevendo aqui mais uma vez. Fique tranquilo ! Tudo será explicado nesta postagem.

Se pararmos para analisar quando foi a última postagem do Preciso Estudar Sempre, chegaremos a conclusão de que foi em 3 de Dezembro de 2017. De lá pra cá muita coisa mudou, estamos falando de um hiato de mais de 3 anos sem publicações. Mas a pergunta que paira no ar é: porque? Por que parei de publicar ? Por que não soltei nenhuma nota para dizer ao público o motivo pelo qual eu estava sumido ? E, como já diz aquela velha e saudosa marchinha de carnaval: Parou porquê ? Por que parou ?

A resposta é simples, estava envolvido na construção do meu livro. E sim, você não leu errado. A história desse livro é um pouco engraçada porque ela começou da forma mais inusitada possível. Eu sempre quis escrever um livro mas nunca tinha encontrado uma oportunidade, até porque pra quem não é do meio escrever um livro parece impossível. Eu, pelo menos, pensava em um milhão de detalhes como “quem vai publicar ?”, “como vou registrar ?”, “como vou vender ?”, “onde imprimir ?” e etc.

Figura 1 - A capa do meu livro

Quem sempre me acompanhou sabe que teve uma época em que escrevia muito sobre a Teoria dos Grafos. Investi nesse tema por pura vontade, sempre gostei do assunto. Para cada publicação que eu escrevia, eu compartilhava o link dela em vários grupos de desenvolvimento no Facebook. Nessa época o Facebook ainda era a rede social badalada do momento. Essa era a minha forma de fazer a minha própria propaganda. Talvez nisso existisse um erro, talvez devesse investir mais na propaganda do blog, ter levado mais a sério esse ponto em específico. Sempre tive poucos acessos porque não dava a devida atenção a divulgação do conteúdo, eu só postava e compartilhava com aquele pequeno círculo de contatos.

Em um desses compartilhamentos um rapaz comentou na minha publicação dizendo que seria legal compilar as minhas postagens em um livro. Ele estava fazendo mestrado e precisava aprender sobre o assunto. Ele tinha criado uma afeição pelo material que eu produzia. Respondi que tinha interesse em criar este livro mas que não sabia como chegar lá. Então, ele me disse que já estava escrevendo um para a editora Casa do Código e eu automaticamente vi a chance que eu precisava. Pedi a ele um contato para que pudesse vender a ideia do meu livro e montei uma proposta. A proposta foi aceita e dei início a construção do livro. Isso tudo aconteceu em meados de Julho de 2017.

No início não dei a devida atenção que o livro merecia. Escrever um livro é uma tarefa que requer muita disciplina e no meu caso eu tive bastante sorte pois a editora não me cobrava tanto por material. Meu momento de vida naquela época era bastante corrido, tinha acabado de me casar, estava montando meu apartamento com minha esposa e tinha pouco dinheiro. Quem passou por isso sabe como é complicado.

Um outro fator que contribuiu muito para o meu êxito foi o apoio da minha esposa, familiares e amigos. Minha esposa teve um papel fundamental nesse processo pois em 2018 notei que o livro precisava “andar” e que ele não estava tão adiantado quanto eu esperava. Mas também, o que eu esperava ? Que tocar o blog, escrever um livro, ser marido, trabalhar e ter uma vida daria para ser feito todos ao mesmo tempo ? Nem preciso te dizer a resposta, né !?

Então tive que dar um tempo no Preciso Estudar Sempre para poder focar mais no livro e aí entra a disciplina que eu falei. Ficava todo dia depois do trabalho, das 18:00 até às 21:00. Chegava em casa quase às 23:00, era um pouco perigoso, mas eu segui em frente. Minha esposa ficava bastante preocupada comigo. O ano de 2018 foi de muito trabalho e provações porque durante a escrita do meu livro perdi minha avó por parte de pai e meu amado cão. Eles nunca sairão da minha mente e estão na seção de agradecimentos do livro.

Quando acabei de escrever o livro por completo em 2019, pensei: “acabei, agora é publicar né !?”. Mais uma vez errado. Iria ter início a revisão de português e escrita por parte da editora, e só depois de revisado por eles que o livro entraria na esteira para venda. Mas e a revisão técnica ? Quem faria ? Mais um novo desafio à frente.

Entrei em contato com o grande professor Orlando Bernardo da UERJ, aquele que me apresentou a Teoria dos Grafos. Ele disse que não teria como me ajudar devido a questões de tempo. Procurei também um outro professor, Heraldo Luís, da UFRJ, também sem tempo. Entretanto, dele saiu uma indicação, o grande professor Cláudio Esperança e bingo ! Consegui meu revisor técnico. Posso afirmar com toda certeza do mundo que tive sorte porque a vida sempre pôs pessoas muito boas no meu caminho, como essas três citadas acima. Infelizmente perdemos o professor Orlando na vida mundana, mas felizmente ele descansa ao lado do Pai celestial e está de lá ensinando com toda sua didática e carinho pelos alunos.

O professor Cláudio trouxe uma visão completamente diferente para o livro, uma visão mais simplista, mais focada na didática. Isso foi de grande valor até porque minha implementação era muito focada na linguagem de programação, o que trazia complicadores técnicos para um assunto que já é complicado por natureza. Refizemos praticamente a parte técnica do livro por completo, tanto a parte da teoria relacionada a grafos quanto ao projeto desenvolvido com o aluno. Em outras palavras, mais trabalho, especialmente em um ano desafiador pois tinha mudado de emprego em Março.

Depois de muito trabalho e debates técnicos, saí dessa experiência engrandecido tecnicamente e o livro, finalmente, terminado. A última etapa que faltava era mandar para a tal bendita revisão de português. É importante citar outra pessoa que foi crucial neste processo, minha editora chefe Vivian Matsui. A visão dela da obra e a paciência, digna de um monge, foram importantíssimos.

Meu livro foi lançado em Dezembro de 2020 e minha odisséia chegou ao fim, para minha felicidade. Fico muito grato de ter chegado neste ponto da minha vida. Fechei este ciclo de trabalho, empenho e disciplina, e pensei “preciso voltar para o meu blog” até porque o hiato durava mais de 3 anos, né !?

Durante o tempo que fiquei matutando como seria minha volta ao blog, pensei “se é para voltar quero voltar com tudo e fazendo o que eu quero fazer”. Com essa vontade criei o Tech Maida. Por que não continuar com o Preciso Estudar Sempre ? Demorei bastante pensando sobre este ponto e cheguei a conclusão que o Preciso Estudar Sempre representou uma parte da minha vida focada em soluções de desenvolvimento, até porque isso na época ia de encontro com a minha profissão. Atualmente, estou muito mais voltado para arquitetura, então precisava alçar voos maiores, sair um pouco da caixa, sabe !?

Com isso em mente, cheguei a conclusão de criar um blog novo, fora da plataforma do Blogger (que é horrível por sinal), onde lá iria por um conteúdo voltado para minha realidade atual e numa linguagem acessível a pessoas de fora do Brasil. O meu ponto fraco sempre foi a identidade visual, combinar cores é quase uma tortura, CSS nem se fale. Então, também gastei um tempo pesquisando uma plataforma que já me oferecesse coisas prontas sem que eu tivesse que reinventar a roda. Um amigo me indicou o GitHub Pages e a engine dele. Demorei um tempinho para aprender, mas foi, o barco andou.

O Preciso Estudar Sempre continuará existindo e eu continuarei ativo para os leitores dele, tirando dúvidas e respondendo comentários. Não posso ser ingrato e deixar de lado toda essa história. E é isso ! Essa postagem metade despedida metade início de um novo projeto termina aqui. Caso tenha chegado a este ponto do texto te agradeço por ter permanecido tanto tempo lendo o que escrevo, saiba que minhas palavras vem de um lugar de muito carinho.

E-mail: precisoestudarsempre@gmail.com

Leia Mais ››

domingo, 3 de dezembro de 2017

Projetando aplicações angulares - AngularJS 1.x

Olá ! Meu nome é João Paulo Maida e bem-vindos ao blog Preciso Estudar Sempre.

Em um mundo de constante evolução e velocidade é necessário saber mudar e se adaptar. Tais características se tornaram decisivas nossas vidas profissionais, e assim como é o mercado de trabalho, também é a vida dos sistemas web. A vinte anos atrás o acesso a internet era raríssimo, era considerado privilégio e os sites eram escassos. Dez anos depois, a internet já era uma realidade assim como a banda larga, jogar e ver vídeos já era possível.

A construção de software voltado para a web também teve uma mudança absurda. A um tempo atrás desenvolver uma aplicação simples com algumas operações requeria uma certa quantidade de páginas HTML, alguns controladores implementados em uma linguagem de programação, usava alguns frameworks e um pouco de JavaScript para controlar o DOM. Se você fosse um cara bom, aprendia até JQuery e fazia a “roda rodar” mais rápida. Mas hoje, isso morreu e porque ?

Como eu disse no início do post, o mundo muda toda hora. Tudo o que tínhamos como idéia de desenvolvimento voltado para web era algo que levava muito tempo. Agora, queremos aplicações velozes, responsivas, fáceis de integrar com outros componentes, leves, multi-plataformas e testáveis. Como atingir tudo isso com velocidade ?

Eis que um novo tipo de aplicações surge: as Single Page Applications. Este novo tipo define que aplicações terão somente uma página aparente ao invés ao invés de várias, como as que conhecíamos até o momento usavam. Quando uso o termo aparente, me refiro a experiência do usuário. Ele terá a impressão de que está em uma única página, assim como são os aplicativos mobile e as aplicações desktop que possuem praticamente uma tela única. Obviamente sabemos que internamente existem várias páginas interagindo e manipulando conteúdo, e é aí que entra uma característica muito forte deste novo tipo, o uso em massa de requisições assíncronas.

Evidentemente estamos falando de AJAX e a esta altura do campeonato esta técnica não é mais uma surpresa. Através deste recurso é possível passar a ideia de que existe somente uma única página responsável por tudo, mas na verdade são várias requisições assíncronas sendo feitas, via JavaScript, para obter conteúdo, trabalhando em conjunto com outras páginas. A consequência disso é um não carregamento total da página, como já conhecido na requisições síncronas, provendo assim uma experiência melhor e uso mais fluido para o usuário. Agora não há mais necessidade de que o usuário tenha que pausar por completo o seu trabalho, pois enquanto um recurso é carregado ele pode executar outras tarefas.

Uma outra característica bem marcante das SPAs é o uso intenso de JavaScript, e isto pode ser justificado pela modernidade dos browsers lançados atualmente e pelo aumento da oportunidade de acesso à internet nos últimos anos. O primeiro fenômeno resulta em um maior poderio de processamento da linguagem, e com uma linguagem mais veloz o interesse em se apoiar mais nela para o desenvolvimento de sistemas aumenta, onde tudo isto é causado pela demanda crescente de acesso à internet. Lembre-se: a primeira porta de entrada para a rede mundial de computadores é um navegador.

Devemos considerar também que o cenário desta linguagem mudou bastante desde de sua concepção. Como já citado acima, antigamente era somente usada para validações de formulário e manipulações do DOM, mas hoje em dia o leque de opções foi expandido devido às inúmeras criações de toda uma comunidade de usuários interessados em recursos mais poderosos e à própria modernização da linguagem.

Uma dessas criações foi a concepção de frameworks, como o AngularJS, que mudam a forma de se construir aplicações para a web e dão vida às Single Page Applications. Este framework possui características bem marcantes como o uso do padrão de projeto MVC como pilar, a incorporação de diversos paradigmas e padrões de projeto, componentização, o alto foco em reuso de código, contextos e um data-binding espetacular. O projeto atualmente tem o suporte da Google, o que lhe dá uma ótima visibilidade para o mercado.

Abaixo temos um exemplo bem simples de uma aplicação AngularJS, que traz conceitos primordiais sobre o funcionamento do framework e analisaremos parte por parte dela para que não façamos confusão.


 1
 2
 3
 4
 5
 6
 7
 8
 9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
<!DOCTYPE html>
<html lang="pt" ng-app>
    <head>
        <meta charset="utf-8" /> 
        <meta name="viewport" content="width=device-width, initial-scale=1" />
        <link rel="stylesheet" href="https://maxcdn.bootstrapcdn.com/bootstrap/4.0.0-beta.2/css/bootstrap.min.css">
        
        <!-- Angular v1.6.6 -->
        <script src="angular/angular.js"></script>
    </head>
    <body>
        <div class="container">
            <h2>Minha Primeira Aplicação em AngularJS</h2>
            <div class="form-group">
                <label for="nome">Seu nome aqui:</label>
                <input id="nome" ng-model="nome" type="text" class="form-control" />
            </div>
            <div class="form-group">
                Meu nome é: {{nome}}
            </div>
        </div>
    </body>
    <!-- jQuery library -->
    <script src="https://ajax.googleapis.com/ajax/libs/jquery/3.2.1/jquery.min.js"></script>

    <!-- Popper JS -->
    <script src="https://cdnjs.cloudflare.com/ajax/libs/popper.js/1.12.6/umd/popper.min.js"></script>

    <!-- Latest compiled JavaScript -->
    <script src="https://maxcdn.bootstrapcdn.com/bootstrap/4.0.0-beta.2/js/bootstrap.min.js"></script>
</html>

O primeiro ponto que deve causar um impacto ao ser visto é o ng-app na tag <html>, após o doctype. O que seria ? Um novo atributo do HTML5 ? Não, meus amigos. Isto é tão pouco pertence ao HTML5 quanto é um atributo, isto na verdade, é uma diretiva, ou em inglês directive, do AngularJS. Impressionante, não ?!

Uma diretiva é uma forma de demarcação de limites de um contexto. Pondo em palavras mais claras, o Angular precisa definir um contexto raiz para criar sua árvore de contextos. Entenda um contexto como uma área de memória. Então, a partir do momento que assinalamos nossa tag <html> com esta diretiva, estamos dizendo ao Angular para marcar esta tag como o elemento raiz da nossa aplicação. Isto nos dá a liberdade de marcar qualquer tag ou a página toda como raiz da aplicação.

Na linha 9 fazemos o import do AngularJS. No exemplo desta postagem estamos utilizando a versão 1.6, mas nada impede que você utilize uma versão mais antiga que esta para aprender os conceitos que estamos discutindo aqui. A partir do momento em que o arquivo é carregado, um callback é registrado para ser executado quando o HTML for carregado por completo. Quando executado, o AngularJS varre a árvore de elementos do DOM à procura da diretiva ng-app. Caso encontre, ele inicializará a aplicação definindo aquele elemento como a raiz.

Dê uma olhada mais abaixo e vá para a linha 16. Mais uma diretiva do AngularJS. Um dos conceitos principais que já vimos acima é o data-binding que o AngularJS realiza. Mas o que seria data-binding ? Traduzindo ao pé da letra, data-binding significaria ligação ou conexão de dados, e é realmente isso que o AngularJS faz. Quando você estabelece uma diretiva ngModel em algum campo HTML de entrada de dados (<input>, <select>, etc.), o AngularJS em tempo de carregamento da página conecta o valor do campo de entrada, no nosso caso um <input>, à uma variável de modelo com o nome especificado dentro da diretiva ngModel e assim mantém os dois em sincronia.

Mas, calma aí, não especificamos nenhuma variável de modelo via JavaScript, como ele realiza essa conexão e mantém essa sincronia ? Ele realiza isso de forma interna, sem que você explicite. Obviamente, que em postagens posteriores veremos como criar controladores via AngularJS e nossas variáveis de modelo, mas agora nos prenderemos ao simples. Essa sincronia é conhecida como two-way data-binding, pois ela é uma via de mão dupla, ou seja, possui dois sentidos. O primeiro sentido já vimos, está na linha 16 e a segunda via está na linha 19.

Imagino que nesse momento mais uma dúvida surja porque o que aquelas chaves estão fazendo lá ? Esta é mais uma característica do AngularJS, conhecida como double-curly binding, e é o segundo sentido de que havíamos conversado. Em suma, representam a outra ponta do two-way data-binding e tornam a sincronia possível. Também aceitam expressões nos moldes JavaScript, que são avaliadas pelo AngularJS e tem seu resultado inserido no DOM. Então, no nosso exemplo, a partir do momento que alterarmos o valor da caixa de texto, uma atualização será feita e exibida abaixo, sem a necessidade de que tenhamos que nos preocupar com isso.

Por último temos que entender como os escopos do AngularJS funcionam porque isso será de grande importância quando você estiver construindo suas próprias aplicações. Existem três coisas muito importantes que acontecem durante a inicialização do AngularJS, são elas:

  • O injetor ou injector usado para a injeção de dependências é criado.
  • O injector criará o escopo raiz da aplicação que se tornará o contexto para o modelo da sua aplicação.
  • O AngularJS irá então compilar o DOM começando no elemento raiz marcado com ngApp, processando quaisquer diretivas e conexão de dados (data-binding) encontradas no caminho.
Uma vez que a aplicação foi inicializada, ela irá então esperar por eventos inesperados do browser que podem mudar o modelo. Uma vez que o evento ocorra, o AngularJS detecta se ele causou alguma mudança no modelo e se alguma mudança for encontrada, o AngularJS irá refletir ela na camada de visão através da atualização de todas as conexões feitas.

De fato, utilizar este framework para o desenvolvimento de SPAs é um fator que torna o processo de construção de um sistema bem veloz, pois como vimos com este simples exemplo, é possível fazer bastante com pouco. Porém, sua curva de aprendizado é bem pesada pois além de trabalhar com diversos padrões de projeto, como factory, injeção de dependências, inversão de controle, MVC, e etc., ele lida com invocações de web services, componentização, entre outros. Então, meu conselho para você que não tem esses conhecimentos tão amadurecidos na sua cabeça é, estude primeiro a teoria para não sair por aí construindo Frankensteins que irão te perseguir até o seu túmulo.

Evidentemente que eu dei uma limpada nos detalhes do framework, mas se eu trouxesse todos eles, a leitura se tornaria impraticável. Por tal motivo recomendo, uma leitura no guia de desenvolvimento ou no roteiro da API.

Como vocês já sabem, todos os links de referências e de download do projeto estão abaixo. 

Até a próxima minha boa gente ! 😘


Dúvidas !? Sugestões ?! Críticas ou elogios ?!

Deixe aí nos comentários, envie um e-mail ou uma mensagem na nossa página do Facebook.

Download no GoogleDrive: clique aqui
Download no Dropbox:

E-mail: precisoestudarsempre@gmail.com
Facebook: https://www.facebook.com/precisoestudarsempre/

Referências:
Leia Mais ››

quinta-feira, 23 de novembro de 2017

Recomendação de livro: Clean Code - A Handbook of Agile Software Craftsmanship

Olá ! Meu nome é João Paulo Maida e bem-vindos ao blog Preciso Estudar Sempre.

O livro que venho recomendar aqui hoje é um dos integrantes do hall de ouro da literatura do desenvolvimento de software. Ele compõe a base do que eu costumo chamar de “fonte de conhecimento”. Tenho este costume pois gosto de acreditar que quando estou em contato com este tipo de obra, estou me servindo diretamente da fonte e isto, para mim, é importantíssimo.

Assim como Indiana Jones perseguiu em uma das suas aventuras a fonte da juventude eterna, acho que é de igual importância a perseguição por conhecimento puro em nossas áreas de interesse. Quando digo puro, me refiro as obras iniciais que serviram como base para outros escritores construírem, posteriormente, suas contribuições.

Não sejamos radicais nesse momento. Evidentemente não estou dizendo que as outras obras que existem por aí não servem ou não são boas. Cada trabalho tem sua contribuição no mundo, como por exemplo, o ponto de vista do autor ou a forma de escrita usada no assunto. Porém, é perigoso se ater somente a esses autores. Pego esta situação e aplico à mim.

Possuo quase dez anos na área de T.I. e passei por diversas áreas, como infra-estrutura, desenvolvimento e qualidade e arquitetura. Imagine se eu me satisfizesse somente com os primeiros livros que li. O que aconteceria ? Uma coisa é certa, eu não possuiria o conhecimento que possuo hoje e provavelmente não teria chegado onde cheguei. Ter lido diversas obras sobre o mesmo assunto ou sobre coisas que eu já sabia, deu a mim o mecanismo da crítica e análise, pois eu conheci vários pontos de vista diferentes.

Isto é de imensa importância. Imagine um profissional com trinta anos de carreira onde ele conhece só uma perspectiva do que faz ? Evidentemente é uma pessoa limitada. Dele ou dela não virão soluções fantásticas e o motivo é claro. Quando não há uma preocupação em se beber direto da fonte criadora do assunto, possuir um raso entendimento e, consequentemente, limitado, é uma questão de tempo.

O livro Clean Code - A Handbook of Agile Software Craftsmanship é das fontes quando o assunto é código limpo. Ele introduz no leitor a idéia do software como uma criação artesanal e cíclica. Isto se traduz em tratar um software com o mesmo cuidado e esmero que um artesão trata sua obra de arte. O resultado deste processo é um código limpo e de alta qualidade, pois a construção de um requer uma análise repetitiva, ou seja, o que você fez hoje pode melhorar amanhã.
Figura 1 - Capa do livro

Apontar um único ou um grupo de capítulos seria complicado porque todos são excelentes. Eu li da primeira até a última página, e em todas eu aprendi técnicas e vi reflexões que me deixaram de boca aberta. O que mais me impressionou nesta leitura foi o toque humano que o autor possui em abordar os problemas. Quando digo “humano”, quero dizer que ele narra as dificuldades e dúvidas que teve de uma forma que me faz pensar que eu já passei o mesmo, me identificando assim com ele.

Isto é deveras importante, pois quando se lê uma obra de altíssima qualidade escrita por uma referência no assunto, no nosso caso Robert C. Martin (a.k.a Uncle Bob), a tendência é a idolatria ao autor e um afastamento da sua imagem à dele. Contudo, a partir do momento em que você lê sobre os mesmos problemas e questionamentos que ele já passou e que você tem ou teve, pensa: “cara, ele é tão humano quanto eu”. Neste momento você se identifica e se aproxima.

Minhas considerações finais são:
  • Leia o livro todo e não somente uma vez. Leia toda vez que sentir vontade ou esquecer algo porque você sempre vai aprender algo novo ali.
  • Tente sempre procurar beber da fonte sobre um determinado assunto que te interesse, mas faça isso sem ignorar as contribuições já feitas posteriores a contribuição do criador.
  • Lembre-se que todos os gigantes da orientação a objetos (Robert C. Martin, Erich Gamma, Martin Fowler, Kent Beck, etc.) se conhecem ou se citam. Então dê uma olhada nas obras citadas ao longo do texto, você vai aprender bastante ali.
  • Tente sempre encontrar a obra em questão em seu idioma original para que você não tenha problemas com traduções, como perda de informações. Mas caso você tenha problemas com línguas estrangeiras, leia a versão traduzida, é melhor que nada.
Abraços !
Até a próxima minha boa gente ! 😘 Leia nossa postagem anterior: Aprendendo a escolher bem o que por em ordem - O algoritmo Selection Sort Dúvidas !? Sugestões ?! Críticas ou elogios ?! Deixe aí nos comentários, envie um e-mail ou uma mensagem na nossa página do Facebook. E-mail: precisoestudarsempre@gmail.com Facebook: https://www.facebook.com/precisoestudarsempre/ Canal Preciso Estudar Sempre: https://www.youtube.com/channel/UCUoW8dS38rXr0a5jWU57etA
Leia Mais ››

quarta-feira, 11 de outubro de 2017

Aprendendo a escolher bem o que por em ordem - O algoritmo Selection Sort

Olá ! Meu nome é João Paulo Maida e bem-vindos ao blog Preciso Estudar Sempre.

Ordenar é de fato uma tarefa que às vezes nos deixa de cabelos em pé. Na literatura existem vários algoritmos que podem nos ajudar, cada um com suas características. As opções são tantas que o problema muda de achar uma solução para qual solução escolher.

Como já vimos aqui em várias situações, o que vai determinar a solução necessária para um certo problema é, de fato, o problema. Logo, se velocidade é o seu problema vá para o Quick Sort, mas se o problema for lidar com partes já ordenadas, use o Insertion Sort (clique aqui para dar uma lida), e assim segue.

Um dos algoritmos primordiais ensinados, seja na faculdade ou no cursinho técnico, é o Bubble Sort (clique aqui). Ele, junto com Insertion Sort e Selection Sort, compõem uma categoria conhecida como “Algoritmos de ordenação simples”. Não vá achando que simples signifique inútil. Ao contrário, esses algoritmos servem como base para algoritmos mais complexos como Quick Sort, Merge Sort e Shell Sort. O que difere a categoria dos básicos para dos complexos são as técnicas e estruturas de programação utilizadas.

Nosso foco hoje será exclusivamente o Selection Sort para assim fechar a categoria dos simples. Abordaremos seu conceito, sua implementação e características.

Imagine que exista uma fileira de lápis que possuem vários tamanhos e você quer por eles em ordem porque, assim como eu, tem TOC.
Figura 1 - Lápis desordenados
Para ordenar esses lápis utilizando a técnica do Selection Sort marcamos o primeiro lápis (à esquerda) com um marcador indicando que aquele é o menor lápis encontrado no momento. Após isso, verificamos um após o outro até o fim, a fim de encontrar algum lápis menor. Quando encontrado, é marcado como o menor lápis encontrado até o momento, mas a busca continua até o fim do conjunto. Caso algum lápis menor ainda seja encontrado, o marcador é movido para este. Caso contrário, a troca já pode ser feita e, o ciclo de ordenação do primeiro lápis está concluído. O marcador vai para o segundo lápis do conjunto. 

No exemplo acima, o menor lápis encontrado em uma primeira instância seria o quarto, porém finalmente o sétimo seria revelado como o menor de todos. Os marcadores iriam ser movidos do primeiro para o quarto e posteriormente para o sétimo. Após finalizado o ciclo, o marcador voltaria para o segundo lápis para assim iniciar um novo ciclo, e este processo se repete até o conjunto todo estar ordenado.

A Figura 2 é um GIF animado que mostra todo o processo sendo feito.
Figura 2 - Funcionamento do algoritmo SelectionSort
Visto que já cobrimos toda a parte teórica do assunto, podemos partir para a prática.

Quem acompanha o blog sabe que eu sempre escolho a linguagem Java como alvo das minhas implementações, mas como o grande Mário Sérgio Cortela já diz:
Mudar é complicado mas acomodar é perecer (Cortella, Mário Sérgio).
Vamos implementar o nosso algoritmo em Javascript, afinal de contas é uma linguagem que funciona em todos os navegadores de todos os dispositivos, sejam eles computadores, notebooks, celulares ou tablets; e não é necessário um ambiente tão complexo de execução igual ao do Java.

1
2
3
4
5
6
7
8
9
for(out=0; out<qtd-1; out++){
    marcador = out;                             //primeiro elemento marcado
    for(ins=out+1; ins<qtd; ins++){             //varro os itens a direita procurando o menor de todos
        if(valores[ins] < valores[marcador]){   //encontrado item menor ?
            marcador = ins;                     //move o marcador
        }
    }
    _trocar(out, marcador);                     //acabaram os dois laços então posso fazer a troca
}
(LAFORE, ROBERT)

Note que o algoritmo é bem simples, não há nada extremamente complexo. Os dois laços for orquestram o processo descrito nos parágrafos acima. O primeiro começando do início e o segundo iniciando a partir do ponto de partida do primeiro, ou seja, se o primeiro laço começa em 0, o segundo começará em 1. Contudo, note que o primeiro laço só vai até qtd-1, porque ? Porque não ir até qtd ?

A resposta é simples se pararmos para analisar a situação como um todo. Com as consecutivas trocas dos valores, os maiores (no caso de ordenação crescente) são sempre jogados para o fim e o maior valor terá seu lugar trocado com alguém menor que ele, ocupando assim o último lugar. Por tais motivos não é necessário que o laço mais externo percorra todas posições do array.

Os nomes das variáveis controladoras de laço foram escolhidas devido ao fato de existirem um laço externo e um interno, logo respectivamente out e ins. O resto do código está bem claro e dispensa maiores explicações.

A ordenação por seleção executa o mesmo número de comparações que a ordenação pelo método bolha: N*(N-1)/2. Para grandes valores de N, os tempos de comparação predominarão, portanto a ordenação por seleção executa em tempo de O(n²), exatamente como a ordenação em bolha. Contudo, ela tende a ser bem mais rápida porque há poucas trocas. Para valores menos de N, a ordenação por seleção pode ser de fato mais rápida, especialmente se os tempos de troca forem muitos maiores que os tempos de comparação (LAFORE, ROBERT).

Chegamos ao fim de mais um post meus amigos. Espero que tenham gostado. Caso tenham sentido falta de algum detalhe, deixe nos comentários.

Até a próxima minha boa gente ! 😘

Leia nossa postagem anterior: Cuidado com os comentários, eles são perigosos !!!

Dúvidas !? Sugestões ?! Críticas ou elogios ?!

Deixe aí nos comentários, envie um e-mail ou uma mensagem na nossa página do Facebook.

Download no GoogleDrive: clique aqui
Download no Dropbox: clique aqui

E-mail: precisoestudarsempre@gmail.com
Facebook: https://www.facebook.com/precisoestudarsempre/
Canal Preciso Estudar Sempre: https://www.youtube.com/channel/UCUoW8dS38rXr0a5jWU57etA

Referências

Cortella, Mário Sérgio; Mudar é complicado? Acomodar é perecer.; https://www.youtube.com/watch?v=Ry3_5Pl8qmk

LAFORE, ROBERT; Estruturas de Dados e Algoritmos em Java; 2004
Leia Mais ››

sexta-feira, 29 de setembro de 2017

Cuidado com os comentários, eles são perigosos !!!

Olá ! Meu nome é João Paulo Maida e bem-vindos ao blog Preciso Estudar Sempre.

Mamãe sempre me disse que comentários são perigoso, e você já comentou o seu código alguma vez na vida ? Já se pegou escrevendo algo do tipo “aqui verifico se é diferente de nulo para não dar erro” ou “se condição igual true é porque idade é maior de 18” ? Se sim, não se desespere pois essa prática é muito comum para quem desenvolve software, porém não é uma das melhores e afirmar isso é o que realmente assusta a maioria das pessoas.
Duas mulheres fofocando. Uma fala no ouvido da outra e causa espanto.
Figura 1 - Cuidado com comentários, eles são perigosos !!!
Mas como um simples comentariozinho seria algo tão grave assim ? Muitos podem afirmar que o que estou dizendo é non-sense ou bobagem, já que comentários são ignorados em processos de compilação. Entretanto, devemos nos lembrar que antes de estarmos escrevendo “linguagem de máquina”, estamos escrevendo texto que outros poderão ler. De que adianta para um autor escrever um livro que ele só entende, ou escrever um livro que para cada parágrafo ele precisa explicar o que realmente ele quis dizer ?

Se ele precisou explicar através de um comentário qual era sua verdadeira intenção, então ele falhou em escrever o texto pois o próprio por si só não consegue ser expressivo bastante para passar sua própria ideia. Em miúdos, podemos concluir que um código-fonte de qualquer linguagem que falhe em passar seu próprio propósito de existência para qualquer leitor é um código defeituoso.

Neste momento espero ser apedrejado até a morte !!!
A figura mostra três homens apedrejando um outro homem de bata branca, com aparência de religioso. Existe um homem atrás de todos, com bata verde que só observa. O homem apedrejado parece pedir ao seu Deus misericórdia.
Figura 2 - Eu sendo cruelmente apedrejado
Bom, se você está lendo isto é porque ainda não fui apedrejado 👌.

Então se você se encaixa no que disse acima, você produz um código defeituoso. Um software deve ser escrito de forma que outros possam lê-lo como se fosse um livro, suavemente. As intenções de todos os elementos, desde daquela minúscula variável até aquela classe mega complexa, devem estar claras ao ponto de que com uma simples passada de olhos um outro programador que nunca tenha visto aquilo possa entender ou ter uma ideia do que está sendo feito.

Como disse no início do texto, esse assunto sempre gera muita discussão, mas é uma das principais métricas quando o assunto é código limpo. Se a sua intenção é, assim como a minha, o self-improvement, ou seja, crescimento pessoal, não se ofenda com o fato de que o código que produz não ser tão bom quanto pensava. Eu já passei pelo mesmo, me surpreendi várias vezes e reaprendi coisas que eu já achava que sabia. Acredito que faz parte passar por isso, quem consegue aprender sem errar ?

O livro que abriu minha mente para a produção de um código mais limpo e expressivo foi o Clean Code, escrito por Robert C. Martin, conhecido também pelo apelido Uncle Bob. Um grande amigo me apresentou a obra e me emprestou o seu livro em português. Comecei a ler e fiquei abismado com a riqueza de detalhes que o simples nome de uma variável pode ter. Depois de um tempo abdiquei do livro emprestado por questões de mobilidade, e baixei o PDF para meu celular. Todo momento livre que eu tenho dou uma lidinha nele, nem que seja cinco minutos. Ele é aquele tipo de livro que você tem que ler várias vezes porque no fim das contas você sempre aprende algo novo.

Existe um capítulo dedicado sobre o estudo de comentários (capítulo 4), onde são abordados assuntos como consequências de um código comentado, categorização, como programar sem comentar, bons e maus comentários, entre outros. O que estamos discutindo aqui é somente uma fração do que o livro cobre. Logo, para mais detalhes dê uma lidinha neste capítulo, vale bem a pena 😊. Deixarei um link para download no fim do post.
A capa do livro traz uma imagem de uma galáxia
Figura 3 - Clean Code escrito por Robert C. Martin
Não pense que sou contra Javadocs, sou muito a favor inclusive. Mas um Javadoc é algo completamente diferente de um comentário explicativo de uma linha de código, e mesmo assim se o Javadoc ferir algumas regrinhas que o livro aborda, então ele possui problemas. Adiante veremos um exemplo de código com o que considero um comentário ruim.

 1
 2
 3
 4
 5
 6
 7
 8
 9
10
11
12
13
14
15
public class BadComment {
    /*valores*/
    private final int[] valores = {1,2,3};
   
    private void verificarValores(){
        //verifico se existem valores
        if(valores.length>0){
            System.out.println("Tem valores !!!");
        }
    }
   
    public static void main (String[] args){
        new BadComment().verificarValores();
    }
}

Para um tempinho e olhe bem a amostra de código acima. Me diga, para que raios uma pessoa cria um comentário (linha 2) com o mesmo nome do atributo da classe ? Pra que isso serve ? Do que adianta ? Qual vantagem traz ? Sinceramente, nunca consegui responder tais questões e já vi isso acontecer várias vezes.

Calma porque ainda vai piorar !

Um outro programador começou a trabalhar nessa classe e resolveu mudar de lugar o atributo valores mas esqueceu de levar o comentário junto. Olha só o que aconteceu.


 1
 2
 3
 4
 5
 6
 7
 8
 9
10
11
12
13
14
15
16
public class BadComment {
    /*valores*/
    
    private void verificarValores(){
        //verifico se existem valores
        if(valores.length>0){
            System.out.println("Tem valores !!!");
        }
    }
    
    private final int[] valores = {1,2,3};
    
    public static void main (String[] args){
        new BadComment().verificarValores();
    }
}

Agora quem for trabalhar em cima dessa classe vai ficar confuso. Porque existe esse comentário na linha 2 ? O que ele está fazendo aí ? Essas são umas das perguntas que são feitas quando isso acontece. Tal fenômeno leva os programadores ao medo, pois é criado o receio de que se algo é mudado o sistema inteiro pode parar em produção. Um sistema que não pode sofrer alterações ou testes está doente.

Analise agora o comentário da linha 5 da amostra acima. Qual é a expressividade que ele nos traz ? Obviamente, ele explica o que está sendo feito e pode até ajudar em uma primeira instância. Porém, e se alguém mudar a instrução if da linha 6 de lugar ou mudar a condição ? Será que o comentário vai acompanhar a mudança ? Senão acompanhar, será que uma outra pessoa vai entender que ali havia uma verificação, ou talvez se a que existe ali condiz com o respectivo comentário ? Note que a teia de dúvidas não pára de ser tecida, está na hora de dar um basta nisso.


 1
 2
 3
 4
 5
 6
 7
 8
 9
10
11
12
13
14
15
16
17
18
public class BadCommentConsequence {
    
    private final int[] valores = {1,2,3};
    
    private void verificarValores(){        
        if(temValores()){
            System.out.println("Tem valores !!!");
        }
    }        
    
    private boolean temValores(){
        return valores.length>0;
    }
    
    public static void main (String[] args){
        new BadCommentConsequence().verificarValores();
    }
}

Nossa classe deve ficar como mostrado acima. Antes de tudo, adeus para comentário de atributo, isso não faz o menor sentido. Um atributo ou uma variável deve mostrar o motivo de sua existência através de seu nome e não por um comentário.

O comentário da linha 5 também foi embora e a condição do if possui um método próprio com um nome bem expressivo, que mostra qual é o motivo dele estar ali. Agora sabemos que somente será impresso algo no console quando existirem valores. A consequência dessa refatoração é uma leitura muito mais limpa e simples.

Conclusão: Um código bem feito, limpo e enxuto passa muito significado. Esse é um dos fatores mais importantes no desenvolvimento de software e uma das maiores preocupações que devemos ter se nossa intenção é produzir um bom trabalho.

Não se preocupa em errar, todos erram ou erraram um dia. Saber que errou e permanecer no erro que é o verdadeiro problema. A construção de um bom código requer um ciclo de revisão contínuo, ou seja, o que você fez hoje pode ser melhorado amanhã .

O livro apresentado é uma das referências no assunto. Selo de recomendação de leitura do Maidão.

Terminamos mais um post !! 😀

Espero que você tenha gostado. Até a próxima minha boa gente ! 😘

Leia nossa postagem anterior: Ausência do blog e férias

Dúvidas !? Sugestões ?! Críticas ou elogios ?!

Deixe aí nos comentários, envie um e-mail ou uma mensagem na nossa página do Facebook.

Download no GoogleDrive: clique aqui
Download no Dropbox: clique aqui

E-mail: precisoestudarsempre@gmail.com
Facebook: https://www.facebook.com/precisoestudarsempre/
Canal Preciso Estudar Sempre: https://www.youtube.com/channel/UCUoW8dS38rXr0a5jWU57etA

Referências
Leia Mais ››

quarta-feira, 20 de setembro de 2017

Ausência do blog e férias

Olá ! Meu nome é João Paulo Maida e bem-vindos ao blog Preciso Estudar Sempre.

Você deve ter notado que eu dei uma parada nas postagens, uma sumida. Sim, eu estava de férias. Estava recarregando minhas baterias, descansando minha cabeça para voltar com potência total com novos assuntos e motivação lá nas alturas. Se você sentiu minha falta nesse período, fico feliz com sua preocupação e carinho até porque é isso que mantém nos trilhos e trabalhando.

Minhas férias foram repletas de novas descobertas, aprendi muito e me reinventei. Pensei sobre diversos pontos, um deles é a trajetória do blog. Devo confessar que senti uma pontada de vontade de engavetar o blog, dar uma parada, descansar mais. Contudo, tenho certeza de que essa seria uma péssima escolha, a qual iria me arrepender profundamente no futuro. O laço, que com muito custo consegui construir com vocês, leitores, é muito importante. Foram anos de dedicação em trazer novos assuntos e de esforço em divulgar o material aqui publicado. A consequência disso são os poucos porém valiosos comentários que tenho de pessoas reais dizendo que de fato eu ajudei elas. Isso, meus amigos, não tem preço.

Ter uma visão voltada para o futuro do blog se faz necessária nesse momento e para haver um futuro é necessário entender o passado, acredito. Um dos pilares que sustenta a idéia do blog é a vontade de se estudar qualquer assunto. Então, pense nas antigas civilizações e o quanto ainda temos que aprender com elas.

Os egípcios, por exemplo, são mestres na arte da engenharia e seu legado possui valor inestimável para a humidade. Contudo ainda existem questões não respondidas. Mais uma vez estamos diante do mesmo questionamento, é necessário entender o que aconteceu milhares de anos atrás para poder entender o presente e pensar em um futuro. Então é isso o que precisa ser feito aqui e agora.

Não quero me estender muito neste assunto até porque esse não é objetivo desta publicação e não temos tempo a perder. Esta declaração é apenas uma satisfação que acho que vocês, leitores, merecem por uma questão de consideração. Feito isso, me despeço e peço que aguardem pois novidades estão por vir.

Até a próxima minha boa gente ! 😘

Leia nossa postagem anterior: Um roteiro para o estudo da teoria dos grafos

Dúvidas !? Sugestões ?! Críticas ou elogios ?!

Deixe aí nos comentários, envie um e-mail ou uma mensagem na nossa página do Facebook.

E-mail: precisoestudarsempre@gmail.com
Leia Mais ››

quinta-feira, 3 de agosto de 2017

Um roteiro para o estudo da teoria dos grafos

Olá ! Meu nome é João Paulo Maida e bem-vindos ao blog Preciso Estudar Sempre.

Parabéns !!! 🎇🎇🎇🎈🎉🎉🎊

Você chegou ao fim de uma incrível jornada, passou e superou diversas intempéries e fez descobertas espetaculares, você merece estar aqui. Sinto neste momento muito orgulho de você.

Se esta é a sua primeira visita neste blog e não está entendendo muito bem o que está acontecendo, não se desanime e continue lendo pois logo vai entender.

Já parou para pensar que é de extrema importância existir, aqui no blog, um catálogo bem resumido e enxuto voltado para o estudo da teoria dos grafos ? Isso nunca foi feito antes. Uma forma de deixar um passo-a-passo, um guia, para as pessoas que estão perdidas e não sabem por onde começar. Se você acha que isto é uma bobeira, está enganado meu caro. Tal possui tanta importância assim como os assuntos já vistos aqui. Na verdade, na minha opinião, a internet carece de tal iniciativa a fim de facilitar a vida de pessoas que estão tentando entrar neste nova área de conhecimento.

Então, sem mais delongas, lhes apresento um guia feito por mim para o estudo da teoria dos grafos.
  1. Grafos - O início
  2. Matrizes de adjacência
  3. Busca em profundidade
  4. Busca em largura
  5. Árvores geradoras mínimas
  6. Orientação
  7. O algoritmo de Warshall
  8. Grafos ponderados
  9. O algoritmo de Dijkstra
Se você quer um entendimento sólido e básico sobre o assunto, recomendo fortemente que siga de forma ordenada as etapas enumeradas. Todas foram feitas com muito carinho e esmero. Explicações detalhadas, exemplos e imagens são apenas uma mera fração da imensidão de conhecimento contido nestes tópicos.
 
Caso você seja um amante da matemática assim como eu, especialmente da teoria dos grafos e fique triste por termos chegado ao fim desta série. Entendo sua situação. Porém pense que seria muito complicado prender o blog e seu público somente a este assunto sabendo que há uma vastidão de assuntos ainda não explorados mas nada impede que futuramente entre em pauta novamente.

Até a próxima minha boa gente ! 😘

Leia nossa postagem anterior: O princípio da responsabilidade única - S.O.L.I.D

Dúvidas !? Sugestões ?! Críticas ou elogios ?!

Deixe aí nos comentários, envie um e-mail ou uma mensagem na nossa página do Facebook.

E-mail: precisoestudarsempre@gmail.com
Facebook: https://www.facebook.com/precisoestudarsempre/
Canal Preciso Estudar Sempre: https://www.youtube.com/channel/UCUoW8dS38rXr0a5jWU57etA

Referências
Leia Mais ››