Swebok

Fazer download em pdf ou txt
Fazer download em pdf ou txt
Você está na página 1de 16

ENGENHARIA

DE SOFTWARE

Adriana de SouzaVettorazzo
Software Engineering Body
of Knowledge (SWEBOK)
Objetivos de aprendizagem
Ao final deste texto, você deve apresentar os seguintes aprendizados:

„„ Descrever o guia SWEBOK e seus objetivos.


„„ Categorizar as áreas de conhecimento do SWEBOK.
„„ Explicar as modalidades de certificação sobre o SWEBOK.

Introdução
Com o aumento da demanda pelo desenvolvimento de software, em
decorrência do crescente número de aplicativos disponíveis em disposi-
tivos móveis, surgiu também a necessidade de padronização e métodos
para melhorar a qualidade desses software. Nesse sentido, foi elaborado
o Software Engineering Body of Knowledge (SWEBOK), um guia de uso e
aplicação das melhores práticas de engenharia de software.
O SWEBOK foi desenvolvido a partir de boas práticas coletadas ao
longo de décadas em vários países. Seu principal objetivo é divulgar um
conjunto de práticas, ferramentas e técnicas para o desenvolvimento de
atividades de engenharia de software.
Assim, neste capítulo, você vai estudar o SWEBOK, compreendendo
quais são seus objetivos e suas áreas de conhecimento. Por fim, você vai
verificar quais são as modalidades de certificação profissional relacionadas
a esse guia.

1 Projeto SWEBOK
Segundo Pressman e Maxim (2016), a engenharia de software é uma dis-
ciplina que reúne um conjunto de métodos, processos e ferramentas para o
desenvolvimento de software, com processos que podem ser utilizados em
todo o ciclo de vida de um projeto de software. Nesse contexto, o Instituto de

Identificação interna do documento 5UVZ0Q6SJ5-BDUBFU1


2 Software Engineering Body of Knowledge (SWEBOK)

Engenheiros Eletricistas e Eletrônicos (IEEE, do inglês Institute of Electrical


and Electronics Engineers) é responsável pelo projeto do SWEBOK, que
atualmente está em sua terceira versão e é disponibilizado de forma gratuita
no website da IEEE Computer Society (BOURQUE; FAIRLEY, 2014). O
SWEBOK tem o objetivo de auxiliar as organizações que trabalham com
desenvolvimento de sistemas a terem uma visão mais consistente sobre o
processo de desenvolvimento de software.
O principal objetivo do guia SWEBOK é descrever o conhecimento rela-
cionado à área da engenharia de software. O guia também é conhecido como
Relatório Técnico 19759 da Organização Internacional de Normalização
(ISO, do inglês International Organization for Standardization) e da Comissão
Eletrotécnica Internacional (IEC, do inglês International Electrotechnical
Commission). Além disso, segundo a IEEE (c2020, tradução nossa), o guia
SWEBOK:

„„ apresenta e descreve as características relacionadas ao conteúdo da


engenharia de software;
„„ promove uma visão consistente de como a engenharia de software é
vista e utilizada no âmbito mundial;
„„ esclarece e delimita as fronteiras entre a engenharia de software e as
outras disciplinas relacionadas (ciência da computação, gerência de
projetos, engenharia da computação, matemática, entre outras);
„„ disponibiliza material de apoio para o autoaprendizado e a certificação
individual de engenheiros de software.

A versão 3 do SWEBOK, lançada em 2014, é composta por 15 áreas de


conhecimento, também conhecidas por knowledge areas. São elas:

1. Requisitos de software
2. Design de software
3. Construção de software
4. Teste de software
5. Manutenção de software
6. Gerência de configuração de software
7. Gerência de engenharia de software
8. Processo de engenharia de software
9. Modelos e métodos de engenharia de software
10. Qualidade de software
11. Prática em engenharia de software profissional

Identificação interna do documento 5UVZ0Q6SJ5-BDUBFU1


