: : www.mundoj.com.br : : Alexandre Gazola ([email protected]): é bacharel em Ciência da Computação pela Universidade Federal de Viçosa (UFV) e mestre em Informática pela PUC-Rio. Trabalha como analista de Sistemas no BNDES e possui as certificações SCJP e SCWCD. Mantem um blog em http://alexandregazola.wordpress.com e Twitter em: http:// twitter.com/alexandregazola. Rafael Pereira ([email protected]): ([email protected]): é bacharel em Ciência da Computação pela UERJ (2004), mestre em Computação pela UFF (2009) e cursa o doutorado em Computação na UFF. Trabalhou em empresas privadas (Accenture, EDS), públicas (Banco Central) e atualmente é analista do BNDES. Autor de dois livros técnicos de Java e possui as certificações SCJP, SCWCD, JBoss, Oracle e Linux (LPI-1). Site: www.rbper.com Concursos públicos na área de TI: Vale a pena? Entenda os atrativos da carreira pública e fique por dentro de alguns temas recorrentes nas provas Nos últimos anos, parece haver aumentado o interesse de profissionais da área de TI na carreira pública. Boas condições de trabalho, problemas desafiadores a serem resolvidos, benefícios diversos e remuneração atrativa têm despertado o interesse de muitos dos melhores desenvolvedores de software para a iniciativa pública. Nos concursos, é recorrente encontrarmos questões relacionadas à linguagem e à plataforma Java, orientação a objetos, padrões de projeto e tecnologias voltadas para a web. Neste artigo, falamos um pouco sobre as vantagens e desvantagens da carreira pública na área de TI e trazemos também um simulado comentado que explora algumas dessas questões de tecnologia nos principais concursos. 42 aprovação em concursos públicos é uma busca recorrente para milhões de brasileiros. De acordo com um estudo do IPEA de 2009, o serviço público emprega 8,2 milhões de funcionários, mais de um quinto do total de pessoas empregadas no País. As carreiras públicas possuem alguns atrativos que, muitas vezes, não são encontrados na iniciativa privada, como, por exemplo: estabilidade, benefícios diversos, ambiente de trabalho agradável, incentivo para especialização e participação em congressos e boa remuneração. Como em praticamente todos os setores da indústria e serviços na sociedade atual, profissionais de TI também estão entre os mais demandados em empresas e órgãos públicos; e muitos profissionais da nossa área têm visado esse tipo de carreira. Será que vale mesmo a pena? E a estagnação da qual as pessoas tanto falam? Neste artigo, discorreremos um pouco sobre os principais atrativos da carreira pública. Destacaremos as principais vantagens de ser um profissional concursado de forma geral e, em seguida, analisaremos brevemente a questão na ótica de um profissional de TI (vantagens e desvantagens). Ao final, comentaremos brevemente a respeito dos concursos (formato das provas, tipos de questões etc.) e apresentaremos um pequeno simulado, com questões extraídas de concursos reais, que o leitor poderá utilizar para testar seus conhecimentos e se familiarizar com os assuntos que costumam ser cobrados. Nesse simulado, nosso foco recairá em conteúdo relacionado à linguagem e à plataforma Java, OO, padrões de projeto e tecnologias web, que são assuntos frequentes em concursos na área de TI. Motivação da carreira pública: vantagens e desvantagens Quais seriam as principais diferenças entre a carreira na iniciativa pública e a carreira na iniciativa privada? Estabilidade garantida? Ambiente de trabalho sem pressão? Falta de desafios e estagnação? Remuneração adequada? Nesta seção, vamos analisar algumas dessas questões considerando também o foco em TI. A estabilidade dos servidores públicos é um direito garantido constitucionalmente, e assegura o emprego do concursado sob o regime estatutário (ex.: Receita Federal, Policia Federal, BACEN, CVM etc.). Esse benefício é justificado pela manutenção do interesse público, qualificação profissional e eficiência da administração, pois o servidor não será dispensado por fatores políticos. Além disso, ele poderá executar o seu trabalho com autonomia e sem ir contra as suas atribuições devido a interesses da sua chefia superior (assédio moral). Lembramos também que existem empresas públicas e de economia mista sob o regime CLT (ex.: Banco do Brasil, Petrobras, Correios, BNDES, Eletrobrás etc.), nas quais o benefício de estabilidade não é oficialmente assegurado, embora na prática as demissões não sejam comuns. Um bom ambiente de trabalho é vital para a satisfação pessoal de qualquer profissional. Isso passa por questões como uma boa relação entre colegas e com os superiores; e um espaço físico agradável; recursos computacionais de hardware e software adequados; carga de trabalho equilibrada; e nível de motivação dos funcionários. Na maioria destes aspectos, não há uma diferença tão grande entre a iniciativa pública e a iniciativa privada. Contudo, não podemos deixar de ressaltar que a iniciativa privada está cheia de exemplos do que é ter um ambiente com uma excessiva carga de trabalho, cheio de estresse e baixa motivação e produtividade por parte dos colaboradores. Existem empresas em que hora extra é a regra, e não a exceção. Ainda neste ponto, queremos também combater o estereótipo do funcionário público como aquele indivíduo que chega no trabalho, coloca o paletó na cadeira e não faz nada o dia inteiro. Certamente, existem órgãos em que isso é verdade, mas existem diversos lugares em que a realidade é completamente outra. Várias empresas públicas precisam desenvolver constantemente sistemas para atender a sociedade e as demandas de órgãos reguladores em que os prazos são muitas vezes bastante apertados, o que não deixa espaço para pessoas acomodadas. Outra vantagem menos aparente, mas que é um atrativo para muitos é a certeza de que o concurso público não irá cometer nenhum tipo de discriminação com base no sexo, raça ou cor, credo religioso e idade. Esta última pode ser um empecilho na iniciativa privada, e especialmente na área de TI, pois com o rápido avanço dos processos e das tecnologias é necessário que o profissional esteja sempre atualizado e em sintonia com o mercado. Nos órgãos públicos de ponta, a atualização tecnológica é acompanhada por consultorias especializadas e pela capacitação do corpo funcional. Um fenômeno que afetou algumas empresas da iniciativa privada, especialmente na área de TI, foi a precarização dos direitos dos tra- balhadores (ex.: contratação sob os regimes PJ, CLT Flex etc.). Na iniciativa pública ocorreu o contrário: para atrair profissionais capacitados, os salários foram elevados e a oferta de benefícios cresceu (ex.: plano de saúde e odontológico, auxílio-educação, jornada flexível, licença capacitação, entre outros). Poder realizar um trabalho que vai contribuir de maneira direta para o Brasil também é um fator que traz motivação para muitas pessoas. Porém, nem todas as carreiras do serviço público podem ser atrativas para os profissionais de TI. A realidade mostra que muitos órgãos ainda estão bastante defasados tecnologicamente, em geral pela falta de recursos para investimento. Esse cenário está mudando, como pode ser atestado conforme relatado nos quadros “Depoimentos”. Formato das provas, concorrência, técnicas de estudo Tendo em vista a quantidade de benefícios oferecida pelos diversos órgãos públicos e empresas estatais, a concorrência tem se tornado cada vez mais acirrada. É comum encontrar entre os aprovados para concursos de nível médio candidatos com diploma de graduação, e para concursos de nível superior candidatos com especialização e/ou mestrado. Os concursos mais concorridos possuem uma relação candidato/ vaga maior do que os vestibulares mais disputados. Para driblar a concorrência, candidatos buscam cada vez mais os cursos preparatórios – a busca aumentou de 15 a 20% em 2009. Soma-se a isso o custo de livros e apostilas sobre os temas constantes nos editais, e conclui-se que nem sempre o investimento é barato. Apesar da elevada concorrência, grande parte dos candidatos não se prepara adequadamente, além de muitos não comparecerem. As provas de concursos são em geral de múltipla escolha e de caráter eliminatório, podendo conter questões discursivas ou redação. Exige-se do candidato um amplo conhecimento sobre uma gama de assuntos na área em questão. Na área de TI é frequente a cobrança de assuntos como Banco de Dados, Redes de Computadores e Internet, Sistemas Operacionais, Linguagens de Programação, Gerência de Projetos e Governança em TI. A preparação para as provas já foi assunto para vários livros sobre concursos públicos.Embora cada candidato tenha um ritmo e característica de aprendizado diversos, em geral ele deve favorecer o tempo e organização do estudo, um domínio mais generalista sobre os assuntos cobrados, o foco nos resultados, e a realização de provas anteriores. Alguns candidatos podem se beneficiar pelo uso de técnicas de memorização (ex: mnemônicos), leitura dinâmica, um talento natural para certo tipo de assunto – mas, em geral, o tempo de estudo é um fator pessoal e determinante para o resultado final, tal qual as horas de voo de um piloto de avião, ou as horas de treino de um músico de uma orquestra. Cargos de informática e tecnologias (Java, OO, Web) Antes de entrarmos em algumas questões importantes relacionadas à tecnologia que todo candidato bem preparado deve conhecer, vamos falar um pouco a respeito da motivação para realizar um concurso público na área de TI especificamente. Mesmo com todos 43 : : www.mundoj.com.br : : os pontos positivos já enumerados anteriormente, será que vale mesmo a pena fazer um concurso em TI? De acordo com Diogo Gobira, um dos representantes do site preparatório Handbook de TI, alguns atrativos dos empregos públicos na área de TI são a não exigência de experiência prévia, certificações e indicações de terceiros. Isso torna a disputa pelas vagas mais democráticas e acessíveis para profissionais de perfis e idades diversos. Uma questão importante a se considerar são as oportunidades de crescimento. Os bons profissionais de TI são pessoas que estão constantemente se atualizando, gostam de aprender e querem contribuir e crescer em suas carreiras. A possibilidade de realizar cursos e participar em eventos e conferências sobre desenvolvimento de software com patrocínio da empresa é algo muito interessante e isso é apoiado por diversas empresas do setor público. Na iniciativa privada, ainda são poucas as empresas que fornecem esse tipo de incentivo de forma contínua e consistente. Outro quesito que precisa ser levado em conta é o nível de motivação dos funcionários, o qual, em TI, passa por dois aspectos: negócio e tecnologia. Queremos resolver problemas interessantes usando tecnologia interessante. Na vertente de negócio, existem empresas públicas e privadas em diversos segmentos com os mais variados e interessantes problemas a serem resolvidos. É na vertente de tecnologia que as empresas privadas ainda acabam se sobressaindo. Em muitas empresas do setor público, ainda é preciso conviver com sistemas legados de tecnologia mais antiga (ex.: mainframe, COBOL, NATURAL, ADABAS, Delphi etc.) e o uso de tecnologia mais nova às vezes é restrito a versões mais antigas (ex.: Asp; Java 1.3; JSF 1.1, EJB 2.1 etc.). O nível de burocracia em empresas públicas, devido, muitas vezes, às exigências de órgãos externos de controle, também é um fator que muitas vezes entrava a adoção das boas práticas, tais como desenvolvimento iterativo e incremental, foco no produto e eliminação de desperdício, tão promulgados pelos métodos ágeis e o desenvolvimento lean. No entanto, a realidade em muitas empresas públicas está mudando tanto na questão tecnológica quanto de processos, atenuando essa deficiência. Com a grande popularização da Web e da plataforma Java, cresceu o desenvolvimento de projetos com essas tecnologias. Uma das suas vantagens é que elas não são tecnologias proprietárias (embora a implementação da Sun/Oracle o seja). Com isso, elas se tornaram uma opção cada vez mais frequente no conteúdo programático apresentado nos editais. Bom, após essa breve explanação, esperamos que o amigo leitor esteja enxergando a iniciativa pública de uma forma mais favorável e menos estereotipada. Sendo assim, vamos ao que interessa: tecnologia! Atualmente as provas contam com 20 a 40% de conteúdo relacionado com as tecnologias voltadas para Web (HTML, XML, CSS, Web Services etc.), Java (linguagem e plataforma), Orientação a Objetos e Padrões de Projeto. Essa é uma ótima oportunidade para que profissionais Java/Web capacitados ingressem no serviço público. A seguir, será apresentado um pequeno simulado com 15 questões objetivas nos assuntos supracitados, com questões retiradas de diversos concursos, que são temas recorrentes da Revista MundoJ. 44 Simulado: questões Escolher uma alternativa Q1. (2009, FUNRIO – FURNAS, Tecnologia da Informação) Na orientação a objetos, classes que NÃO geram instâncias diretas (objetos) são denominadas classes a) primárias. b) abstratas. c) virtuais. d) básicas. e) derivadoras. Q2. (2009, ESAF – ANA, Analista Administrativo) Se, na superclasse, um método é declarado protected, o(s) modificador(es) aplicável(is) na sobrescrita do método é(são) a) private. b) private e protected. c) “default”. d) protected, “default” e public. e) protected e public. Q3. (2005, NCE-UFRJ – BNDES, Analista de Sistemas) Observe o seguinte trecho de código em Java: //Código da Q3 interface I1 { public void m1(); } interface I2 extends I1 { public void m2(); } class C1 implements I2 { // o código da classe C1 segue aqui } public class Teste { public void m3() { // o código do método m3() segue aqui } public static void main(String args[]) { I1 obj = new C1(); obj.xx(); // substitua xx pela // resposta apropriada } } Os possíveis valores para xx no código anterior são: a) somente m1; b) somente m2; c) somente m1 e m2; d) m1 e m3; e) m1, m2 e m3. Q4. (2008, ESAF – STN, Analista de Finanças e Controle) O que fazer para forçar a coleta de lixo de um objeto, em Java? Indique a opção correta. a) Invocar finalize(). b) Remover todas as referências ao objeto. c) Invocar Runtime.gc(). d) Invocar System.gc(). e) A coleta de lixo não pode ser forçada. Interface) de uso muito complicado. Para que os desenvolvedores possam acessar uma interface mais simples, o arquiteto do sistema pode determinar o uso do padrão de projeto a) Prototype. b) Decorator. c) Observer. d) Façade. e) Flyweight. Q5. (2010, CESGRANRIO – Banco Central, Analista) Uma instituição financeira desenvolverá um novo sistema de informação WEB com base na plataforma Java EE 5. Os programadores devem ter ciência de que, na linguagem de programação Java e tecnologias relacionadas, NÃO é a) possível listar, por meio da Reflection API, que anotações foram colocadas em um parâmetro de um método. b) possível obter, por meio da Reflection API, as interfaces que determinada classe implementa. c) importante declarar métodos como “final”, sempre que possível, para obter aumento de, pelo menos, 50% no desempenho, na JVM da Sun. d) importante, por questões de desempenho, evitar utilizar métodos “synchronized”, quando possível. e) necessário fechar, explicitamente, objetos JDBC como ResultSet, sob pena de vazamento de memória (memory leak), na conexão com alguns bancos de dados. Q9. (2009, Comperve – UFRN, Desenvolvedor de Software) O padrão de projeto JEE (Java Enterprise Edition) cuja finalidade é encapsular as operações de lookup e complexas interfaces de operações de rede é o a) Front Controller. b) Service Locator. c) Transfer Object. d) NetworkProxy. e) Data Access Object. Q6. (2009, CESGRANRIO – BNDES, Analista de Desenvolvimento) Ao estudar as especificações e frameworks Java EE, um Analista de Sistemas concluiu que: a) o container WEB do servidor de aplicações é o responsável por gerenciar o ciclo de vida de servlets e de EJBs utilizados numa aplicação Java. b) no container WEB, uma página JSP transforma-se em um servlet, que é compilado, carregado e inicializado. c) Enterprise JavaBeans é um modelo de componentes padronizado, executado no lado do cliente e que facilita a construção de aplicações distribuídas robustas. d) STRUTS é um framework de persistência que permite o gerenciamento de dados relacionais, utilizando-se de mapeamento objeto-relacional. e) a utilização de Java Persistent API obriga o uso de um container EJB com Session Beans. Q7. (2007, FCC – TER-SE, Analista de Sistemas) Sendo um grupo de classes e componentes responsáveis pelo armazenamento e recuperação de dados, esta camada inclui necessariamente um modelo das entidades do domínio de negócios (mesmo que seja somente um modelo de metadados). No âmbito do mapeamento objeto-relacional (Hibernate) esta é a camada de a) negócio. b) restrição. c) apresentação. d) consistência. e) persistência. Q8. (2009, CESGRANRIO – BNDES, Analista de Desenvolvimento) O presidente de uma empresa determinou que fosse disponibilizado um sistema de vendas na Internet. No entanto, o software de controle de estoque que deve ser acessado pela aplicação de vendas é muito antigo e provê uma API (Application Programming Q10. (2005, FCC – Banco Central, Analista de Sistemas) Java, como tecnologia de desenvolvimento de software, significa: a) uma plataforma, somente, composta de computador, sistema operacional e ambiente de execução Java (JRE). b) uma linguagem, somente, composta por um conjunto de palavras e símbolos utilizados para escrever programas. c) um ambiente de desenvolvimento, somente, composto de ferramentas para construção de aplicativos. d) interfaces de programas aplicativos (API), somente, compostos de classes e interfaces já existentes para o uso. e) a junção de uma linguagem, de um ambiente de desenvolvimento e de APIs, somente. Q11. (2009, FUNRIO – FURNAS, Tecnologia da Informação) Considere uma classe ContaBancária e suas duas subclasses ContaCorrente e ContaPoupança, cada uma das três com o método AplicarJuros. A redefinição do método AplicarJuros nas duas subclasses, cada uma com detalhes de implementação diferentes com a mesma interface, caracteriza o princípio denominado na orientação a objetos como a) abstração. b) encapsulamento. c) herança. d) unificação. e) polimorfismo. Q12. (2009, CESGRANRIO – BNDES, Analista de Desenvolvimento) Qual das afirmações a seguir faz uma apreciação correta a respeito da linguagem de programação Java? a) O conceito de herança múltipla é implementado nativamente. b) Uma classe pode implementar somente uma interface ao mesmo tempo. c) Uma classe pode implementar uma interface ou ser subclasse de outra classe qualquer, mas não ambos simultaneamente. d) A construção de um método que pode levantar uma exceção, cuja instância é uma subclasse de java.lang.RuntimeException, não exige tratamento obrigatório por parte do programador dentro daquele método. e) Objetos da classe java.lang.String têm comportamento otimizado para permitir que seu valor seja alterado sempre que necessário, liberando imediatamente a memória usada pelo conteúdo anterior. 45 : : www.mundoj.com.br : : Q13. (2009, CESGRANRIO – BNDES, Analista de Desenvolvimento) Analise as informações que se seguem, relacionadas aos conceitos de Orientação a Objetos (OO). I- O conceito de herança possibilita a especialização de comportamentos preexistentes em classes ancestrais. II- Para que um método seja ativado num objeto, uma mensagem não precisa necessariamente ter uma referência explícita a ele, se o objeto default da classe correspondente estiver adequadamente configurado. III- Uma das desvantagens da herança é a criação de dependência entre as classes envolvidas. IV- De acordo com a ideia do encapsulamento, é desejável, do ponto de vista de um objeto, que seus atributos internos estejam protegidos contra modificações diretas e que o acesso seja realizado por meio de métodos específicos (setters e getters). V- Polimorfismo está relacionado à vinculação dinâmica de mensagens e sobrescrita de métodos, sendo que o método correto a ser chamado só será definido em tempo de execução e dependerá do tipo da instância do objeto referenciado pela mensagem. São corretas APENAS as afirmações a) I e II. b) II e III. c) III e IV. d) III, IV e V. e) I, III, IV e V. Q14. (2009, CESGRANRIO – BNDES, Analista de Desenvolvimento) No âmbito da Refatoração de software, analise as afirmativas a seguir. I - Introduce Parameter Object é uma técnica de refatoração que pode ser aplicada em métodos muito longos. II - Código duplicado é candidato para aplicação das técnicas Extract Method e Substitute Algorithm. III - Extract Class é uma técnica de refatoração que pode ser aplicada em classes muito grandes. Está(ão) correta(s) a(s) afirmativa(s) a) I, apenas. b) II, apenas. c) III, apenas. d) I e II, apenas. e) I, II e III. CERTO OU ERRADO? Q15. (2008, CESPE – Petrobras, Analista de Desenvolvimento) Diga se cada afirmativa abaixo esta certa ou errada. I) O padrão de projeto (design pattern) Proxy é usado quando se quer usar uma classe existente, mas a interface da classe não é a de que se precisa. O Proxy pode ser implementado usandose herança múltipla para converter uma interface em outra. II) No padrão model view controller (MVC), o controlador trata eventos gerados pelos usuários e passa para o modelo os dados das requisições; um requisito para que o estilo de arquitetura MVC seja respeitado é o de que exista, em uma mesma aplicação, um único objeto no papel de controlador. III) Os membros declarados private podem ser acessados a partir de código na classe com esses membros ou a partir de códigos em classes derivadas. Tais como os membros para os quais não 46 são declarados modificadores de acesso, os membros private podem ser acessados a partir de códigos em quaisquer classes no package no qual está a classe com o referido membro. Simulado: respostas R1. (b) abstratas. Classes abstratas não podem ser instanciadas diretamente. As suas propriedades e métodos devem ser herdados por uma classe concreta, que implementará toda ou parte das suas funcionalidades. Em Java, normalmente, uma classe abstrata possui pelo menos um método abstrato, apesar de isso não ser obrigatório. Além disso, em Java uma classe que possua apenas métodos abstratos é usualmente declarada como uma interface. R2. (e). A restrição de acesso de um membro de uma classe não pode ser maior do que na superclasse. R3. (a) Somente m1. Não é possível instanciar uma interface diretamente, mas é possível instanciar uma classe que implementa essa interface. A classe C1() é instanciada e atribuída a um objeto do tipo I1, portanto mesmo C1() implementando também a interface I2, os métodos que não estão definidos em I1 não estarão acessíveis para o objeto obj. m3() e m2() não estão definidos na interface I1, logo não podem ser acessados por obj. Para isso, seria necessário um cast. R4. (e). A função de coleta de lixo do Java (garbage collector) não pode ser forçada. Quando removemos todas as referências a um objeto, ele fica disponível para ser coletado. Chamar System. gc() tem o efeito de apenas sugerir à JVM para executar o garbage collector, mas, novamente, sem garantia. R5. (c). Essa questão aborda conceitos de várias APIs do Java. A API de Reflexão pode ser usada para obter as anotações, modificadores, interfaces, propriedades e classes do código Java, em tempo de execução. Portanto as duas primeiras alternativas são verdadeiras. Sobre o synchronized, esse modificador faz com que o acesso a um método seja feito de forma sincronizada por múltiplas threads – o que acarreta impactos no desempenho caso esse método seja requisitado por várias threads, pois apenas uma poderá executá-lo por vez. É uma boa prática de programação chamar explicitamente os métodos close() de classes como ResultSet e Statement, para que o objeto seja liberado no banco de dados imediatamente – disponibilizando mais memória para a aplicação. É importante que a chamada aos métodos close() seja realizada em blocos finally para garantir sua execução tanto em caso de execução bem-sucedida quanto em casos de exceção. A alternativa (c) é descabida, pois associar o modificador final a um método apenas indica que ele não pode ser sobrescrito por uma subclasse, e de fato isso pode melhorar o desempenho pelo compilador ao gerar os bytecodes correspondentes – mas essa pequena otimização não chegará nem perto dos 50% sugeridos. Como bons desenvolvedores, devemos focar em escrever código legível e que faça sentido em nosso projeto orientado a objetos (lembre da frase: “otimização prematura é a raiz de todo o mal”). Portanto, neste caso, devemos marcar um método como final apenas se, de fato, queremos que ele não seja sobrescrito por subclasses (esse pode ser o caso numa implementação do padrão Template Method, por exemplo). Vale a pena estudar bastante as principais funcionalidades da API de Reflexão do Java. É um assunto que tem aparecido nos concursos e que também é bastante usado em diversos frameworks do mercado. R6. (b). O container web gerencia o ciclo de vida de servlets e páginas JSPs, mas não EJBs, que exigem um container específico. EJBs executam no lado do servidor. Hibernate é um framework de persistência que perfaz o mapeamento objeto-relacional, e não o Struts (este é um framework para desenvolvimento web MVC). E a Java Persistent API não exige o uso do container EJB. Ela só exige um provedor que implemente suas interfaces (por exemplo: Hibernate, TopLink etc.) e, portanto, pode ser usada também num ambiente desktop. R7. (e) persistência. O armazenamento e recuperação de dados é tarefa para a camada de persistência, que pode utilizar o Hibernate para o mapeamento objeto-relacional (entidades de domínio para tabelas relacionais). É uma boa ideia utilizar a Java Persistence API (JPA) para mapeamento objeto-relacional em nossas aplicações Java em vez de utilizar diretamente o Hibernate. R8. (d) A ideia do facade é prover uma interface simplificada para acessar um sub-sistema mais complexo. É bastante usado (e, muitas vezes, abusado) por desenvolvedores para criar uma camada de serviço ou aplicação em sistemas web. Prototype é um padrão para criação de objetos; Decorator é um padrão para extensão dinâmica de funcionalidades de um objeto; Observer é um padrão para notificação e implementação de eventos entre objetos; e Flyweight é um padrão para compartilhamento de objetos e otimização de uso da memória. É importantíssimo que você, como bom desenvolvedor, conheça bem os principais padrões de projeto. Isso o ajudará a ler código escrito por outros, projetar novas soluções e se comunicar melhor com seus colegas. Aprenda, pelo menos, os padrões de projeto descritos no livro da gangue dos quatro (GoF) e os padrões arquiteturais de aplicações corporativas do Martin Fowler (ver referências). R9. (b). Service Locator. R10. (e) Java é uma tecnologia que agrega uma linguagem de programação, um ambiente de desenvolvimento e APIs próprias. R11. (e) polimorfismo. A capacidade de redefinir um método em subclasses diferentes é chamada de polimorfismo, e é um dos conceitos mais importantes da orientação a objetos. Como a interface da classe pai (ContaBancária) é a mesma para as duas subclasses, o método AplicarJuros() pode ser referenciado sem conhecer o comportamento, detalhes de implementação ou redefinições nas classes filhas. R12. (d). Java não possui o conceito de herança múltipla. Por outro lado, uma classe pode implementar mais de uma interface ao mesmo tempo, e também ser subclasse de outra classe simultaneamente (combinando as cláusulas extends e implements). As exceções que são subclasses da RuntimeException não exigem tratamento pelo programador. Já os objetos da classe String são imutáveis: uma vez criado, o objeto não pode ter o seu valor alterado. A solução para alterar uma String é criar uma nova instância de um objeto, ou então utilizar a classe StringBuilder, que permite que o seu valor seja alterado. R13. (e) I - Esta é a ideia da herança: estender uma superclasse adicionando comportamento específico. A herança expressa um relacionamento do tipo "é um". Por exemplo, Quadrado "é uma" FormaGeometrica. II - Em Java, não existe a configuração de um objeto "default". O que existe é a possibilidade de chamar um método sem especificar um objeto específico se já estivermos no contexto de um objeto (o que equivale a fazer this.umMetodoQualquer() ). III - Corretíssimo. Uma grande desvantagem da herança é a geração de um acoplamento elevado entre as classes (ver dica a seguir). Muitas pessoas utilizam herança apenas com o intuito de reaproveitamento de código. Isso é ruim porque a herança "crava" o comportamento da superclasse nas subclasses e esse comportamento é de difícil substituição. Em outras palavras, há um elevado acoplamento entre as classes da hierarquia, dificultando a manutenibilidade, a flexibilidade e a testabilidade das classes envolvidas. Portanto, quando a intenção for simplesmente reaproveitamento código, analise se não seria melhor utilizar composição (relacionamento do tipo "tem um"). Não é à toa que a maioria dos padrões de projeto favorecem composição à herança. Só mais uma coisa: não se esqueça de utilizar injeção de dependência: seus testes agradecem! (Ver link na seção de referências "Como não aprender orientação a objetos: Herança") IV) Encapsulamento é uma característica essencial em sistemas orientados a objetos. Cuidado com a geração indiscriminada de getters() e setters() sem necessidade nas suas classes de domínio. Em bons sistemas OO, com design orientado a domínio, é importante buscar dar mais responsabilidades a essas classes, e não mover tudo para classes de serviço deixando suas entidades como meras "portadoras de dados". (Ver link na seção de referências "Como não aprender Java e Orientação a Objetos: getters e setters" e "Fantoches") V) Polimorfismo é uma característica básica da orientação a objetos, possibilitando a criação de designs flexíveis por meio da substituição de objetos em tempo e execução. R14. (e) Refatoração é uma técnica disciplinada para alterar a estrutura interna de um código sem modificar o comportamento externo. Isso 47 : : www.mundoj.com.br : : é feito com o objetivo de melhorar o design do código visando acomodar melhor futuras funcionalidades e tornar o código mais fácil de entender e manter. Introduce Parameter Object é uma refatoração que utilizamos quando possuímos um conjunto de parâmetros num método que faz sentido compor um objeto. Neste caso, faz sentido utilizá-lo visando diminuir o número de argumentos de um método (de fato, afirmação da questão está meio ambígua). Substitute Algorithm é uma refatoração que utilizamos quando queremos substituir um trecho de código de um algoritmo por outro trecho de código mais claro. Frequentemente, podemos remover duplicação de código neste processo. Extract method é uma refatoração que utilizamos quando queremos mover um trecho de código comum (provavelmente utilizado em diversos lugares no sistema) para um método e então possivelmente reaproveitá-lo nos diversos lugares. Esta refatoração também é muito usada para mover um pedaço de código para um método cujo nome “explique” o que o código faça. Esta refatoração, juntamente com as refatorações de renomeação, é uma das mais usadas pelos desenvolvedores experientes que se preocupam com a legibilidade e manutenibilidade de código. Refatoração é um assunto que deve ser conhecido por todo desenvolvedor profissional. É um pilar das boas práticas de engenharia ágeis, com destaque especial para o Test-driven Development (TDD). A leitura do livro “Refactoring: Improving the Design of Existing Code”, de Martin Fowler, é fortemente recomendada. R15. I) ERRADO Quando queremos usar uma classe existente, mas a interface da classe não é a de que se precisa usamos o padrão Adapter. O Proxy pode ser implementado usando-se composição e implementação de uma interface comum. QUADRO: o leitor conhecedor de padrões pode reparar que a estrutura de classes dos padrões Adapter, Proxy e Decorator é praticamente a mesma. O que difere um padrão do outro é a intenção que cada um tem. II) ERRADO Uma aplicação pode ter quantos models, views e controllers quantos sejam necessários. Existem frameworks MVC que implementam o padrão FrontController, cuja ideia é ter apenas um controlador (em Java, normalmente implementado como um Servlet), responsável por encaminhar a requisição para o componente adequado. III) ERRADO Os membros declarados private podem ser acessados apenas a partir de código na classe com esses membros. Se não fosse assim, como teríamos encapsulamento? Lembramos que, em Java, variáveis de instância declaradas como 48 protected são acessíveis não só em classes derivadas, mas também em classes contidas no mesmo pacote. Para Saber Mais • “Herança e Composição – os princípios por trás dos padrões”, ed. 39 da MundoJ – Eduardo Guerra • “Refatoração: Melhoria Contínua do Código”, ed. 33 da MundoJ – Eduardo Guerra • Série “Design patterns para um Mundo Real”, eds. 21, 22 e 23 da MundoJ – Rodrigo Yoshima Considerações finais Neste artigo, comentamos um pouco a respeito das vantagens e desvantagens de se trabalhar na iniciativa pública na área de TI. Boas condições de trabalho, estabilidade e salários elevados são características que têm atraído um grande número de profissionais. Trouxemos ainda um simulado com algumas questões extraídas de concursos reais para que o leitor possa se familiarizar com os tipos de assuntos que costumam ser cobrados em muitos dos concursos públicos. Esperamos que o artigo possa ter sido proveitoso para diminuir a visão estereotipada que muitas pessoas possuem com relação à carreira pública na área de TI e que as questões comentadas possam ajudar aqueles que estão se preparando ou apenas pensando na possibilidade de fazer um concurso. Para os que desejam continuar os estudos das tecnologias apresentadas no artigo com o foco em concursos públicos, indicamos como bibliografia adicional o livro recém-lançado "Java e Web para Concursos" (ver quadro)• “Voltei-me, e vi debaixo do sol que não é dos ligeiros a carreira, nem dos fortes a batalha, nem tampouco dos sábios o pão, nem tampouco dos prudentes as riquezas, nem tampouco dos entendidos o favor, mas que o tempo e a oportunidade ocorrem a todos.” (Ec 9:11) Referências • [Handbook de TI]: http://www.handbookdeti.com.br • [Pesquisa da FGV] : http://www1.folha.uol.com.br/folha/dinheiro/ult91u474686. shtml • [Salarios em TI e o setor publico]: http://carreiradeti.com.br/nivel-superior-na-areade-ti-e-salario-de-mais-de-r9500/ • [Ambiente de trabalho] http://www.administradores.com.br/informe-se/informativo/bom-ambiente-de-trabalho-e-cada-vez-mais-valorizado-como-identificalo/15062/ • [Pesquisa do IPEA] http://desafios2.archipelago/003/00301009.jsp?ttCD_ CHAVE=13047 • [Como não aprender orientação a objetos: herança] http://blog.caelum.com. br/2006/10/14/como-nao-aprender-orientacao-a-objetos-heranca/ • [Como não aprender orientação a objetos: getters e setters] http://blog.caelum. com.br/2006/09/14/nao-aprender-oo-getters-e-setters/ • http://www.fragmental.com.br/wiki/index.php/Fantoches • [Resumo dos padrões de projeto GoF] http://www.dofactory.com/Patterns/Patterns. aspx • Design Patterns: Elements of Reusable Object-Oriented Software • Patterns of Enterprise Application Architecture • Refactoring: Improving the Design of Existing Code Livro: Java e Web para Concursos A proposta do livro é apresentar de maneira objetiva o conteúdo específico para a realização dos exames – focados em tecnologias relacionadas à Web, Orientação a Objetos, plataforma Java e JEE (JSP, Servlets, JSF, JPA), frameworks Web, Padrões de Projeto e Web Services. Além disso, são oferecidas mais de 300 questões de concursos públicos relativas ao conteúdo apresentado, que foram organizadas entre os exercícios dos capítulos e os simulados no final. Prepare-se para as provas do Bacen, Bndes, Petrobras, IBGE, Serpro, MPU, Eletrobras e muitas outras. Mais informações e seções do livro disponíveis para download encontram-se no site do autor: www.rbper.com Depoimentos Depoimento I José Roberto: tem 22 anos de experiência na área de informática. Formado em Tecnologia de Processamento de Dados pela PUC-RJ e em Administração de Empresas pela UERJ, possui pós-graduação lato-sensu em Gestão Estratégica de Informação pela UFRJ e em Gestão Estratégica de Negócios pela Fundação Dom Cabral. É mestre em Informática pela UFRJ e já ministrou disciplinas relacionadas a gerenciamento de projetos em cursos de pós-graduação (MBA) na UFRJ e na Universidade Estácio de Sá. Trabalhou na Dataprev e Vale como analista de sistemas e coordenador de projetos. No Banco Central, vem atuando na Administração do Selic coordenando equipes de infraestrutura (banco de dados, segurança e servidores de aplicação). Atualmente participa da formação da equipe de segurança de TI para o Selic. Ingressei no Banco Central em 1997 por meio de um concurso específico pra área de informática. Na ocasião, não havia sequer a diferença entre TI e desenvolvimento. Ou seja, a matéria era simplesmente... tudo !! Confesso que foi exatamente aí uma das razões para o meu sucesso, por conta do meu perfil generalista. Credito a minha aprovação também ao fato de ter concluído em 1997 um MBA em Gestão Estratégica de TI, que me proporcionou um conhecimento bastante amplo acerca de várias disciplinas (inclusive administrativas – Matemática Financeira, Contabilidade, Economia, Administração) cobradas no concurso. Eu fui testemunha de um grande salto de qualidade na instituição. Em janeiro de 1998, quando tomei posse no BC depois de ter me desligado da Vale (na época ainda conhecida por Companhia Vale do Rio Doce) tive a sensação de entrar numa organização no mínimo 10 anos atrasada em relação aos processos com os quais convivia. O nível tecnológico era muito baixo e havia uma defasagem muito grande em relação ao que se fazia na iniciativa privada. Durante a década que se iniciou no ano 2000 e, mais efetivamente, com o projeto SPB (Sistema de Pagamento Brasileiro), o Banco Central passou a tirar essa diferença de forma galopante. Atualmente, trabalhamos no Bacen com tecnologia de ponta, processos de trabalho modernos e uma qualificação muito alta dos servidores. Mesmo se tratando de uma instituição heterogênea (algumas áreas ainda trabalham com processos mais antigos), de um modo geral, a instituição trabalhou bem a manutenção do seu grau de excelência. Eu classifico essa mudança como essencial no serviço público para podermos encarar os desafios que estão pela frente. A sociedade brasileira vem amadurecendo seus conceitos de cidadania e de cobrança por serviços de qualidade das instituições públicas. Para encarar esse desafio a qualificação do servidor precisa estar associada à motivação para o trabalho e, principalmente, ao sentido do verbo “servir”, muitas vezes esquecido pela classe política. Depoimento II Vinci Amorim ([email protected]): é Analista Executivo do Inmetro, arquiteto de Soluções. Bacharel em Ciência da Computação pela UFV e mestre em Informática pela PUC-Rio. Possui certificações Java e experiência de 9 anos em projetos para Petrobras, Vale e Oi, em atividades de requisitos, arquitetura, desenvolvimento e gerência de projetos. Trabalhar no Inmetro está sendo para mim uma experiência ímpar. Por um lado, enormes desafios típicos de órgãos públicos, em especial devido a tempo de realização de licitações e concursos, e todas as consequências imagináveis causadas por décadas de má gestão pública devido a administradores sem competência técnica e administrativa. Por outro lado, uma enorme vontade, especialmente dos novos servidores de implantar as boas práticas já consagradas na iniciativa privada, como BSC, Gestão por Processos, Gestão por Competências, Avaliação de Desempenho etc. Ainda falta um grande caminho a percorrer rumo ao desenvolvimento. Mas pelo menos já estamos na direção certa. Na área de TI o TCU está realizando um ótimo trabalho no sentido de orientar os órgãos quanto à adoção de modelos de Governança de TI como Cobit, ITIL, CMMI, PMBoK. E também no sentido de que os servidores públicos atuem em atividades de gestão, estratégias, diretrizes e fiscalização. E sugere que as atividades operacionais sejam terceirizadas. Como arquiteto de Soluções tenho a oportunidade de colaborar na definição de metodologias, boas práticas, processos de TI, avaliação de tecnologias e ferramentas corporativas. Além de atuar com coaching, testes e soluções de integração. Ou seja, minha experiência no Inmetro é de trabalho árduo e bastante desafiante. Estou aprendendo muito. Para passar num concurso o principal é resolver muitas questões, especialmente as comentadas. E para os assuntos pouco vistos em faculdade como Governança de TI e Segurança da Informação recomendo realizar cursos como os da TI. Exames. 49