Como reconhecer bons programadores
Hoje recebi do amigo Leonardo Carvalho um outro texto interessante.
Um artigo de Paul Graham fala dos 18 erros que podem levar projetos ao fracasso. Entre os erros ele cita a contratação de péssimos programadores como um dos fatores. Assim este texto fala justamente de como reconhecer os bons programadores.
De maneira resumida, o artigo que me foi enviado, aponta alguns indicadores (tanto positivos, quanto negativos) que facilitam a identificação deste "ser":
Indicadores positivos:
- Apaixonado por tecnologia
- Programa por Hobby
- Participa de discussões técnicas
- Possui projetos pessoais em paralelo
- Aprende novas tecnologias por conta própria
- Tem a capacidade de opinar qual a melhor tecnologia para cada tipo de uso.
- Sente desconforto em trabalhar com uma tecnologia na qual ele não crê que seja "ideal"
- Esperto e capaz de conversar sobre vários assuntos.
- Começou a programar bem antes de entrar na faculdade
- Conhece várias tecnologias (algumas podem nem estar presentes no seu Curriculum)
Indicadores Negativos:
- Programa apenas no trabalho
- Não quer ou não gosta de participar de debates técnicos
- Somente aprende novas tecnologias quando a empresa paga cursos
- Está feliz em trabalhar com qualquer tecnologia. "Toda tecnologia é boa"
- Não parece ser "esperto"
- Começou a programar na faculdade
- Toda sua experiência de programação está no Curriculum
- Focado em apenas 1 ou 2 tecnologias sem experiência fora delas.
Não gosto de ser radical, mas depois de conhecer vários profissionais de informática, durante vários anos e em vários projetos, posso dizer que em 95% dos casos os indicadores caem como uma luva. Muitos dos que não concordam dizem (principalmente aqui no Brasil) que este é o perfil de um Nerd, e que seus perfis extremamento técnicos não ajudam o projeto por não saberem lidar com o fator humano (principalmente o cliente) envolvido nos grandes projetos de TI. Para as pessoas que pensam assim, queria dizer apenas uma coisa: "Estou cansado de ver projetos compostos apenas por blábláblá*, onde a parte técnica é TOTALMENTE negligenciada e assim o produto (o software) não atende o cliente nem nos requisitos funcionais quanto nos não funcionais.
* E complementando: Não quero dizer que comunicação não é importante, pelo contrário; é o motor que faz o projeto andar para o caminho certo. O "blábláblá" do qual me refiro são os artefatos que não agregam valor nem para o cliente, nem para a equipe, nem para o projeto. São apenas blábláblá!!!!
Maiores informações sobre estes indicadores podem ser lidos no artigo: How to recognise a good programmer
Boa Leitura!
Leave a comment