Software Engineering Body of Knowledge (SWEBOK) 3

12. Economia em engenharia de software


13. Fundamentos da computação
14. Fundamentos matemáticos
15. Fundamentos da engenharia

A seguir, vamos explicar cada uma das 15 áreas.

1 Requisitos de software
Os requisitos correspondem às necessidades e restrições do produto de soft-
ware e ajudam nas soluções e nos problemas do mundo real. Nessa área, temos
a elicitação, a análise, as especificações e a validação dos requisitos funcionais
e não funcionais. Nos projetos de software, na maioria das vezes, as principais
falhas ocorrem devido às dificuldades em se entender as necessidades do
usuário. Por isso, fazer um bom levantamento de requisitos é extremamente
importante. O SWEBOK apresenta alguns pontos relacionados à área de
requisitos de software, descritos a seguir.

„„ Fundamentos dos requisitos de software: requisitos são propriedades que


devem espelhar o mundo real com o intuito de resolver um problema.
Requisitos podem ser de produto ou de processo, funcionais ou não
funcionais, e de sistema ou de software. Também podem apresentar pro-
priedades emergentes. Precisam ser, preferencialmente, quantificáveis.
„„ Processo de requisitos: essa área inclui o planejamento de requisitos,
mostrando como os processos de requisitos vão integrar-se com os
processos de software. Nessa fase, são discutidos os modelos e atores de
processo. Também é definido como serão o suporte e o gerenciamento
de processos, além dos processos que visam à qualidade e à melhoria
de processos.
„„ Elicitação de requisitos: essa área visa a efetuar a captura e a aquisi-
ção dos requisitos de software, identificando as fontes dos requisitos.
Nessa fase, é importante definir as fontes de requisitos e as técnicas
de elicitação.
„„ Análise de requisitos: a análise é a responsável por fazer a ligação entre
a alocação de software em nível de sistema e o projeto de software, aju-
dando o engenheiro a aprimorar e construir modelos. Segundo Pressman
e Maxim (2016, p. 122), “[...] se você não analisa, é altamente provável
que construa uma solução de software muito elegante que resolve o
problema errado”. Nessa fase, são feitas a classificação e a modelagem

Identificação interna do documento 5UVZ0Q6SJ5-BDUBFU1


4 Software Engineering Body of Knowledge (SWEBOK)

conceitual de requisitos, o projeto arquitetural e a alocação de requisitos,


a negociação de requisitos entre o time de desenvolvimento e o cliente
e, por fim, a análise formal.
„„ Especificação de requisitos: compreende a atribuição de valores nu-
méricos para os objetivos do projeto, e a atividade principal dessa área
é a documentação do sistema. Nessa fase, é feita a documentação de
definição do sistema, a especificação dos requisitos de sistema e a
especificação dos requisitos de software.
„„ Validação de requisitos: a documentação levantada na especificação
de requisitos pode ser utilizada para a validação da conformidade com
os padrões da organização. Essa fase visa a enumerar os problemas
encontrados e inclui a revisão de requisitos, a prototipação, a validação
de modelos e os testes de aceitação.
„„ Considerações práticas: aqui são descritos tópicos para serem com-
preendidos na prática e, ao mesmo tempo, para validar os atributos e
o tamanho das alterações nos requisitos e fazer a estimativa de custo
para o desenvolvimento e a manutenção
„„ Ferramentas para requisitos de software: usualmente suportam diversas
atividades, como documentação, rastreamento e gerenciamento da
mudança. Há duas principais categorias: ferramentas para modelagem
e ferramentas para o gerenciamento de requisitos.

2 Design de software
A área do design, ou projeto, de software está relacionada ao ciclo de vida
do projeto, em que são feitas a análise dos requisitos e a descrição da estru-
tura interna do software. Aqui, definem-se a arquitetura, os componentes,
as relações e outras características do sistema. Essa área é apresentada com
a estrutura descrita a seguir.

„„ Fundamentos do projeto de software: discute os conceitos gerais rela-


cionados à arquitetura do software, como o contexto, o processo e os
princípios fundamentais em design de software.
„„ Questões-chave em design de software: nessa fase, são discutidas ques-
tões relacionadas à arquitetura, como concorrência, controle de eventos,
persistência de dados e segurança.
„„ Estrutura e arquitetura de software: apresenta estruturas e estilos ar-
quiteturais e padrões, discute as decisões de arquitetura e apresenta
conjuntos de programas e frameworks.

Identificação interna do documento 5UVZ0Q6SJ5-BDUBFU1


Software Engineering Body of Knowledge (SWEBOK) 5

„„ Projeto da interface com o usuário: discursa sobre questões relacionadas


a princípios, problemas, modalidades, formas de apresentação e outros
tópicos relacionados à experiência do usuário com o sistema.
„„ Análise e avaliação de qualidade do projeto de software: discute os
atributos de qualidade, a análise, as métricas e as técnicas de avaliação
de design de software.
„„ Notações do projeto de software: diferencia descrições estruturais
(visualizações estáticas) e descrições comportamentais (visualizações
dinâmicas).
„„ Estratégias e métodos para o projeto de software: apresenta as principais
estratégias voltadas ao design de software, como orientada a função,
orientada a objeto, centrada nos dados ou baseada em componentes,
entre outras.
„„ Ferramentas para o projeto de software: podem ser utilizadas como
apoio para a criação do artefato de software. Usualmente, possibilitam as
atividades de traduzir o modelo de requisitos em uma representação de
projeto, além de apoiar a representação da interface e dos componentes
funcionais, entre outras atividades.

3 Construção de software
Essa área integra as demais áreas de conhecimento do guia SWEBOK, mas se
destaca um relacionamento maior com o projeto e os testes de software. Estão
inseridas aqui as atividades de implementação, verificação, testes de unidade e
teste de integração e depuração. Essa seção trata dos pontos descritos a seguir.

„„ Fundamentos da construção: apresenta técnicas para ajudar a reduzir a


complexidade e antecipar necessidades de mudança, verificação, reúso
e outros padrões relacionados.
„„ Gerenciamento da construção: introduz os modelos de ciclo de vida,
o planejamento e as métricas relacionadas à construção de software.
„„ Considerações práticas: trata de questões como o design da construção,
as linguagens, a codificação, a qualidade na construção, a integração,
entre outros tópicos relacionados.
„„ Tecnologias para construção: apresenta diversos conceitos relacionados
a tecnologias para o desenvolvimento de software, como projeto e uso
de interfaces de programação de aplicações, padrões de plataforma,
modelos executáveis, middleware etc.

Identificação interna do documento 5UVZ0Q6SJ5-BDUBFU1


6 Software Engineering Body of Knowledge (SWEBOK)

„„ Ferramentas para a construção de software: apoiam o desenvolvimento


do software em si por meio dos ambientes de desenvolvimento, dos
construtores de interface gráfica, das ferramentas para teste unitário
e das ferramentas para análise de desempenho.

4 Teste de software
Segundo o SWEBOK (BOURQUE; FAIRLEY, 2014), o teste de software é
uma atividade realizada para a avaliação da qualidade do produto, efetuando
sua melhoria por meio da identificação de defeitos e problemas. Aqui, é feita
a verificação do comportamento do software a partir de casos de testes, para
verificar se o comportamento está dentro do esperado. A área de testes de
software inclui as subáreas descritas a seguir.

„„ Fundamentos de teste de software: introduz terminologias e problemas-


-chave e fala do relacionamento de testes de software com outras áreas
do conhecimento.
„„ Níveis de teste: discute a importância de definir bem o alvo e os ob-
jetivos do teste.
„„ Técnicas de testes: apresenta as técnicas mais utilizadas, como a téc-
nica baseada na intuição e experiência do engenheiro de software,
a baseada no código e a baseada em falhas, e discute como selecionar
e/ou combinar as técnicas mais adequadas de acordo com o contexto.
„„ Métricas relacionadas aos testes: trata especificamente de duas ava-
liações, a avaliação do programa que está sendo testado e a avaliação
dos testes que foram executados.
„„ Processo de testes: fala das aplicações práticas relacionadas às ativi-
dades de testes.
„„ Ferramentas para o teste de software: inclui ferramentas para a criação
de drivers e stubs, para a geração de casos de teste, para a captura e
repetição de erros, para testes de regressão, entre outras.

5 Manutenção de software
Essa área tem como foco principal dar suporte ao produto no ciclo de vida
operacional. Esse suporte efetivo pode ser fornecido antes ou depois da
entrega ao cliente: antes, desenvolvendo atividades de planejamento; depois,
nas codificações para corrigir as falhas e melhorar o desempenho. De forma

Identificação interna do documento 5UVZ0Q6SJ5-BDUBFU1


Software Engineering Body of Knowledge (SWEBOK) 7

geral, as manutenções de software podem ser corretivas, adaptativas, perfec-


tivas ou preventivas.
Na manutenção corretiva, o software é modificado para corrigir os er-
ros encontrados. Na manutenção adaptativa, o software é alterado para se
adaptar às mudanças do ambiente externo. Já na manutenção perfectiva,
o software é aprimorado conforme solicitação do cliente. Por fim, na ma-
nutenção preventiva, o software é modificado para facilitar as correções,
adaptações e melhorias.
A área de manutenção é apresentada conforme as subáreas apresentadas
a seguir.

„„ Fundamentos de manutenção de software: introduz a terminologia


relacionada à manutenção de software, à natureza da manutenção,
à sua necessidade, além de categorias, custos etc.
„„ Questões-chave em manutenção de software: discute questões técnicas,
gerenciais e relacionadas à estimativa de custos da manutenção.
„„ Processo de manutenção: especifica as práticas mais comuns relacio-
nadas a processos e atividades de manutenção.
„„ Técnicas para a manutenção: apresenta técnicas como reengenharia,
engenharia reversa e migração.
„„ Ferramentas para a manutenção de software: ferramentas que são uti-
lizadas quando o software está sendo modificado, como ferramentas
que verificam a dependência entre trechos de código-fonte.

6 Gerência da configuração de software (GCS)


Essa é a área que tem por finalidade controlar as versões do software durante
o desenvolvimento do projeto e apresenta as atividades descritas a seguir.

„„ Gerenciamento do processo de GCS: discute o contexto organizacional,


as restrições e guias para o processo de GCS, o planejamento, o plano
e a sobrevivência de sistemas de GCS.
„„ Identificação da configuração do software: apresenta os itens a serem
controlados e as bibliotecas de software.
„„ Controle da configuração do software: fala sobre requisições, avalia-
ções e aprovação de mudanças, sobre implementação de mudanças nos
software e sobre desvios e desistências.
„„ Controle do status de configuração de software: apresenta a importância
da informação e do relatório de status do software de configuração.

Identificação interna do documento 5UVZ0Q6SJ5-BDUBFU1


8 Software Engineering Body of Knowledge (SWEBOK)

„„ Auditoria da configuração de software: discute a auditoria funcional


e física.
„„ Gerenciamento e entrega das releases do software: discute as entregas
de software e o versionamento.
„„ Ferramentas para a GCS: incluem ferramentas para a identificação,
o empacotamento e a entrega do produto de software. Ferramentas nessa
categoria incluem ferramentas de controle de versão e de controle de
mudanças. Um exemplo muito utilizado é o GitHub (c2020), uma das
ferramentas de versionamento de software mais utilizadas no mundo,
que hospeda mais de 100 milhões de repositórios de código-fonte con-
tendo as mais diferentes linguagens de programação.

7 Gerência da engenharia de software


Esta área se destina às atividades de gerenciamento do projeto de software,
como planejamento, coordenação, medição, monitoração, controle e docu-
mentação, a fim de garantir software de qualidade. O projeto é algo com
início, meio e fim, ou seja, é temporário e tem o objetivo de criar um produto
ou um serviço.
Segundo Pressman e Maxim (2016), a gestão do projeto engloba o planeja-
mento, a monitoração e o controle de todos os eventos que acontecem durante
o processo de desenvolvimento do software. O gerenciamento da engenharia
de software é dividido conforme descrito a seguir.

„„ Iniciação e definição do escopo: inclui a determinação e negociação


dos requisitos, a análise de viabilidade e a discussão do processo para
revisão de requisitos.
„„ Planejamento do projeto de software: trata do planejamento, da de-
terminação dos entregáveis do projeto, das estimativas de esforço,
do cronograma e custo, da alocação de recursos, da gerência de riscos,
da gerência da qualidade e da gerência do plano do projeto.
„„ Declaração do projeto de software: inicia a implementação do plano
definido na etapa anterior. Trata da aquisição de recursos, da imple-
mentação de métricas de processo, do monitoramento, do controle e
dos relatórios do progresso.
„„ Revisão e avaliação: determina a satisfação dos requisitos e revisa e
avalia o desempenho.
„„ Encerramento: determina o fechamento do projeto e encerra as
atividades.

Identificação interna do documento 5UVZ0Q6SJ5-BDUBFU1


Software Engineering Body of Knowledge (SWEBOK) 9

„„ Métricas de desempenho em engenharia de software: estabelece e


mantém um comprometimento com as medições, planeja e executa os
processos de medição e, por fim, avalia as medições.
„„ Ferramentas para o gerenciamento da engenharia de software: facilitam
a visibilidade e o controle do software em desenvolvimento. Incluem
ferramentas para planejamento e rastreabilidade do projeto, para ge-
renciamento de riscos, para facilitar a comunicação e para cálculo das
métricas.

8 Processo de engenharia de software


Compreende um conjunto de atividades que facilitam a transformação de ideias
abstratas em projetos de software. É composto pelas subáreas descritas a seguir.

„„ Definição do processo de software: definições gerenciais e arquiteturais.


„„ Ciclo de vida do software: apresenta categorias, modelos, adaptação
de processos e outras considerações práticas.
„„ Avaliação e melhoria do processo de software: trata sobre os modelos
e métricas relacionados à avaliação e sobre os modelos relacionados à
melhoria do processo de software.
„„ Métricas de software: métricas relacionadas a processo e produto,
à qualidade dos resultados mensurados, aos modelos de informação de
software e às técnicas para identificar métricas de processo de software.
„„ Ferramentas para o processo de engenharia de software: inclui ferra-
mentas para desenho de fluxos, diagramas, mapeamento das atividades,
painel de controle, dashboard etc.

9 Modelos e métodos de engenharia de software


Nessa área, são pesquisados modelos e métodos que aumentem a produtividade,
auxiliando no ciclo de vida do software. Essas ferramentas automatizam ativi-
dades do processo, liberando o analista para se concentrar nas atividades que
exigem esforço intelectual. Essa área se divide nas subáreas descritas a seguir.

„„ Modelagem: introduz os princípios da modelagem, as propriedades e a


expressão dos modelos, contextualiza sintaxe, semântica e pragmática,
além de pré-condições, pós-condições e invariantes.

Identificação interna do documento 5UVZ0Q6SJ5-BDUBFU1


10 Software Engineering Body of Knowledge (SWEBOK)

„„ Tipos de modelos: discute os modelos informacional, comportamental


e estrutural.
„„ Análise de modelos: discursa sobre a completeza, a consistência,
a correção, a rastreabilidade e a análise de interação dos modelos.
„„ Métodos de engenharia de software: discute os métodos heurístico,
formal, por protótipo e ágeis.

10 Qualidade de software
Para falar de qualidade, é necessário observar vários aspectos relacionados
ao produto, como desenvolvimento, manutenção e uso. Melhorar a qualidade
é um dos principais objetivos da engenharia de software, e isso é possível a
partir da utilização de métodos e tecnologias.
Empresas que trabalham a melhoria da qualidade geralmente utilizam
modelos como Capability Maturity Model Integration ou normas técnicas como
a ISO/IEC 9126. Essas empresas podem pleitear a certificação como forma de
garantir aos seus clientes que elas desenvolvem e entregam produtos com maior
qualidade. A qualidade de software se divide nas subáreas descritas a seguir.

„„ Fundamentos da qualidade de software: discute o impacto da cultura


e da ética na qualidade de software, a relação de valor versus custo na
qualidade, as características de modelos, a melhoria na qualidade do
software e a segurança de sistemas.
„„ Processos de gerência da qualidade de software: apresenta os concei-
tos relacionados à garantia da qualidade, à verificação, à validação,
às revisões e à auditoria da qualidade do software.
„„ Considerações práticas: fala sobre os requisitos de qualidade, introduz a
caracterização de defeito, apresenta técnicas para a gerência da qualidade
do software e discursa sobre as métricas de qualidade no software.
„„ Ferramentas para o processo de qualidade de software: inclui ferramen-
tas de análise estática e dinâmica para analisar a qualidade do software.

As primeiras 10 áreas de conhecimento, discutidas até então, tratam espe-


cificamente de conteúdo diretamente relacionado ao produto e ao processo de
software. As próximas cinco áreas a serem apresentadas também são bastante
relevantes para a engenharia de software, pois tratam de conceitos relacionados
e fundamentais à prática da engenharia de software.

Identificação interna do documento 5UVZ0Q6SJ5-BDUBFU1


Software Engineering Body of Knowledge (SWEBOK) 11

11 Prática profissional em engenharia de software


Esta área apresenta os conhecimentos, as habilidades e as atitudes necessárias
a um indivíduo que trabalha com engenharia de software. Discursa sobre
questões como o profissionalismo e o uso de dinâmicas de grupo e psicologia
e fala da importância das habilidades de comunicação.

12 Economia em engenharia de software


Aborda o contexto econômico da engenharia de software pela perspectiva de
negócios, com bastante ênfase no custo para o desenvolvimento de um projeto
de software. Nessa área, são apresentados os fundamentos de economia em
engenharia de software. Também se discute o ciclo de vida da economia,
os riscos e as incertezas, os métodos de análise econômica e, por fim, as con-
siderações práticas em relação ao aspecto econômico para o desenvolvimento
de sistemas.

13 Fundamentos de computação
Na área de conhecimento sobre os fundamentos de computação, são aborda-
dos conceitos fundamentais relacionados à ciência da computação, como as
principais técnicas para resolução de problemas, a abstração, os fundamentos
de programação, as ferramentas e técnicas para debugação, as noções básicas
sobre linguagem de programação, os fatores humanos etc.

14 Fundamentos matemáticos
Apresenta conceitos matemáticos importantes para facilitar a abstração de
engenheiros de software ao trabalhar com um problema computacional baseado
em matemática, como a teoria dos conjuntos, as relações e funções, a lógica
básica, os grafos e árvores, a teoria dos números, as estruturas algébricas,
entre outros.

15 Fundamentos de engenharia
Entre as técnicas e os métodos de engenharia que podem ser aplicadas à
engenharia de software, podemos citar: métodos empíricos e técnicas experi-
mentais, análise estatística, métricas, modelagem, simulação e prototipagem,
análise de causa raiz, entre outras.

Identificação interna do documento 5UVZ0Q6SJ5-BDUBFU1


12 Software Engineering Body of Knowledge (SWEBOK)

2 Certificações SWEBOK
O mercado de tecnologia da informação vem desenvolvendo-se e tornando-se
cada vez mais competitivo no que diz respeito a novas tecnologias e também aos
serviços prestados. Adotar modelos e padrões de qualidade ajuda as empresas
a se diferenciarem das demais, pois, com isso, demostram maior organização
e preocupação quanto aos produtos desenvolvidos. A IEEE disponibiliza três
tipos de certificação relacionadas ao SWEBOK, descritas a seguir.

„„ Associate Software Developer — Certificação de Desenvolvedor de Soft-


ware Associado: para esta certificação, os candidatos devem comprovar
que possuem os requisitos básicos de conhecimento relacionados ao
desenvolvimento de produtos de software. O candidato deve demonstrar
conhecimento sobre os princípios e processos relacionados às áreas de
requisitos, design, construção e teste de software.
■■ Não há pré-requisitos para esta certificação, embora seja essencial
o estudo do SWEBOK.
■■ O exame é on-line, dura 100 minutos e é composto por 80 questões.
„„ Professional Software Developer — Certificação para Desenvolvedor
de Software Profissional: o candidato a esta modalidade deve apresen-
tar proficiência como desenvolvedor de software nas mesmas quatro
áreas de conhecimento básicas (requisitos, design, construção e teste
de software).
■■ Não há pré-requisitos para esta certificação, embora seja essencial
o estudo do SWEBOK. Ainda, é recomendado um mínimo de dois
anos de educação superior em Ciência da Computação ou equivalente,
além de dois anos de experiência na indústria de software.
■■ O exame é on-line, dura três horas e é composto por 160 questões.
„„ Professional Software Engineering Master — Mestre Profissional em
Engenharia de Software: esta é a certificação mais completa e mais
complexa. O candidato deverá comprovar maestria em 11 áreas de
conhecimento do SWEBOK: requisitos, design, construção, teste, ma-
nutenção, gerência de configuração, gerência da engenharia de software,
modelos e métodos, qualidade e economia em engenharia de software.
■■ Não há pré-requisitos para esta certificação, embora seja essencial o
estudo do SWEBOK. Ainda, é recomendado um mínimo de quatro
anos de educação superior em Ciência da Computação ou equivalente,
além de quatro anos de experiência na indústria de software.
■■ O exame é on-line, dura três horas e é composto por 160 questões.

Identificação interna do documento 5UVZ0Q6SJ5-BDUBFU1


Software Engineering Body of Knowledge (SWEBOK) 13

As certificações do desenvolvedor de software associado da IEEE Computer Society


são projetadas para avaliar e validar o conhecimento de engenharia de software e as
habilidades de desenvolvimento. A avaliação reúne várias áreas de conhecimento
inter-relacionadas, para avaliar a capacidade de um candidato em compreender os
conceitos, integrar várias áreas de conhecimento e aplicá-las na prática. Para saber
sobre valores e inscrição, acesse o site da IEEE (IEEE, c2020).

BOURQUE, P.; FAIRLEY, R. E. (ed.). SWEBOK v3. 0: Guide to the software engineering body
of knowledge. Washington: IEEE Computer Society, 2014.
GITHUB, c2020. Disponível em: https://github.com/about. Acesso em: 22 out. 2020.
IEEE COMPUTER SOCIETY. Software Engineering Body of Knowledge (SWEBOK), c2020.
Disponível em: https://www.computer.org/education/bodies-of-knowledge/software-
-engineering. Acesso em: 22 out. 2020.
PRESSMAN, R. S.; MAXIM, B. R. Engenharia de software uma abordagem profissional.
8. ed. Porto Alegre: Bookman, 2016.

Leitura recomendada
SOMMERVILLE, I.; SOMMERVILLE, I. Engenharia de software. 9. ed. São Paulo: Pearson, 2011.

Os links para sites da web fornecidos neste capítulo foram todos testados, e seu fun-
cionamento foi comprovado no momento da publicação do material. No entanto, a
rede é extremamente dinâmica; suas páginas estão constantemente mudando de
local e conteúdo. Assim, os editores declaram não ter qualquer responsabilidade
sobre qualidade, precisão ou integralidade das informações referidas em tais links.

Identificação interna do documento 5UVZ0Q6SJ5-BDUBFU1

Você também pode gostar