소프트웨어 엔지니어링-퀵 가이드
먼저 소프트웨어 엔지니어링이 무엇을 의미하는지 이해합시다. 이 용어는 소프트웨어와 엔지니어링의 두 단어로 구성됩니다.
Software 단순한 프로그램 코드 이상입니다. 프로그램은 일부 계산 목적을 제공하는 실행 가능한 코드입니다. 소프트웨어는 실행 가능한 프로그래밍 코드, 관련 라이브러리 및 문서의 모음으로 간주됩니다. 특정 요구 사항을 위해 만들어진 소프트웨어가 호출 될 때software product.
Engineering 반면에 잘 정의 된 과학적 원칙과 방법을 사용하여 제품을 개발하는 것입니다.
Software engineering잘 정의 된 과학적 원리, 방법 및 절차를 사용하여 소프트웨어 제품 개발과 관련된 엔지니어링 분야입니다. 소프트웨어 엔지니어링의 결과는 효율적이고 안정적인 소프트웨어 제품입니다.
정의
IEEE는 소프트웨어 엔지니어링을 다음과 같이 정의합니다.
(1) 소프트웨어의 개발, 운영 및 유지 보수에 대한 체계적이고, 규율 적이며, 정량화 가능한 접근 방식의 적용; 즉, 엔지니어링을 소프트웨어에 적용하는 것입니다.
(2) 위의 진술에서와 같은 접근법의 연구.
독일의 컴퓨터 과학자 인 Fritz Bauer는 소프트웨어 엔지니어링을 다음과 같이 정의합니다.
소프트웨어 엔지니어링은 경제적으로 신뢰할 수 있고 실제 기계에서 효율적으로 작동하는 소프트웨어를 얻기 위해 건전한 엔지니어링 원칙을 수립하고 사용하는 것입니다.
소프트웨어 진화
소프트웨어 엔지니어링 원리와 방법을 사용하여 소프트웨어 제품을 개발하는 프로세스를 software evolution. 여기에는 예상되는 요구 사항을 충족하는 원하는 소프트웨어 제품이 개발 될 때까지 소프트웨어의 초기 개발과 유지 관리 및 업데이트가 포함됩니다.
진화는 요구 사항 수집 프로세스에서 시작됩니다. 그런 다음 개발자는 의도 한 소프트웨어의 프로토 타입을 만들고 소프트웨어 제품 개발의 초기 단계에서 피드백을받을 수 있도록 사용자에게 보여줍니다. 사용자는 여러 연속 업데이트 및 유지 관리도 계속 변경되는 변경 사항을 제안합니다. 이 프로세스는 원하는 소프트웨어가 완성 될 때까지 원래 소프트웨어로 변경됩니다.
사용자가 원하는 소프트웨어를 손에 넣은 후에도 발전하는 기술과 변화하는 요구 사항으로 인해 소프트웨어 제품이 그에 따라 변경됩니다. 소프트웨어를 처음부터 다시 만들고 요구 사항에 따라 일대일로 진행하는 것은 불가능합니다. 실행 가능하고 경제적 인 유일한 솔루션은 최신 요구 사항과 일치하도록 기존 소프트웨어를 업데이트하는 것입니다.
소프트웨어 진화 법칙
Lehman은 소프트웨어 진화에 대한 법을 제시했습니다. 그는 소프트웨어를 세 가지 범주로 나눴습니다.
- S-type (static-type) - 이것은 정의 된 사양 및 솔루션 에 따라 엄격하게 작동하는 소프트웨어 입니다. 이를 달성하기위한 솔루션과 방법은 코딩 전에 즉시 이해됩니다. s- 타입 소프트웨어는 변경이 가장 적으므로 가장 간단합니다. 예를 들어, 수학적 계산을위한 계산기 프로그램.
- P-type (practical-type) - 이것은 절차 모음이있는 소프트웨어입니다 . 이것은 절차가 정확히 무엇을 할 수 있는지에 의해 정의됩니다. 이 소프트웨어에서는 사양을 설명 할 수 있지만 솔루션이 즉시 명확하지 않습니다. 예를 들어, 게임 소프트웨어.
- E-type (embedded-type) - 이 소프트웨어는 실제 환경 의 요구 사항으로 밀접하게 작동 합니다. 이 소프트웨어는 실제 상황에서 법률, 세금 등의 다양한 변화가 있기 때문에 고도로 진화했습니다. 예를 들어, 온라인 거래 소프트웨어.
E-Type 소프트웨어 진화
Lehman은 E-Type 소프트웨어 진화를위한 8 가지 법칙을 제시했습니다.
- Continuing change - E- 타입 소프트웨어 시스템은 현실 세계의 변화에 계속 적응해야합니다. 그렇지 않으면 점차적으로 유용하지 않게됩니다.
- Increasing complexity - E 형 소프트웨어 시스템이 발전함에 따라 유지 보수 또는 축소를위한 작업을 수행하지 않으면 복잡성이 증가하는 경향이 있습니다.
- Conservation of familiarity - 소프트웨어에 대한 친숙 함 또는 개발 방법에 대한 지식, 특정 방식으로 개발 된 이유 등은 시스템 변경을 구현하기 위해 어떤 비용 으로든 유지되어야합니다.
- Continuing growth- 일부 비즈니스 문제를 해결하려는 E-type 시스템의 경우 비즈니스의 라이프 스타일 변화에 따라 변화를 구현하는 규모가 커집니다.
- Reducing quality - E 유형 소프트웨어 시스템은 엄격하게 유지 관리하고 변화하는 운영 환경에 적응하지 않으면 품질이 저하됩니다.
- Feedback systems- E- 타입 소프트웨어 시스템은 다중 루프, 다중 레벨 피드백 시스템을 구성하며 성공적으로 수정되거나 개선 되려면 그렇게 취급되어야합니다.
- Self-regulation - E- 유형 시스템 진화 프로세스는 제품의 분포와 정상에 가까운 프로세스 측정으로 자체 조절됩니다.
- Organizational stability - 진화하는 E- 타입 시스템에서 평균 유효 글로벌 활동 률은 제품 수명 동안 변하지 않습니다.
소프트웨어 패러다임
소프트웨어 패러다임은 소프트웨어를 설계하는 동안 취해지는 방법과 단계를 의미합니다. 많은 방법이 제안되고 현재 작동 중이지만 소프트웨어 엔지니어링에서 이러한 패러다임이 어디에 있는지 확인해야합니다. 이들은 서로에 포함되어 있지만 다양한 범주로 결합 할 수 있습니다.
프로그래밍 패러다임은 소프트웨어 개발 패러다임의 하위 집합 인 소프트웨어 디자인 패러다임의 하위 집합입니다.
소프트웨어 개발 패러다임
이 패러다임은 소프트웨어 개발과 관련된 모든 엔지니어링 개념이 적용되는 소프트웨어 엔지니어링 패러다임으로 알려져 있습니다. 여기에는 소프트웨어 제품을 구축하는 데 도움이되는 다양한 연구 및 요구 사항 수집이 포함됩니다. 구성은 –
- 요구 사항 수집
- 소프트웨어 디자인
- Programming
소프트웨어 디자인 패러다임
이 패러다임은 소프트웨어 개발의 일부이며 다음을 포함합니다.
- Design
- Maintenance
- Programming
프로그래밍 패러다임
이 패러다임은 소프트웨어 개발의 프로그래밍 측면과 밀접한 관련이 있습니다. 여기에는 다음이 포함됩니다.
- Coding
- Testing
- Integration
소프트웨어 엔지니어링의 필요성
소프트웨어 엔지니어링의 필요성은 사용자 요구 사항 및 소프트웨어가 작동하는 환경의 변화율이 높기 때문에 발생합니다.
- Large software - 마찬가지로 소프트웨어의 크기가 커지면서 공학적으로 과학적 프로세스를 제공해야하기 때문에 집이나 건물보다 벽을 만드는 것이 더 쉽습니다.
- Scalability- 소프트웨어 프로세스가 과학 및 엔지니어링 개념을 기반으로하지 않았다면 기존 소프트웨어를 확장하는 것보다 새 소프트웨어를 다시 만드는 것이 더 쉬울 것입니다.
- Cost- 하드웨어 산업이 그 기술을 보여주고 거대한 제조로 인해 컴퓨터 및 전자 하드웨어의 가격이 낮아졌습니다. 그러나 적절한 프로세스가 적용되지 않으면 소프트웨어 비용이 여전히 높습니다.
- Dynamic Nature- 소프트웨어의 항상 성장하고 적응하는 특성은 사용자가 작업하는 환경에 따라 크게 달라집니다. 소프트웨어의 특성이 항상 변경되는 경우 기존 소프트웨어에서 새로운 개선 사항을 수행해야합니다. 여기에서 소프트웨어 엔지니어링이 좋은 역할을합니다.
- Quality Management- 더 나은 소프트웨어 개발 프로세스는 더 나은 품질의 소프트웨어 제품을 제공합니다.
좋은 소프트웨어의 특성
소프트웨어 제품은 그것이 제공하는 것과 그것이 얼마나 잘 사용될 수 있는지에 따라 판단 될 수 있습니다. 이 소프트웨어는 다음을 충족해야합니다.
- Operational
- Transitional
- Maintenance
잘 설계되고 제작 된 소프트웨어는 다음과 같은 특성을 가질 것으로 예상됩니다.
운영
이것은 소프트웨어가 운영에서 얼마나 잘 작동하는지 알려줍니다. 다음에서 측정 할 수 있습니다.
- Budget
- Usability
- Efficiency
- Correctness
- Functionality
- Dependability
- Security
- Safety
과도기
이 측면은 소프트웨어가 한 플랫폼에서 다른 플랫폼으로 이동할 때 중요합니다.
- Portability
- Interoperability
- Reusability
- Adaptability
유지
이 측면은 소프트웨어가 끊임없이 변화하는 환경에서 자신을 유지할 수있는 능력을 얼마나 잘 갖추고 있는지에 대해 간략히 설명합니다.
- Modularity
- Maintainability
- Flexibility
- Scalability
요컨대, 소프트웨어 엔지니어링은 효율적이고 내구성이 있으며 확장 가능하며 예산 내에서 적시에 소프트웨어 제품을 생산하는 데 필요한 잘 정의 된 엔지니어링 개념을 사용하는 컴퓨터 과학의 한 분야입니다.
소프트웨어 개발 수명주기 (SDLC)는 의도 한 소프트웨어 제품을 개발하기위한 소프트웨어 엔지니어링 단계의 잘 정의되고 구조화 된 시퀀스입니다.
SDLC 활동
SDLC는 소프트웨어 제품을 효율적으로 설계하고 개발하기 위해 따라야 할 일련의 단계를 제공합니다. SDLC 프레임 워크에는 다음 단계가 포함됩니다.
통신
이것은 사용자가 원하는 소프트웨어 제품에 대한 요청을 시작하는 첫 번째 단계입니다. 그는 서비스 제공자에게 연락하여 조건을 협상하려고합니다. 그는 서비스 제공 기관에 서면으로 요청을 제출합니다.
요구 사항 수집
이 단계는 소프트웨어 개발 팀이 프로젝트를 수행하기 위해 노력합니다. 팀은 문제 영역의 다양한 이해 관계자와 토론을하고 그들의 요구 사항에 대해 가능한 한 많은 정보를 가져 오려고 노력합니다. 요구 사항은 사용자 요구 사항, 시스템 요구 사항 및 기능 요구 사항으로 고려되고 분리됩니다. 요구 사항은 다음과 같은 여러 관행을 사용하여 수집됩니다.
- 기존 또는 구식 시스템 및 소프트웨어 연구,
- 사용자 및 개발자 인터뷰 수행,
- 데이터베이스를 참조하거나
- 설문지에서 답변을 수집합니다.
타당성 조사
요구 사항 수집 후 팀은 소프트웨어 프로세스의 대략적인 계획을 세웁니다. 이 단계에서 팀은 소프트웨어가 사용자의 모든 요구 사항을 충족하도록 만들 수 있는지 그리고 소프트웨어가 더 이상 유용하지 않을 가능성이 있는지 분석합니다. 프로젝트가 재정적으로, 실질적으로, 기술적으로 조직이 수용 할 수 있는지 여부가 밝혀졌습니다. 개발자가 소프트웨어 프로젝트의 타당성을 결정하는 데 도움이되는 많은 알고리즘이 있습니다.
시스템 분석
이 단계에서 개발자는 계획의 로드맵을 결정하고 프로젝트에 적합한 최상의 소프트웨어 모델을 가져 오려고합니다. 시스템 분석에는 소프트웨어 제품 제한 사항에 대한 이해, 기존 시스템에서 수행해야 할 학습 시스템 관련 문제 또는 변경 사항, 조직 및 인력에 대한 프로젝트의 영향 파악 및 해결 등이 포함됩니다. 프로젝트 팀은 프로젝트 범위를 분석하고 일정을 계획합니다. 그에 따라 자원.
소프트웨어 디자인
다음 단계는 요구 사항 및 분석에 대한 전체 지식을 책상 위에 놓고 소프트웨어 제품을 설계하는 것입니다. 요구 사항 수집 단계에서 수집 된 사용자 및 정보의 입력이이 단계의 입력입니다. 이 단계의 출력은 두 가지 디자인의 형태로 제공됩니다. 논리적 설계 및 물리적 설계. 엔지니어는 메타 데이터 및 데이터 사전, 논리 다이어그램, 데이터 흐름 다이어그램 및 경우에 따라 의사 코드를 생성합니다.
코딩
이 단계는 프로그래밍 단계라고도합니다. 소프트웨어 설계의 구현은 적절한 프로그래밍 언어로 프로그램 코드를 작성하고 오류없는 실행 프로그램을 효율적으로 개발하는 측면에서 시작됩니다.
테스팅
추정에 따르면 전체 소프트웨어 개발 프로세스의 50 %를 테스트해야합니다. 오류는 소프트웨어를 위험 수준에서 자체 제거까지 망칠 수 있습니다. 소프트웨어 테스트는 개발자가 코딩하는 동안 수행되며 모듈 테스트, 프로그램 테스트, 제품 테스트, 사내 테스트 및 제품 테스트와 같은 다양한 수준의 코드에서 테스트 전문가가 철저한 테스트를 수행합니다. 오류를 조기에 발견하고 해결하는 것이 신뢰할 수있는 소프트웨어의 핵심입니다.
완성
소프트웨어는 라이브러리, 데이터베이스 및 기타 프로그램과 통합되어야 할 수 있습니다. SDLC의이 단계는 소프트웨어와 외부 세계 개체의 통합에 관여합니다.
이행
이것은 사용자 컴퓨터에 소프트웨어를 설치하는 것을 의미합니다. 때때로 소프트웨어는 사용자 측에서 설치 후 구성이 필요합니다. 소프트웨어는 이식성 및 적응성을 테스트하고 통합 관련 문제는 구현 중에 해결됩니다.
운영 및 유지 보수
이 단계에서는 효율성 향상 및 오류 감소 측면에서 소프트웨어 작동을 확인합니다. 필요한 경우 사용자는 소프트웨어 작동 방법 및 소프트웨어 작동 유지 방법에 대한 설명서를 교육 받거나 도움을받습니다. 소프트웨어는 사용자 최종 환경 또는 기술에서 발생하는 변경 사항에 따라 코드를 업데이트하여 적시에 유지됩니다. 이 단계는 숨겨진 버그와 실제 미확인 문제로 인한 문제에 직면 할 수 있습니다.
처분
시간이 지나면 소프트웨어 성능이 저하 될 수 있습니다. 완전히 사용되지 않거나 집중적 인 업그레이드가 필요할 수 있습니다. 따라서 시스템의 대부분을 제거해야하는 절박한 요구가 발생합니다. 이 단계에는 데이터 및 필수 소프트웨어 구성 요소 보관, 시스템 종료, 처리 작업 계획 및 적절한 시스템 종료 시간에 시스템 종료가 포함됩니다.
소프트웨어 개발 패러다임
소프트웨어 개발 패러다임은 개발자가 소프트웨어 개발 전략을 선택할 수 있도록 도와줍니다. 소프트웨어 개발 패러다임에는 명확하게 표현되고 소프트웨어 개발 수명주기를 정의하는 자체 도구, 방법 및 절차 세트가 있습니다. 몇 가지 소프트웨어 개발 패러다임 또는 프로세스 모델은 다음과 같이 정의됩니다.
폭포 모델
Waterfall 모델은 소프트웨어 개발 패러다임의 가장 간단한 모델입니다. SDLC의 모든 단계가 선형 방식으로 차례로 작동한다고 말합니다. 즉, 첫 번째 단계가 완료되면 두 번째 단계 만 시작됩니다.
이 모델은 모든 것이 이전 단계에서 계획 한대로 완벽하게 수행되고 수행되며 다음 단계에서 발생할 수있는 과거 문제에 대해 생각할 필요가 없다고 가정합니다. 이 모델은 이전 단계에서 몇 가지 문제가 남아 있으면 원활하게 작동하지 않습니다. 모델의 순차적 인 특성으로 인해 뒤로 돌아가서 작업을 실행 취소하거나 다시 실행할 수 없습니다.
이 모델은 개발자가 이미 과거에 유사한 소프트웨어를 설계 및 개발했으며 모든 도메인을 알고있는 경우에 가장 적합합니다.
반복 모델
이 모델은 반복에서 소프트웨어 개발 프로세스를 주도합니다. SDLC 프로세스의 매 사이클마다 모든 단계를 반복하는 순환 방식으로 개발 프로세스를 투영합니다.
이 소프트웨어는 처음에 매우 작은 규모로 개발되고 고려되는 모든 단계를 따릅니다. 그런 다음, 다음 반복 할 때마다 더 많은 기능과 모듈이 설계, 코딩, 테스트 및 소프트웨어에 추가됩니다. 모든주기는 그 자체로 완전하고 이전의 것보다 더 많은 기능과 기능을 가진 소프트웨어를 생성합니다.
각 반복 후 관리 팀은 위험 관리 작업을 수행하고 다음 반복을 준비 할 수 있습니다. 주기는 전체 소프트웨어 프로세스의 작은 부분을 포함하기 때문에 개발 프로세스를 관리하는 것이 더 쉽지만 더 많은 리소스를 소비합니다.
나선형 모델
나선형 모델은 반복 모델과 SDLC 모델 중 하나의 조합입니다. 하나의 SDLC 모델을 선택하고이를 순환 프로세스 (반복 모델)와 결합하는 것처럼 볼 수 있습니다.
이 모델은 대부분의 다른 모델에서 종종 눈에 띄지 않는 위험을 고려합니다. 모델은 한 번의 반복을 시작할 때 소프트웨어의 목표와 제약을 결정하는 것으로 시작합니다. 다음 단계는 소프트웨어 프로토 타이핑입니다. 여기에는 위험 분석이 포함됩니다. 그런 다음 하나의 표준 SDLC 모델을 사용하여 소프트웨어를 구축합니다. 다음 반복 계획의 네 번째 단계에서 준비됩니다.
V – 모델
폭포수 모델의 가장 큰 단점은 이전 단계가 끝났을 때만 다음 단계로 이동하고 이후 단계에서 문제가 발견되면 되돌아 갈 기회가 없다는 것입니다. V-Model은 각 단계에서 반대로 소프트웨어 테스트 수단을 제공합니다.
모든 단계에서 해당 단계의 요구 사항에 따라 제품을 확인하고 검증하기 위해 테스트 계획과 테스트 케이스가 생성됩니다. 예를 들어 요구 사항 수집 단계에서 테스트 팀은 요구 사항에 따라 모든 테스트 케이스를 준비합니다. 나중에 제품이 개발되고 테스트 할 준비가되면이 단계의 테스트 사례에서이 단계의 요구 사항에 대한 유효성에 대해 소프트웨어를 확인합니다.
이렇게하면 확인과 유효성 검사가 동시에 진행됩니다. 이 모델은 검증 및 검증 모델이라고도합니다.
빅뱅 모델
이 모델은 형태 상 가장 단순한 모델입니다. 적은 계획, 많은 프로그래밍 및 많은 자금이 필요합니다. 이 모델은 우주의 빅뱅을 중심으로 개념화되었습니다. 과학자들이 빅뱅 이후 많은 은하계가 일어난 후 행성과 별이 하나의 사건으로 진화했다고 말합니다. 마찬가지로 우리가 많은 프로그래밍과 자금을 모으면 최고의 소프트웨어 제품을 얻을 수 있습니다.
이 모델의 경우 매우 적은 양의 계획이 필요합니다. 어떤 프로세스도 따르지 않거나 고객이 요구 사항과 향후 요구 사항에 대해 확신하지 못하는 경우가 있습니다. 따라서 입력 요구 사항은 임의적입니다.
이 모델은 대규모 소프트웨어 프로젝트에는 적합하지 않지만 학습 및 실험에는 적합합니다.
SDLC 및 다양한 모델에 대한 자세한 내용을 보려면 여기를 클릭하십시오.
소프트웨어 개발에 종사하는 IT 회사의 업무 패턴은 다음 두 부분으로 나뉩니다.
- 소프트웨어 생성
- 소프트웨어 프로젝트 관리
프로젝트는 목표를 달성하기 위해 수행되는 여러 작업 (예 : 소프트웨어 개발 및 제공)의 모음 인 잘 정의 된 작업입니다. 프로젝트의 특징은 다음과 같습니다.
- 모든 프로젝트에는 고유하고 뚜렷한 목표가있을 수 있습니다.
- 프로젝트는 일상적인 활동이나 일상적인 작업이 아닙니다.
- 프로젝트에는 시작 시간과 종료 시간이 있습니다.
- 프로젝트는 목표가 달성되면 종료되므로 조직 수명의 일시적인 단계입니다.
- 프로젝트에는 시간, 인력, 재정, 재료 및 지식 은행 측면에서 적절한 자원이 필요합니다.
소프트웨어 프로젝트
소프트웨어 프로젝트는 요구 사항 수집에서 테스트 및 유지 관리에 이르기까지 소프트웨어 개발의 전체 절차로, 의도 된 소프트웨어 제품을 달성하기 위해 지정된 기간 동안 실행 방법론에 따라 수행됩니다.
소프트웨어 프로젝트 관리의 필요성
소프트웨어는 무형의 제품이라고합니다. 소프트웨어 개발은 세계 비즈니스에서 일종의 완전히 새로운 흐름이며 소프트웨어 제품을 구축하는 데 경험이 거의 없습니다. 대부분의 소프트웨어 제품은 고객의 요구 사항에 맞게 맞춤 제작됩니다. 가장 중요한 것은 기본 기술이 너무 자주 빠르게 변화하고 발전하여 한 제품의 경험이 다른 제품에 적용되지 않을 수 있다는 것입니다. 이러한 모든 비즈니스 및 환경 적 제약은 소프트웨어 개발에 위험을 초래하므로 소프트웨어 프로젝트를 효율적으로 관리하는 것이 필수적입니다.
위의 이미지는 소프트웨어 프로젝트에 대한 삼중 제약을 보여줍니다. 양질의 제품을 제공하고 비용을 고객의 예산 범위 내에서 유지하고 일정에 따라 프로젝트를 제공하는 것은 소프트웨어 조직의 필수 부분입니다. 이 삼중 제약 삼각형에 영향을 줄 수있는 내부 및 외부 요인이 여러 개 있습니다. 세 가지 요소 중 하나가 다른 두 요소에 심각한 영향을 미칠 수 있습니다.
따라서 소프트웨어 프로젝트 관리는 예산 및 시간 제약과 함께 사용자 요구 사항을 통합하는 데 필수적입니다.
소프트웨어 프로젝트 관리자
소프트웨어 프로젝트 관리자는 소프트웨어 프로젝트를 실행하는 책임을 맡은 사람입니다. 소프트웨어 프로젝트 관리자는 소프트웨어가 거치는 SDLC의 모든 단계를 철저히 알고 있습니다. 프로젝트 관리자는 최종 제품 생산에 직접 관여 할 수 없지만 생산과 관련된 활동을 제어하고 관리합니다.
프로젝트 관리자는 비용, 예산, 자원, 시간, 품질 및 고객 만족 문제를 해결하기 위해 개발 프로세스를 면밀히 모니터링하고, 다양한 계획을 준비 및 실행하고, 필요하고 적절한 리소스를 준비하고, 모든 팀 구성원 간의 의사 소통을 유지합니다.
프로젝트 관리자가 담당하는 책임을 몇 가지 살펴 보겠습니다.
사람 관리
- 프로젝트 리더 역할
- 이해 관계자와의 병변
- 인적 자원 관리
- 보고 계층 등 설정
프로젝트 관리
- 프로젝트 범위 정의 및 설정
- 프로젝트 관리 활동 관리
- 진행 상황 및 성과 모니터링
- 모든 단계에서 위험 분석
- 문제를 피하거나 해결하기 위해 필요한 조치를 취하십시오.
- 프로젝트 대변인 역할
소프트웨어 관리 활동
소프트웨어 프로젝트 관리는 프로젝트 계획, 소프트웨어 제품의 범위 결정, 다양한 용어의 비용 추정, 작업 및 이벤트 일정 수립, 자원 관리를 포함하는 여러 활동으로 구성됩니다. 프로젝트 관리 활동에는 다음이 포함될 수 있습니다.
- Project Planning
- Scope Management
- Project Estimation
프로젝트 기획
소프트웨어 프로젝트 계획은 소프트웨어 생산이 실제로 시작되기 전에 수행되는 작업입니다. 그것은 소프트웨어 생산을위한 것이지만 소프트웨어 생산과 어떤 방향으로도 연결되는 구체적인 활동은 포함하지 않습니다. 오히려 소프트웨어 생산을 용이하게하는 여러 프로세스의 집합입니다. 프로젝트 계획에는 다음이 포함될 수 있습니다.
범위 관리
프로젝트의 범위를 정의합니다. 여기에는 제공 가능한 소프트웨어 제품을 만들기 위해 수행해야하는 모든 활동, 프로세스가 포함됩니다. 범위 관리는 프로젝트에서 수행 할 작업과 수행하지 않을 작업을 명확하게 정의하여 프로젝트의 경계를 만들기 때문에 필수적입니다. 따라서 프로젝트에 제한적이고 정량화 가능한 작업이 포함되어 쉽게 문서화 할 수 있으며 비용과 시간 초과를 방지 할 수 있습니다.
프로젝트 범위 관리 중에 다음을 수행해야합니다.
- 범위 정의
- 확인 및 제어 결정
- 관리의 용이성을 위해 프로젝트를 다양한 작은 부분으로 나눕니다.
- 범위 확인
- 범위 변경 사항을 통합하여 범위 제어
프로젝트 추정
효과적인 관리를 위해서는 다양한 조치의 정확한 추정이 필수입니다. 정확한 견적을 통해 관리자는 프로젝트를보다 효율적이고 효과적으로 관리하고 제어 할 수 있습니다.
프로젝트 추정에는 다음이 포함될 수 있습니다.
- Software size estimation
소프트웨어 크기는 KLOC (Kilo Line of Code) 또는 소프트웨어의 기능 포인트 수를 계산하여 추정 할 수 있습니다. 코드 줄은 코딩 관행에 따라 다르며 기능 포인트는 사용자 또는 소프트웨어 요구 사항에 따라 다릅니다.
- Effort estimation
관리자는 소프트웨어를 생산하는 데 필요한 인력 요구 사항과 인건비 측면에서 노력을 추정합니다. 노력 추정 소프트웨어 크기를 알고 있어야합니다. 이는 관리자의 경험, 조직의 과거 데이터 또는 소프트웨어 크기에 의해 파생 될 수 있으며 일부 표준 공식을 사용하여 노력으로 변환 될 수 있습니다.
- Time estimation
규모와 노력이 추정되면 소프트웨어를 생산하는 데 필요한 시간을 추정 할 수 있습니다. 필요한 노력은 소프트웨어의 다양한 구성 요소의 요구 사양 및 상호 의존성에 따라 하위 범주로 구분됩니다. 소프트웨어 작업은 WBS (Work Breakthrough Structure)에 따라 작은 작업, 활동 또는 이벤트로 나뉩니다. 작업은 매일 또는 달력 월 단위로 예약됩니다.
모든 작업을 몇 시간 또는 며칠 내에 완료하는 데 필요한 총 시간은 프로젝트를 완료하는 데 투자 한 총 시간입니다.
- Cost estimation
이것은 이전 요소보다 더 많은 요소에 의존하기 때문에 가장 어려운 것으로 간주 될 수 있습니다. 프로젝트 비용을 추정하려면 다음 사항을 고려해야합니다.
- 소프트웨어 크기
- 소프트웨어 품질
- Hardware
- 추가 소프트웨어 또는 도구, 라이선스 등
- 작업 별 기술을 보유한 숙련 된 인력
- 관련된 여행
- Communication
- 교육 및 지원
프로젝트 추정 기법
규모, 노력, 시간 및 비용과 같은 프로젝트 추정과 관련된 다양한 매개 변수에 대해 논의했습니다.
프로젝트 관리자는 널리 알려진 두 가지 기술을 사용하여 나열된 요소를 추정 할 수 있습니다.
분해 기법
이 기술은 소프트웨어를 다양한 구성의 제품으로 가정합니다.
두 가지 주요 모델이 있습니다.
- Line of Code 추정은 소프트웨어 제품의 코드 줄 수를 대신하여 수행됩니다.
- Function Points 추정은 소프트웨어 제품의 기능 포인트 수를 대신하여 수행됩니다.
경험적 추정 기법
이 기법은 경험적으로 도출 된 공식을 사용하여 추정하며, 이러한 공식은 LOC 또는 FP를 기반으로합니다.
- Putnam Model
이 모델은 Norden의 주파수 분포 (Rayleigh 곡선)를 기반으로하는 Lawrence H. Putnam에 의해 만들어졌습니다. Putnam 모델은 소프트웨어 크기에 필요한 시간과 노력을 매핑합니다.
- COCOMO
COCOMO는 Barry W. Boehm이 개발 한 COnstructive COst MOdel의 약자입니다. 소프트웨어 제품을 유기적, 반 분리형 및 내장형의 세 가지 범주로 나눕니다.
프로젝트 일정
프로젝트의 프로젝트 스케줄링은 지정된 순서와 각 활동에 할당 된 시간 슬롯 내에서 수행 할 모든 활동의 로드맵을 나타냅니다. 프로젝트 관리자는 다양한 작업과 프로젝트 이정표를 정의하고 다양한 요소를 염두에두고 정렬하는 경향이 있습니다. 그들은 일정에서 중요한 경로에있는 작업을 찾습니다.이 작업은 특정 방식으로 (작업 상호 의존성 때문에) 완료해야하며 엄격하게 할당 된 시간 내에 완료해야합니다. 중요한 경로를 벗어난 작업의 배열은 프로젝트의 모든 일정에 영향을 줄 가능성이 적습니다.
프로젝트를 예약하려면 다음을 수행해야합니다.
- 프로젝트 작업을 더 작고 관리하기 쉬운 형식으로 분류
- 다양한 작업을 찾아 상호 연결
- 각 작업에 필요한 시간 프레임 추정
- 시간을 작업 단위로 나누십시오.
- 각 작업에 적절한 수의 작업 단위 할당
- 프로젝트 시작부터 완료까지 필요한 총 시간 계산
자원 관리
소프트웨어 제품을 개발하는 데 사용되는 모든 요소는 해당 프로젝트의 자원으로 간주 될 수 있습니다. 여기에는 인적 자원, 생산 도구 및 소프트웨어 라이브러리가 포함될 수 있습니다.
자원은 제한된 수량으로 제공되며 자산 풀로 조직에 머물러 있습니다. 자원 부족은 프로젝트 개발을 방해하고 일정보다 지연 될 수 있습니다. 추가 리소스를 할당하면 결국 개발 비용이 증가합니다. 따라서 프로젝트를위한 적절한 자원을 추정하고 할당하는 것이 필요합니다.
자원 관리에는 다음이 포함됩니다.
- 프로젝트 팀을 구성하고 각 팀원에게 책임을 할당하여 적절한 조직 프로젝트 정의
- 특정 단계에 필요한 리소스 및 가용성 결정
- 리소스가 필요할 때 리소스 요청을 생성하고 더 이상 필요하지 않을 때는 할당을 해제하여 리소스를 관리합니다.
프로젝트 위험 관리
위험 관리에는 프로젝트에서 예측 가능하고 예측 불가능한 위험을 식별, 분석 및 제공하는 것과 관련된 모든 활동이 포함됩니다. 위험에는 다음이 포함될 수 있습니다.
- 경험 많은 직원이 프로젝트를 떠나고 새로운 직원이 들어옵니다.
- 조직 관리의 변화.
- 요구 사항 변경 또는 요구 사항 잘못 해석.
- 필요한 시간과 자원의 과소 평가.
- 기술 변화, 환경 변화, 비즈니스 경쟁.
리스크 관리 프로세스
위험 관리 프로세스에는 다음과 같은 활동이 있습니다.
- Identification - 프로젝트에서 발생할 수있는 모든 가능한 위험을 기록하십시오.
- Categorize - 프로젝트에 미칠 수있는 영향에 따라 알려진 위험을 높음, 중간 및 낮음 강도로 분류합니다.
- Manage - 다양한 단계에서 위험 발생 확률을 분석합니다. 위험을 피하거나 직면 할 계획을 세우십시오. 부작용을 최소화하십시오.
- Monitor - 잠재적 위험과 초기 증상을 면밀히 모니터링하십시오. 또한이를 완화하거나 피하기 위해 취한 조치의 효과를 모니터링하십시오.
프로젝트 실행 및 모니터링
이 단계에서는 프로젝트 계획에 설명 된 작업이 일정에 따라 실행됩니다.
모든 것이 계획대로 진행되고 있는지 확인하려면 실행을 모니터링해야합니다. 모니터링은 위험 가능성을 확인하기 위해 관찰하고 위험을 해결하거나 다양한 작업의 상태를보고하기위한 조치를 취하는 것입니다.
이러한 조치에는 다음이 포함됩니다.
- Activity Monitoring - 일부 작업 내에서 예약 된 모든 활동은 매일 모니터링 할 수 있습니다. 작업의 모든 활동이 완료되면 완료된 것으로 간주됩니다.
- Status Reports - 보고서에는 주어진 시간 프레임 (일반적으로 1 주일) 내에 완료된 활동 및 작업의 상태가 포함됩니다. 상태는 완료, 보류 또는 진행 중 등으로 표시 될 수 있습니다.
- Milestones Checklist - 모든 프로젝트는 SDLC의 단계에 따라 주요 작업이 수행되는 여러 단계 (이정표)로 나뉩니다. 이 마일스톤 체크리스트는 몇 주에 한 번씩 준비되며 마일스톤 상태를보고합니다.
프로젝트 커뮤니케이션 관리
효과적인 의사 소통은 프로젝트의 성공에 중요한 역할을합니다. 하드웨어 공급 업체와 같은 프로젝트의 다른 이해 관계자뿐만 아니라 팀 구성원 간의 클라이언트와 조직 간의 격차를 해소합니다.
의사 소통은 구두 또는 서면으로 할 수 있습니다. 통신 관리 프로세스에는 다음 단계가있을 수 있습니다.
- Planning -이 단계에는 프로젝트의 모든 이해 관계자의 식별과 이들 간의 의사 소통 방식이 포함됩니다. 추가 통신 기능이 필요한지 여부도 고려합니다.
- Sharing -기획의 다양한 측면을 결정한 후 관리자는 정확한 시간에 정확한 사람과 정확한 정보를 공유하는 데 집중합니다. 이를 통해 프로젝트에 관련된 모든 사람이 프로젝트 진행 상황과 상태를 최신 상태로 유지할 수 있습니다.
- Feedback -프로젝트 관리자는 다양한 측정 및 피드백 메커니즘을 사용하고 상태 및 성과 보고서를 작성합니다. 이 메커니즘은 다양한 이해 관계자의 의견이 프로젝트 관리자에게 피드백으로 전달되도록합니다.
- Closure -각 주요 이벤트가 끝날 때, SDLC 단계가 끝날 때 또는 프로젝트 자체가 끝날 때 이메일을 보내거나 문서의 하드 카피를 배포하거나 기타 효과적인 커뮤니케이션 수단을 통해 모든 이해 관계자를 업데이트하기 위해 행정 폐쇄가 공식적으로 발표됩니다.
종료 후 팀은 다음 단계 또는 프로젝트로 이동합니다.
구성 관리
구성 관리는 제품의 요구 사항, 디자인, 기능 및 개발 측면에서 소프트웨어의 변경 사항을 추적하고 제어하는 프로세스입니다.
IEEE는이를 "시스템에서 항목을 식별 및 정의하고, 수명주기 동안 이러한 항목의 변경을 제어하고, 항목 및 변경 요청의 상태를 기록 및보고하고, 항목의 완전성과 정확성을 확인하는 프로세스"로 정의합니다.
일반적으로 SRS가 완료되면 사용자의 변경 요구 사항이 적습니다. 변경 사항이 발생하면 비용 및 시간 초과 가능성이 있으므로 고위 경영진의 사전 승인을 통해서만 변경 사항이 처리됩니다.
기준선
기준선이있는 경우 SDLC의 단계가 가정됩니다. 즉 기준선은 단계의 완전성을 정의하는 측정입니다. 단계는 관련된 모든 활동이 완료되고 잘 문서화 될 때 기준이됩니다. 최종 단계가 아니라면 출력은 다음 단계에서 사용됩니다.
구성 관리는 한 단계가 기준이 된 후 모든 변경 (프로세스, 요구 사항, 기술, 전략적 등) 발생을 처리하는 조직 관리 분야입니다. CM은 소프트웨어의 변경 사항을 계속 확인합니다.
변경 제어
변경 제어는 구성 관리의 기능으로, 소프트웨어 시스템에 대한 모든 변경 사항이 일관되고 조직 규칙 및 규정에 따라 이루어 지도록합니다.
제품 구성 변경은 다음 단계를 거칩니다.
Identification-내부 또는 외부 소스에서 변경 요청이 도착합니다. 변경 요청이 공식적으로 식별되면 적절하게 문서화됩니다.
Validation -변경 요청의 유효성을 확인하고 처리 절차를 확인합니다.
Analysis-일정, 비용 및 필요한 노력 측면에서 변경 요청의 영향을 분석합니다. 시스템에 대한 예상 변경의 전반적인 영향이 분석됩니다.
Control-예상 변경이 시스템의 너무 많은 주체에 영향을 미치거나 불가피한 경우 변경이 시스템에 통합되기 전에 고위 당국의 승인을 받아야합니다. 그 변화가 합병 가치가 있는지 아닌지 결정됩니다. 그렇지 않은 경우 변경 요청이 공식적으로 거부됩니다.
Execution -이전 단계에서 변경 요청을 실행하기로 결정한 경우이 단계에서는 변경을 실행하기 위해 적절한 조치를 취하고 필요한 경우 철저한 수정을 수행합니다.
Close request-변경 사항이 올바른 구현을 위해 확인되고 나머지 시스템과 병합됩니다. 소프트웨어에 새로 통합 된이 변경 사항은 적절하게 문서화되었으며 요청은 공식적으로 종료됩니다.
프로젝트 관리 도구
프로젝트가 정해진 방법론에 따라 개발 되더라도 프로젝트 규모에 따라 위험과 불확실성이 여러 배로 증가합니다.
효과적인 프로젝트 관리에 도움이되는 도구가 있습니다. 몇 가지가 설명되어 있습니다.
간트 차트
Gantt 차트는 Henry Gantt (1917)에 의해 고안되었습니다. 기간에 대한 프로젝트 일정을 나타냅니다. 프로젝트 활동에 대해 예약 된 활동 및 시간을 나타내는 막대가있는 가로 막대 차트입니다.
PERT 차트
PERT (Program Evaluation & Review Technique) 차트는 프로젝트를 네트워크 다이어그램으로 묘사하는 도구입니다. 프로젝트의 주요 이벤트를 병렬 및 연속 방식으로 그래픽으로 표현할 수 있습니다. 차례로 발생하는 이벤트는 이전 이벤트에 대한 이후 이벤트의 종속성을 보여줍니다.
이벤트는 번호가 매겨진 노드로 표시됩니다. 프로젝트의 작업 순서를 나타내는 레이블이 지정된 화살표로 연결됩니다.
리소스 히스토그램
이것은 프로젝트 이벤트 (또는 단계)에 대해 시간이 지남에 따라 필요한 리소스 (일반적으로 숙련 된 직원) 수를 나타내는 막대 또는 차트가 포함 된 그래픽 도구입니다. 리소스 히스토그램은 직원 계획 및 조정을위한 효과적인 도구입니다.
중요 경로 분석
이 도구는 프로젝트에서 상호 의존적 인 작업을 인식하는 데 유용합니다. 또한 프로젝트를 성공적으로 완료하기위한 최단 경로 또는 중요 경로를 찾는 데 도움이됩니다. PERT 다이어그램과 마찬가지로 각 이벤트에는 특정 시간 프레임이 할당됩니다. 이 도구는 이전 이벤트가 완료된 경우에만 이벤트가 다음으로 진행될 수 있다고 가정하여 이벤트의 종속성을 표시합니다.
이벤트는 가능한 가장 빠른 시작 시간에 따라 정렬됩니다. 시작 노드와 끝 노드 사이의 경로는 더 이상 줄일 수없는 중요한 경로이며 모든 이벤트는 동일한 순서로 실행되어야합니다.
소프트웨어 요구 사항은 대상 시스템의 기능에 대한 설명입니다. 요구 사항은 소프트웨어 제품에서 사용자의 기대치를 전달합니다. 요구 사항은 클라이언트의 관점에서 명확하거나 숨겨져 있거나, 알려 지거나 알려지지 않았거나, 예상되거나 예상치 못한 것일 수 있습니다.
요구 공학
클라이언트로부터 소프트웨어 요구 사항을 수집하고이를 분석하고 문서화하는 프로세스를 요구 사항 엔지니어링이라고합니다.
요구 사항 엔지니어링의 목표는 정교하고 설명적인 '시스템 요구 사항 사양'문서를 개발하고 유지하는 것입니다.
요구 엔지니어링 프로세스
다음을 포함하는 4 단계 프로세스입니다.
- 타당성 조사
- 요구 사항 수집
- 소프트웨어 요구 사항 사양
- 소프트웨어 요구 사항 검증
프로세스를 간단히 살펴 보겠습니다.
타당성 조사
고객이 원하는 제품을 개발하기 위해 조직에 접근하면 소프트웨어가 수행해야하는 모든 기능과 소프트웨어에서 예상되는 모든 기능에 대한 대략적인 아이디어가 떠 오릅니다.
이 정보를 참조하여 분석가는 원하는 시스템과 기능을 개발할 수 있는지 여부에 대한 자세한 연구를 수행합니다.
이 타당성 조사는 조직의 목표에 초점을 맞추고 있습니다. 이 연구는 소프트웨어 제품이 구현, 조직에 대한 프로젝트의 기여도, 비용 제약 및 조직의 가치와 목표에 따라 실질적으로 구체화 될 수 있는지 분석합니다. 사용성, 유지 보수성, 생산성 및 통합 능력과 같은 프로젝트 및 제품의 기술적 측면을 탐색합니다.
이 단계의 결과는 프로젝트를 수행해야하는지 여부에 대한 관리를위한 적절한 의견과 권장 사항을 포함해야하는 타당성 조사 보고서 여야합니다.
요구 사항 수집
타당성 보고서가 프로젝트 수행에 긍정적 인 경우 다음 단계는 사용자로부터 요구 사항을 수집하는 것으로 시작됩니다. 분석가와 엔지니어는 클라이언트 및 최종 사용자와 소통하여 소프트웨어가 제공해야하는 내용과 소프트웨어에 포함 할 기능에 대한 아이디어를 파악합니다.
소프트웨어 요구 사항 사양
SRS는 다양한 이해 관계자로부터 요구 사항을 수집 한 후 시스템 분석가가 만든 문서입니다.
SRS는 의도 한 소프트웨어가 하드웨어, 외부 인터페이스, 작동 속도, 시스템 응답 시간, 다양한 플랫폼 간의 소프트웨어 이식성, 유지 관리, 충돌 후 복구 속도, 보안, 품질, 제한 등과 상호 작용하는 방식을 정의합니다.
고객으로부터받은 요구 사항은 자연어로 작성됩니다. 소프트웨어 개발 팀이 이해하고 유용 할 수 있도록 요구 사항을 기술 언어로 문서화하는 것은 시스템 분석가의 책임입니다.
SRS는 다음과 같은 기능을 제공해야합니다.
- 사용자 요구 사항은 자연어로 표현됩니다.
- 기술 요구 사항은 조직 내에서 사용되는 구조화 된 언어로 표현됩니다.
- 설계 설명은 의사 코드로 작성해야합니다.
- 양식 및 GUI 화면 인쇄의 형식.
- DFD 등에 대한 조건부 및 수학적 표기법
소프트웨어 요구 사항 검증
요구 사항 사양이 개발 된 후이 문서에 언급 된 요구 사항이 검증됩니다. 사용자가 불법적이고 비실용적 인 솔루션을 요청하거나 전문가가 요구 사항을 잘못 해석 할 수 있습니다. 이로 인해 새싹에 꽂 히지 않으면 비용이 크게 증가합니다. 다음 조건에 대해 요구 사항을 확인할 수 있습니다.
- 실질적으로 구현할 수있는 경우
- 유효하고 소프트웨어의 기능 및 도메인에 따라
- 모호한 부분이있는 경우
- 완료되면
- 시연 가능하다면
요구 사항 추출 프로세스
요구 사항 추출 프로세스는 다음 다이어그램을 사용하여 설명 할 수 있습니다.
- Requirements gathering - 개발자는 클라이언트 및 최종 사용자와 논의하고 소프트웨어에 대한 기대치를 알고 있습니다.
- Organizing Requirements - 개발자는 중요성, 긴급 성 및 편의성 순으로 요구 사항의 우선 순위를 지정하고 정렬합니다.
Negotiation & discussion - 요구 사항이 모호하거나 다양한 이해 관계자의 요구 사항에 충돌이있는 경우 이해 관계자와 협의하고 논의합니다. 그런 다음 요구 사항의 우선 순위가 지정되고 합리적으로 손상 될 수 있습니다.
요구 사항은 다양한 이해 관계자가 제공합니다. 모호함과 충돌을 제거하기 위해 명확성과 정확성을 위해 논의됩니다. 비현실적인 요구 사항은 합리적으로 손상됩니다.
- Documentation - 모든 공식 및 비공식, 기능 및 비 기능 요구 사항은 문서화되어 다음 단계 처리에 사용할 수 있습니다.
요구 사항 추출 기법
요구 사항 추출은 클라이언트, 최종 사용자, 시스템 사용자 및 소프트웨어 시스템 개발에 이해 관계가있는 다른 사용자와 통신하여 의도 한 소프트웨어 시스템에 대한 요구 사항을 찾는 프로세스입니다.
요구 사항을 발견하는 다양한 방법이 있습니다.
인터뷰
인터뷰는 요구 사항을 수집하는 강력한 매체입니다. 조직은 다음과 같은 여러 유형의 인터뷰를 수행 할 수 있습니다.
- 수집 할 모든 정보가 미리 결정되는 구조적 (밀폐) 인터뷰는 패턴과 논의 사항을 확고하게 따릅니다.
- 수집 할 정보가 미리 결정되지 않고 더 유연하고 편향적이지 않은 비정형 (개방) 인터뷰.
- 구두 인터뷰
- 서면 인터뷰
- 테이블에있는 두 사람이 일대일 인터뷰를합니다.
- 참가자 그룹간에 진행되는 그룹 인터뷰. 수많은 사람들이 참여함에 따라 누락 된 요구 사항을 발견하는 데 도움이됩니다.
설문 조사
조직은 향후 시스템에 대한 기대 및 요구 사항을 쿼리하여 다양한 이해 관계자들 사이에서 설문 조사를 수행 할 수 있습니다.
설문지
사전 정의 된 일련의 객관적인 질문과 각 옵션이 포함 된 문서가 모든 이해 관계자들에게 전달되어 수집되고 편집됩니다.
이 기술의 단점은 일부 문제에 대한 옵션이 설문지에 언급되지 않은 경우 문제가 방치 될 수 있다는 것입니다.
작업 분석
엔지니어와 개발자 팀은 새로운 시스템이 필요한 작업을 분석 할 수 있습니다. 클라이언트가 특정 작업을 수행 할 수있는 소프트웨어가 이미있는 경우이를 조사하고 제안 된 시스템의 요구 사항을 수집합니다.
도메인 분석
모든 소프트웨어는 특정 도메인 범주에 속합니다. 도메인의 전문가는 일반 및 특정 요구 사항을 분석하는 데 큰 도움이 될 수 있습니다.
브레인 스토밍
다양한 이해 관계자들 사이에서 비공식 토론이 열리고 추가 요구 사항 분석을 위해 모든 입력 내용이 기록됩니다.
프로토 타이핑
프로토 타이핑은 사용자가 의도 한 소프트웨어 제품의 기능을 해석 할 수 있도록 세부 기능을 추가하지 않고 사용자 인터페이스를 구축하는 것입니다. 요구 사항에 대한 더 나은 아이디어를 제공하는 데 도움이됩니다. 개발자 참조를 위해 클라이언트 측에 설치된 소프트웨어가없고 클라이언트가 자체 요구 사항을 인식하지 못하는 경우 개발자는 처음에 언급 한 요구 사항을 기반으로 프로토 타입을 만듭니다. 프로토 타입이 클라이언트에게 표시되고 피드백이 기록됩니다. 클라이언트 피드백은 요구 사항 수집을위한 입력으로 사용됩니다.
관측
전문가 팀이 고객의 조직이나 직장을 방문합니다. 그들은 기존에 설치된 시스템의 실제 작동을 관찰합니다. 그들은 클라이언트 측의 워크 플로우와 실행 문제가 어떻게 처리되는지 관찰합니다. 팀 자체는 소프트웨어에서 예상되는 요구 사항을 형성하는 데 도움이되는 몇 가지 결론을 도출합니다.
소프트웨어 요구 사항 특성
소프트웨어 요구 사항 수집은 전체 소프트웨어 개발 프로젝트의 기초입니다. 따라서 명확하고 정확하며 잘 정의되어야합니다.
전체 소프트웨어 요구 사항 사양은 다음과 같아야합니다.
- Clear
- Correct
- Consistent
- Coherent
- Comprehensible
- Modifiable
- Verifiable
- Prioritized
- Unambiguous
- Traceable
- 신뢰할 수있는 출처
소프트웨어 요구 사항
요구 사항 추출 단계에서 어떤 종류의 요구 사항이 발생할 수 있으며 소프트웨어 시스템에서 어떤 종류의 요구 사항이 예상되는지 이해하려고 노력해야합니다.
소프트웨어 요구 사항은 크게 두 가지 범주로 분류해야합니다.
기능 요구 사항
소프트웨어의 기능적 측면과 관련된 요구 사항이이 범주에 속합니다.
이들은 소프트웨어 시스템 내부 및 소프트웨어 시스템의 기능과 기능을 정의합니다.
예-
- 다양한 인보이스에서 검색 할 수 있도록 사용자에게 제공되는 검색 옵션입니다.
- 사용자는 모든 보고서를 관리자에게 메일로 보낼 수 있어야합니다.
- 사용자는 그룹으로 나눌 수 있으며 그룹은 별도의 권한을 부여받을 수 있습니다.
- 비즈니스 규칙 및 관리 기능을 준수해야합니다.
- 하위 호환성을 그대로 유지하면서 소프트웨어가 개발되었습니다.
비 기능적 요구 사항
소프트웨어의 기능적 측면과 관련이없는 요구 사항이이 범주에 속합니다. 사용자가 가정하는 소프트웨어의 암시 적 또는 예상되는 특성입니다.
비 기능적 요구 사항은 다음과 같습니다.
- Security
- Logging
- Storage
- Configuration
- Performance
- Cost
- Interoperability
- Flexibility
- 재해 복구
- Accessibility
요구 사항은 논리적으로 다음과 같이 분류됩니다.
- Must Have : 소프트웨어 없이는 작동한다고 말할 수 없습니다.
- Should have : 소프트웨어 기능 향상.
- Could have : 소프트웨어는 이러한 요구 사항에 따라 제대로 작동 할 수 있습니다.
- Wish list : 이러한 요구 사항은 소프트웨어의 어떤 목표에도 매핑되지 않습니다.
소프트웨어를 개발하는 동안 'Must have'를 구현해야하며 'Should have'는 이해 관계자와의 논쟁과 부정의 문제이며, 'cand have'와 'wish list'는 소프트웨어 업데이트를 위해 보관할 수 있습니다.
사용자 인터페이스 요구 사항
UI는 소프트웨어, 하드웨어 또는 하이브리드 시스템의 중요한 부분입니다. 다음과 같은 경우 소프트웨어가 널리 허용됩니다.
- 작동하기 쉬움
- 빠른 응답
- 운영 오류를 효과적으로 처리
- 간단하면서도 일관된 사용자 인터페이스 제공
사용자 동의는 주로 사용자가 소프트웨어를 사용할 수있는 방법에 따라 다릅니다. UI는 사용자가 시스템을 인식 할 수있는 유일한 방법입니다. 성능이 좋은 소프트웨어 시스템은 매력적이고 명확하며 일관되고 반응이 빠른 사용자 인터페이스를 갖추어야합니다. 그렇지 않으면 소프트웨어 시스템의 기능을 편리하게 사용할 수 없습니다. 시스템을 효율적으로 사용할 수있는 수단을 제공하면 좋은 시스템이라고합니다. 사용자 인터페이스 요구 사항은 아래에 간략하게 설명되어 있습니다.
- 콘텐츠 프레젠테이션
- 쉬운 탐색
- 간단한 인터페이스
- Responsive
- 일관된 UI 요소
- 피드백 메커니즘
- 기본 설정
- 목적에 맞는 레이아웃
- 색상과 질감의 전략적 사용.
- 도움말 정보 제공
- 사용자 중심 접근 방식
- 그룹 기반보기 설정.
소프트웨어 시스템 분석가
IT 조직의 시스템 분석가는 제안 된 시스템의 요구 사항을 분석하고 요구 사항이 적절하고 정확하게 구상되고 문서화되었는지 확인하는 사람입니다. 분석가의 역할은 SDLC의 소프트웨어 분석 단계에서 시작됩니다. 개발 된 소프트웨어가 클라이언트의 요구 사항을 충족하는지 확인하는 것은 분석가의 책임입니다.
시스템 분석가는 다음과 같은 책임이 있습니다.
- 의도 한 소프트웨어의 요구 사항 분석 및 이해
- 프로젝트가 조직 목표에 어떻게 기여할 것인지 이해
- 요구 사항의 출처 파악
- 요구 사항 검증
- 요구 사항 관리 계획 개발 및 구현
- 비즈니스, 기술, 프로세스 및 제품 요구 사항 문서화
- 요구 사항의 우선 순위를 지정하고 모호성을 제거하기 위해 클라이언트와 협력
- 고객 및 기타 이해 관계자와 함께 수락 기준 마무리
소프트웨어 지표 및 측정
소프트웨어 측정은 소프트웨어의 다양한 속성과 측면을 정량화하고 상징화하는 프로세스로 이해할 수 있습니다.
소프트웨어 메트릭은 소프트웨어 프로세스 및 소프트웨어 제품의 다양한 측면에 대한 측정 값을 제공합니다.
소프트웨어 측정은 소프트웨어 엔지니어링의 기본 요구 사항입니다. 소프트웨어 개발 프로세스를 제어하는 데 도움이 될뿐만 아니라 궁극적 인 제품의 품질을 우수하게 유지하는 데 도움이됩니다.
소프트웨어 엔지니어 인 Tom DeMarco에 따르면 "측정 할 수없는 것은 제어 할 수 없습니다." 그의 말에 따르면 소프트웨어 측정이 얼마나 중요한지 매우 분명합니다.
몇 가지 소프트웨어 메트릭을 살펴 보겠습니다.
Size Metrics - LOC (Lines of Code)는 대부분 제공되는 수천 개의 소스 코드 행으로 계산되며 KLOC로 표시됩니다.
Function Point Count는 소프트웨어에서 제공하는 기능의 척도입니다. 기능 점수는 소프트웨어의 기능적 측면의 크기를 정의합니다.
- Complexity Metrics - McCabe의 순환 적 복잡성은 프로그램 또는 해당 모듈의 복잡성으로 인식되는 프로그램에서 독립적 인 경로 수의 상한을 수량화합니다. 제어 흐름 그래프를 사용하여 그래프 이론 개념으로 표현됩니다.
Quality Metrics - 결함, 유형 및 원인, 결과, 심각도의 강도 및 그 의미가 제품의 품질을 정의합니다.
개발 과정에서 발견 된 결함의 수와 제품이 고객 측에 설치되거나 납품 된 후 고객이보고 한 결함의 수는 제품의 품질을 정의합니다.
- Process Metrics - SDLC의 다양한 단계에서 사용되는 방법과 도구, 회사 표준 및 개발 성능은 소프트웨어 프로세스 메트릭입니다.
- Resource Metrics - 사용 된 노력, 시간 및 다양한 리소스는 리소스 측정을위한 메트릭을 나타냅니다.
소프트웨어 디자인은 사용자 요구 사항을 적절한 형식으로 변환하는 프로세스로, 프로그래머가 소프트웨어 코딩 및 구현에 도움을줍니다.
사용자 요구 사항을 평가하기 위해 SRS (Software Requirement Specification) 문서가 생성되는 반면 코딩 및 구현을 위해서는 소프트웨어 용어에서보다 구체적이고 상세한 요구 사항이 필요합니다. 이 프로세스의 출력은 프로그래밍 언어 구현에 직접 사용할 수 있습니다.
소프트웨어 설계는 문제 영역에서 솔루션 영역으로 집중을 이동하는 SDLC (Software Design Life Cycle)의 첫 번째 단계입니다. SRS에 언급 된 요구 사항을 충족하는 방법을 지정하려고합니다.
소프트웨어 디자인 수준
소프트웨어 설계는 세 가지 수준의 결과를 제공합니다.
- Architectural Design - 건축 설계는 시스템의 가장 추상적 인 버전입니다. 여러 구성 요소가 서로 상호 작용하는 시스템으로 소프트웨어를 식별합니다. 이 수준에서 설계자는 제안 된 솔루션 도메인에 대한 아이디어를 얻습니다.
- High-level Design- 높은 수준의 디자인은 아키텍처 디자인의 '단일 엔티티-다중 구성 요소'개념을 하위 시스템 및 모듈에 대한 덜 요약 된보기로 나누고 서로 간의 상호 작용을 묘사합니다. 고급 설계는 시스템과 모든 구성 요소를 모듈 형태로 구현하는 방법에 중점을 둡니다. 각 하위 시스템의 모듈 식 구조와 서로 간의 관계 및 상호 작용을 인식합니다.
- Detailed Design- 상세 설계는 이전 두 설계에서 시스템 및 하위 시스템으로 보이는 구현 부분을 다룹니다. 모듈 및 해당 구현에 대해 더 자세히 설명합니다. 다른 모듈과 통신하기 위해 각 모듈의 논리적 구조와 인터페이스를 정의합니다.
모듈화
모듈화는 소프트웨어 시스템을 독립적으로 작업을 수행 할 수있을 것으로 예상되는 여러 개의 개별 및 독립 모듈로 분할하는 기술입니다. 이러한 모듈은 전체 소프트웨어에 대한 기본 구조로 작동 할 수 있습니다. 설계자는 모듈을 개별적으로 독립적으로 실행 및 / 또는 컴파일 할 수 있도록 설계하는 경향이 있습니다.
모듈 형 설계는 소프트웨어의 모듈 형 설계에 추가 된 많은 다른 이점이 있기 때문에 문제 해결 전략의 '분할 및 정복'규칙을 의도하지 않게 따르고 있습니다.
모듈화의 장점 :
- 구성 요소가 작을수록 유지 관리가 더 쉽습니다.
- 기능적 측면에 따라 프로그램을 나눌 수 있음
- 프로그램에서 원하는 추상화 수준을 가져올 수 있습니다.
- 응집력이 높은 부품은 다시 재사용 할 수 있습니다.
- 동시 실행 가능
- 보안 측면에서 원하는
동시성
시간을 거슬러 올라가면 모든 소프트웨어는 순차적으로 실행됩니다. 순차적 실행이란 코딩 된 명령어가 차례로 실행된다는 것을 의미하며 이는 주어진 시간에 프로그램의 한 부분 만 활성화됨을 의미합니다. 예를 들어, 소프트웨어에 여러 모듈이있는 경우 실행시 모든 모듈 중 하나만 활성 상태로 발견 될 수 있습니다.
소프트웨어 설계에서 동시성은 소프트웨어를 모듈과 같은 여러 독립 실행 단위로 분할하고 병렬로 실행하여 구현됩니다. 즉, 동시성은 소프트웨어가 서로 병렬로 둘 이상의 코드 부분을 실행할 수있는 기능을 제공합니다.
프로그래머와 디자이너는 병렬 실행이 가능한 모듈을 인식 할 필요가 있습니다.
예
워드 프로세서의 맞춤법 검사 기능은 워드 프로세서 자체와 함께 실행되는 소프트웨어 모듈입니다.
결합 및 응집
소프트웨어 프로그램이 모듈화되면 그 작업은 몇 가지 특성에 따라 여러 모듈로 나뉩니다. 아시다시피, 모듈은 몇 가지 작업을 수행하기 위해 조합 된 지침 집합입니다. 그러나 그들은 단일 엔티티로 간주되지만 함께 작동하기 위해 서로를 참조 할 수 있습니다. 모듈 설계의 품질과 모듈 간의 상호 작용을 측정 할 수있는 방법이 있습니다. 이러한 측정을 결합 및 응집이라고합니다.
응집력
응집력은 모듈 요소 내에서 내부 의존성의 정도를 정의하는 척도입니다. 응집력이 클수록 프로그램 디자인이 더 좋습니다.
응집력에는 7 가지 유형이 있습니다.
- Co-incidental cohesion -계획되지 않은 임의의 응집력은 모듈화를 위해 프로그램을 더 작은 모듈로 분할 한 결과 일 수 있습니다. 계획되지 않았기 때문에 프로그래머에게 혼란을 줄 수 있으며 일반적으로 허용되지 않습니다.
- Logical cohesion - 논리적으로 분류 된 요소가 모듈로 모이면 논리적 응집이라고합니다.
- emporal Cohesion - 모듈의 요소가 유사한 시점에서 처리되도록 구성되는 것을 시간적 응집이라고합니다.
- Procedural cohesion - 작업을 수행하기 위해 순차적으로 실행되는 모듈의 요소가 함께 그룹화되는 것을 절차 적 응집력이라고합니다.
- Communicational cohesion - 순차적으로 실행되고 동일한 데이터 (정보)에 대해 작업하는 모듈의 요소가 함께 그룹화되어있는 것을 통신 응집력이라고합니다.
- Sequential cohesion - 한 요소의 출력이 다른 요소에 대한 입력 역할을하여 모듈의 요소가 그룹화되는 경우이를 순차 응집이라고합니다.
- Functional cohesion - 그것은 가장 높은 응집력으로 간주되며 높은 기대 수준입니다. 기능적 응집성의 모듈 요소는 모두 하나의 잘 정의 된 함수에 기여하기 때문에 그룹화됩니다. 재사용 할 수도 있습니다.
커플 링
커플 링은 프로그램 모듈 간의 상호 의존성 수준을 정의하는 척도입니다. 모듈이 서로 간섭하고 상호 작용하는 수준을 알려줍니다. 커플 링이 낮을수록 프로그램이 더 좋습니다.
결합에는 5 가지 수준이 있습니다.
- Content coupling - 모듈이 다른 모듈의 내용에 직접 액세스하거나 수정하거나 참조 할 수있는 경우이를 내용 수준 결합이라고합니다.
- Common coupling- 여러 모듈에 일부 글로벌 데이터에 대한 읽기 및 쓰기 액세스 권한이있는 경우이를 공통 또는 글로벌 커플 링이라고합니다.
- Control coupling- 두 모듈 중 하나가 다른 모듈의 기능을 결정하거나 실행 흐름을 변경하는 경우 두 모듈을 제어 결합이라고합니다.
- Stamp coupling- 여러 모듈이 공통 데이터 구조를 공유하고 다른 부분에서 작동하는 경우이를 스탬프 커플 링이라고합니다.
- Data coupling- 데이터 커플 링은 두 모듈이 데이터 전달 (파라미터로)을 통해 서로 상호 작용하는 경우입니다. 모듈이 데이터 구조를 매개 변수로 전달하면 수신 모듈은 모든 구성 요소를 사용해야합니다.
이상적으로는 커플 링이 최고로 간주되지 않습니다.
디자인 검증
소프트웨어 설계 프로세스의 출력은 설계 문서, 의사 코드, 세부 논리 다이어그램, 프로세스 다이어그램 및 모든 기능 또는 비 기능 요구 사항에 대한 자세한 설명입니다.
소프트웨어 구현 인 다음 단계는 위에서 언급 한 모든 출력에 따라 달라집니다.
그러면 다음 단계로 진행하기 전에 출력을 확인해야합니다. 실수를 조기에 발견할수록 제품을 테스트 할 때까지 더 잘 발견되거나 발견되지 않을 수 있습니다. 설계 단계의 출력이 공식 표기 형식 인 경우 관련 검증 도구를 사용해야합니다. 그렇지 않으면 철저한 설계 검토를 검증 및 검증에 사용할 수 있습니다.
구조화 된 검증 접근 방식을 통해 검토자는 일부 조건을 간과하여 발생할 수있는 결함을 감지 할 수 있습니다. 좋은 소프트웨어 설계, 정확성 및 품질을 위해서는 좋은 설계 검토가 중요합니다.
소프트웨어 분석 및 설계에는 요구 사항 사양을 구현으로 변환하는 데 도움이되는 모든 활동이 포함됩니다. 요구 사항 사양은 소프트웨어의 모든 기능 및 비 기능적 기대치를 지정합니다. 이러한 요구 사항 사양은 사람이 읽을 수 있고 이해할 수있는 문서의 형태로 제공되며 컴퓨터가 할 일이 없습니다.
소프트웨어 분석 및 디자인은 사람이 읽을 수있는 요구 사항을 실제 코드로 변환하는 데 도움이되는 중간 단계입니다.
소프트웨어 설계자가 사용하는 몇 가지 분석 및 설계 도구를 살펴 보겠습니다.
데이터 흐름 다이어그램
데이터 흐름 다이어그램은 정보 시스템에서 데이터 흐름을 그래픽으로 표현한 것입니다. 들어오는 데이터 흐름, 나가는 데이터 흐름 및 저장된 데이터를 묘사 할 수 있습니다. DFD는 데이터가 시스템을 통과하는 방식에 대해 언급하지 않습니다.
DFD와 순서도 간에는 현저한 차이가 있습니다. 순서도는 프로그램 모듈의 제어 흐름을 나타냅니다. DFD는 다양한 수준에서 시스템의 데이터 흐름을 나타냅니다. DFD에는 제어 또는 분기 요소가 없습니다.
DFD의 유형
데이터 흐름 다이어그램은 논리적이거나 물리적입니다.
- Logical DFD -이 유형의 DFD는 시스템 프로세스 및 시스템의 데이터 흐름에 집중합니다 (예 : 은행 소프트웨어 시스템에서 데이터가 서로 다른 엔티티간에 이동하는 방법).
- Physical DFD-이 유형의 DFD는 데이터 흐름이 시스템에서 실제로 구현되는 방식을 보여줍니다. 더 구체적이고 구현에 가깝습니다.
DFD 구성 요소
DFD는 다음 구성 요소 세트를 사용하여 소스, 대상, 스토리지 및 데이터 흐름을 나타낼 수 있습니다.
- Entities-엔티티는 정보 데이터의 소스 및 대상입니다. 엔티티는 각각의 이름이있는 직사각형으로 표시됩니다.
- Process -데이터에 대한 활동 및 조치는 원형 또는 둥근 사각형으로 표시됩니다.
- Data Storage -데이터 저장에는 두 가지 변형이 있습니다. 작은 변이없는 직사각형 또는 한쪽 만 누락 된 개방형 직사각형으로 표시 할 수 있습니다.
- Data Flow-데이터 이동은 뾰족한 화살표로 표시됩니다. 데이터 이동은 원본으로 화살표 밑에서 화살표 머리 방향으로 대상으로 표시됩니다.
DFD 수준
- Level 0-가장 높은 추상화 수준 DFD는 수준 0 DFD로 알려져 있으며 전체 정보 시스템을 모든 기본 세부 정보를 은폐하는 하나의 다이어그램으로 묘사합니다. 레벨 0 DFD는 컨텍스트 레벨 DFD라고도합니다.
- Level 1-레벨 0 DFD는보다 구체적인 레벨 1 DFD로 나뉩니다. 레벨 1 DFD는 시스템의 기본 모듈과 다양한 모듈 간의 데이터 흐름을 나타냅니다. 레벨 1 DFD는 기본 프로세스 및 정보 소스도 언급합니다.
Level 2 -이 레벨에서 DFD는 레벨 1에서 언급 한 모듈 내부에서 데이터가 어떻게 흐르는 지 보여줍니다.
높은 수준의 DFD는 원하는 수준의 사양이 달성되지 않는 한 더 깊은 수준의 이해를 통해보다 구체적인 낮은 수준의 DFD로 변환 될 수 있습니다.
구조 차트
구조 차트는 데이터 흐름 다이어그램에서 파생 된 차트입니다. DFD보다 더 자세하게 시스템을 나타냅니다. 전체 시스템을 가장 낮은 기능의 모듈로 나누고 시스템 각 모듈의 기능과 하위 기능을 DFD보다 더 자세히 설명합니다.
구조 차트는 모듈의 계층 구조를 나타냅니다. 각 계층에서 특정 작업이 수행됩니다.
다음은 구조도 구성에 사용되는 기호입니다.
- Module-프로세스 또는 서브 루틴 또는 작업을 나타냅니다. 제어 모듈은 둘 이상의 하위 모듈로 분기됩니다. 라이브러리 모듈은 모든 모듈에서 재사용 및 호출이 가능합니다.
- Condition-모듈 하단에 작은 다이아몬드로 표시됩니다. 제어 모듈이 어떤 조건에 따라 서브 루틴을 선택할 수 있음을 나타냅니다.
- Jump -모듈 내부를 가리키는 화살표가 표시되어 컨트롤이 하위 모듈 중간에서 점프 함을 나타냅니다.
- Loop-곡선 화살표는 모듈의 루프를 나타냅니다. 루프에 포함 된 모든 하위 모듈은 모듈 실행을 반복합니다.
- Data flow -끝에 빈 원이있는 방향 화살표는 데이터 흐름을 나타냅니다.
- Control flow -끝에 채워진 원이있는 방향 화살표는 제어 흐름을 나타냅니다.
HIPO 다이어그램
HIPO (Hierarchical Input Process Output) 다이어그램은 시스템을 분석하고 문서화 수단을 제공하기 위해 두 가지 조직화 된 방법의 조합입니다. HIPO 모델은 1970 년 IBM에서 개발했습니다.
HIPO 다이어그램은 소프트웨어 시스템의 모듈 계층을 나타냅니다. 분석가는 HIPO 다이어그램을 사용하여 시스템 기능에 대한 높은 수준의보기를 얻습니다. 계층 적 방식으로 기능을 하위 기능으로 분해합니다. 시스템에서 수행하는 기능을 설명합니다.
HIPO 다이어그램은 문서화 목적에 적합합니다. 이들의 그래픽 표현은 설계자와 관리자가 시스템 구조에 대한 그림 아이디어를 쉽게 얻을 수 있도록합니다.
모듈의 제어 및 데이터 흐름을 나타내는 IPO (Input Process Output) 다이어그램과 달리 HIPO는 데이터 흐름 또는 제어 흐름에 대한 정보를 제공하지 않습니다.
예
HIPO 다이어그램, 계층 적 프리젠 테이션 및 IPO 차트의 두 부분은 소프트웨어 프로그램의 구조 설계 및 동일한 문서화에 사용됩니다.
구조화 된 영어
대부분의 프로그래머는 소프트웨어의 큰 그림을 인식하지 못하기 때문에 관리자가 지시하는 작업에만 의존합니다. 정확하면서도 빠른 코드를 개발하기 위해 프로그래머에게 정확한 정보를 제공하는 것은 상위 소프트웨어 관리의 책임입니다.
그래프 나 다이어그램을 사용하는 다른 형태의 방법은 때때로 사람마다 다르게 해석 될 수 있습니다.
따라서 소프트웨어의 분석가와 디자이너는 Structured English와 같은 도구를 제공합니다. 코딩에 필요한 내용과 코딩 방법에 대한 설명 일뿐입니다. 구조화 된 영어는 프로그래머가 오류없는 코드를 작성하는 데 도움이됩니다.
그래프 나 다이어그램을 사용하는 다른 형태의 방법은 때때로 사람마다 다르게 해석 될 수 있습니다. 여기서 Structured English와 Pseudo-Code는 이러한 이해 격차를 완화하려고합니다.
구조화 된 영어는 구조화 된 프로그래밍 패러다임에서 일반 영어 단어를 사용합니다. 궁극적 인 코드가 아니라 코딩에 필요한 내용과 코딩 방법에 대한 일종의 설명입니다. 다음은 구조화 된 프로그래밍의 일부 토큰입니다.
IF-THEN-ELSE,
DO-WHILE-UNTIL
Analyst는 데이터 사전에 저장된 동일한 변수 및 데이터 이름을 사용하므로 코드를 작성하고 이해하는 것이 훨씬 더 간단 해집니다.
예
온라인 쇼핑 환경에서 고객 인증의 동일한 예를 사용합니다. 고객 인증 절차는 다음과 같이 구조화 된 영어로 작성할 수 있습니다.
Enter Customer_Name
SEEK Customer_Name in Customer_Name_DB file
IF Customer_Name found THEN
Call procedure USER_PASSWORD_AUTHENTICATE()
ELSE
PRINT error message
Call procedure NEW_CUSTOMER_REQUEST()
ENDIF
구조화 된 영어로 작성된 코드는 일상적인 영어 구어와 비슷합니다. 소프트웨어 코드로 직접 구현할 수 없습니다. 구조화 된 영어는 프로그래밍 언어와 무관합니다.
의사 코드
의사 코드는 프로그래밍 언어에 더 가깝게 작성됩니다. 주석과 설명이 가득한 증강 프로그래밍 언어로 간주 될 수 있습니다.
의사 코드는 변수 선언을 피하지만 C, Fortran, Pascal 등과 같은 실제 프로그래밍 언어 구조를 사용하여 작성됩니다.
의사 코드에는 구조화 된 영어보다 더 많은 프로그래밍 세부 정보가 포함되어 있습니다. 마치 컴퓨터가 코드를 실행하는 것처럼 작업을 수행하는 방법을 제공합니다.
예
피보나치를 n 개까지 출력하는 프로그램.
void function Fibonacci
Get value of n;
Set value of a to 1;
Set value of b to 1;
Initialize I to 0
for (i=0; i< n; i++)
{
if a greater than b
{
Increase b by a;
Print b;
}
else if b greater than a
{
increase a by b;
print a;
}
}
의사 결정 테이블
의사 결정 테이블은 구조화 된 표 형식으로 조건과이를 해결하기 위해 취해야 할 각 조치를 나타냅니다.
오류를 디버그하고 방지하는 강력한 도구입니다. 유사한 정보를 단일 테이블로 그룹화 한 다음 테이블을 결합하여 쉽고 편리한 의사 결정을 제공합니다.
의사 결정 테이블 생성
의사 결정 테이블을 작성하려면 개발자는 기본 네 단계를 따라야합니다.
- 해결할 수있는 모든 조건 식별
- 확인 된 모든 조건에 대한 조치 결정
- 가능한 최대 규칙 만들기
- 각 규칙에 대한 작업 정의
의사 결정 테이블은 최종 사용자가 확인해야하며 최근에는 중복 규칙 및 작업을 제거하여 단순화 할 수 있습니다.
예
인터넷 연결과 관련된 일상적인 문제의 간단한 예를 들어 보겠습니다. 인터넷을 시작하는 동안 발생할 수있는 모든 문제와 각각의 가능한 해결책을 식별하는 것으로 시작합니다.
열 조건에서 가능한 모든 문제를 나열하고 조치 열에서 예상 조치를 나열합니다.
조건 / 조치 | 규칙 | ||||||||
---|---|---|---|---|---|---|---|---|---|
정황 | 연결된 쇼 | 엔 | 엔 | 엔 | 엔 | 와이 | 와이 | 와이 | 와이 |
Ping이 작동 중입니다. | 엔 | 엔 | 와이 | 와이 | 엔 | 엔 | 와이 | 와이 | |
웹 사이트를 엽니 다 | 와이 | 엔 | 와이 | 엔 | 와이 | 엔 | 와이 | 엔 | |
행위 | 네트워크 케이블 확인 | 엑스 | |||||||
인터넷 라우터 확인 | 엑스 | 엑스 | 엑스 | 엑스 | |||||
웹 브라우저 다시 시작 | 엑스 | ||||||||
서비스 제공 업체에 문의 | 엑스 | 엑스 | 엑스 | 엑스 | 엑스 | 엑스 | |||
조치하지 마십시오 |
엔터티 관계 모델
엔티티-관계 모델은 실제 엔티티와 이들 간의 관계 개념을 기반으로하는 데이터베이스 모델 유형입니다. 실제 시나리오를 ER 데이터베이스 모델에 매핑 할 수 있습니다. ER 모델은 속성, 제약 조건 및 관계를 가진 개체 집합을 만듭니다.
ER 모델은 데이터베이스의 개념 설계에 가장 적합합니다. ER 모델은 다음과 같이 나타낼 수 있습니다.
Entity -ER 모델의 엔티티는 실제 세계이며 attributes. 모든 속성은 해당 값 집합에 의해 정의됩니다.domain.
예를 들어, 학교 데이터베이스를 고려하십시오. 여기에서 학생은 실체입니다. 학생은 이름, 아이디, 나이, 수업 등 다양한 속성을 가지고 있습니다.
Relationship -엔티티 간의 논리적 연관을 호출합니다. relationship. 관계는 다양한 방식으로 엔터티와 매핑됩니다. 매핑 카디널리티는 두 엔터티 간의 연결 수를 정의합니다.
카디널리티 매핑 :
- 1-1
- 일대 다
- 다 대일
- 다 대다
데이터 사전
데이터 사전은 데이터에 대한 중앙 집중식 정보 모음입니다. 데이터의 의미와 출처, 다른 데이터와의 관계, 사용을위한 데이터 형식 등을 저장합니다. 데이터 사전에는 사용자 및 소프트웨어 설계자를 용이하게하기 위해 모든 이름에 대한 엄격한 정의가 있습니다.
데이터 사전은 종종 메타 데이터 (데이터에 대한 데이터) 저장소로 참조됩니다. 소프트웨어 프로그램의 DFD (Data Flow Diagram) 모델과 함께 생성되며 DFD가 변경되거나 업데이트 될 때마다 업데이트 될 예정입니다.
데이터 사전 요구 사항
데이터는 소프트웨어를 설계하고 구현하는 동안 데이터 사전을 통해 참조됩니다. 데이터 사전은 모호성의 가능성을 제거합니다. 프로그램의 모든 곳에서 동일한 객체 참조를 사용하면서 프로그래머와 디자이너의 작업을 동기화하는 데 도움이됩니다.
데이터 사전은 한 곳에서 전체 데이터베이스 시스템에 대한 문서화 방법을 제공합니다. DFD의 유효성 검사는 데이터 사전을 사용하여 수행됩니다.
내용
데이터 사전에는 다음에 대한 정보가 포함되어야합니다.
- 데이터 흐름
- 데이터 구조
- 데이터 요소
- 데이터 저장소
- 데이터 처리
데이터 흐름은 앞에서 연구 한 DFD를 통해 설명되고 설명 된대로 대수 형식으로 표현됩니다.
= | 구성 |
---|---|
{} | 되풀이 |
() | 선택 과목 |
+ | 과 |
[/] | 또는 |
예
주소 = 집 번호 + (거리 / 지역) + 도시 + 주
과정 ID = 과정 번호 + 과정 이름 + 과정 수준 + 과정 성적
데이터 요소
데이터 요소는 데이터 및 제어 항목의 이름과 설명, 내부 또는 외부 데이터 저장소 등으로 구성되며 다음 세부 정보가 있습니다.
- 기본 이름
- 보조 이름 (별칭)
- 사용 사례 (사용 방법 및 위치)
- 내용 설명 (표기 등)
- 추가 정보 (사전 설정 값, 제약 조건 등)
데이터 저장소
데이터가 시스템에 입력되고 시스템 외부에 존재하는 정보를 저장합니다. 데이터 저장소에는 다음이 포함될 수 있습니다.
- Files
- 소프트웨어 내부.
- 소프트웨어 외부에 있지만 동일한 시스템에 있습니다.
- 다른 시스템에있는 소프트웨어 및 시스템 외부.
- Tables
- 명명 규칙
- 인덱싱 속성
데이터 처리
데이터 처리에는 두 가지 유형이 있습니다.
- Logical: 사용자가 볼 때
- Physical: 소프트웨어가 보는대로
소프트웨어 디자인은 소프트웨어 요구 사항을 소프트웨어 구현으로 개념화하는 프로세스입니다. 소프트웨어 설계는 사용자 요구 사항을 도전으로 받아들이고 최적의 솔루션을 찾으려고합니다. 소프트웨어가 개념화되는 동안 의도 한 솔루션을 구현할 수있는 최상의 설계를 찾기위한 계획이 작성됩니다.
소프트웨어 디자인에는 여러 변형이 있습니다. 간략하게 살펴 보겠습니다.
구조화 된 디자인
구조화 된 설계는 문제를 여러 가지 잘 구성된 솔루션 요소로 개념화 한 것입니다. 기본적으로 솔루션 설계와 관련이 있습니다. 구조화 된 설계의 이점은 문제가 해결되는 방식을 더 잘 이해할 수 있다는 것입니다. 구조화 된 디자인은 또한 디자이너가 문제에 더 정확하게 집중하는 것을 더 간단하게 만듭니다.
구조화 된 디자인은 대부분 문제를 여러 개의 작은 문제로 나누고 전체 문제가 해결 될 때까지 각각의 작은 문제가 개별적으로 해결되는 '분할 정복'전략을 기반으로합니다.
작은 문제는 솔루션 모듈을 통해 해결됩니다. 구조화 된 설계는 이러한 모듈이 정확한 솔루션을 얻기 위해 잘 구성되어 있음을 강조합니다.
이러한 모듈은 계층 구조로 정렬됩니다. 그들은 서로 의사 소통합니다. 좋은 구조적 설계는 항상 여러 모듈 간의 통신에 대한 몇 가지 규칙을 따릅니다.
Cohesion -기능적으로 관련된 모든 요소의 그룹화.
Coupling -다른 모듈 간의 통신.
좋은 구조적 디자인은 높은 응집력과 낮은 결합 배열을 갖습니다.
기능 지향 설계
기능 지향 설계에서 시스템은 기능으로 알려진 많은 작은 하위 시스템으로 구성됩니다. 이러한 기능은 시스템에서 중요한 작업을 수행 할 수 있습니다. 이 시스템은 모든 기능의 평면도로 간주됩니다.
기능 지향 디자인은 분할 및 정복 방법론이 사용되는 구조적 디자인의 일부 속성을 상속합니다.
이 설계 메커니즘은 전체 시스템을 더 작은 기능으로 분할하여 정보와 그 작동을 은폐하여 추상화 수단을 제공합니다. 이러한 기능 모듈은 정보를 전달하고 전 세계적으로 사용 가능한 정보를 사용하여 정보를 서로 공유 할 수 있습니다.
함수의 또 다른 특징은 프로그램이 함수를 호출 할 때 해당 함수가 프로그램의 상태를 변경한다는 것입니다. 이는 다른 모듈에서 허용하지 않는 경우도 있습니다. 기능 지향 설계는 시스템 상태가 중요하지 않고 프로그램 / 기능이 상태가 아닌 입력에서 작동하는 경우 잘 작동합니다.
디자인 과정
- 전체 시스템은 데이터 흐름 다이어그램을 통해 시스템에서 데이터가 흐르는 방식으로 간주됩니다.
- DFD는 기능이 전체 시스템의 데이터 및 상태를 변경하는 방법을 보여줍니다.
- 전체 시스템은 시스템에서의 작동에 따라 기능이라고하는 더 작은 단위로 논리적으로 분류됩니다.
- 그런 다음 각 기능에 대해 자세히 설명합니다.
객체 지향 디자인
객체 지향 디자인은 소프트웨어 시스템과 관련된 기능 대신 엔티티와 그 특성을 중심으로 작동합니다. 이 디자인 전략은 엔티티와 그 특성에 중점을 둡니다. 소프트웨어 솔루션의 전체 개념은 참여하는 엔티티를 중심으로합니다.
객체 지향 디자인의 중요한 개념을 살펴 보겠습니다.
- Objects - 솔루션 디자인에 관련된 모든 엔터티를 개체라고합니다. 예를 들어, 사람, 은행, 회사 및 고객은 객체로 취급됩니다. 모든 엔티티에는 연관된 속성이 있으며 속성에 대해 수행 할 메소드가 있습니다.
Classes - 클래스는 객체에 대한 일반화 된 설명입니다. 객체는 클래스의 인스턴스입니다. 클래스는 객체가 가질 수있는 모든 속성과 객체의 기능을 정의하는 메서드를 정의합니다.
솔루션 설계에서 속성은 변수로 저장되고 기능은 방법 또는 절차를 통해 정의됩니다.
- Encapsulation - OOD에서는 속성 (데이터 변수)과 메서드 (데이터에 대한 작업)가 함께 묶여있는 것을 캡슐화라고합니다. 캡슐화는 개체의 중요한 정보를 함께 묶을뿐만 아니라 외부 세계에서 데이터 및 메서드에 대한 액세스를 제한합니다. 이것을 정보 숨김이라고합니다.
- Inheritance - OOD를 사용하면 하위 또는 하위 클래스가 즉시 수퍼 클래스에서 허용 된 변수 및 메서드를 가져오고 구현하고 재사용 할 수있는 계층 적 방식으로 유사한 클래스를 쌓을 수 있습니다. 이 OOD 속성을 상속이라고합니다. 이렇게하면 특정 클래스를 정의하고 특정 클래스에서 일반화 된 클래스를 쉽게 만들 수 있습니다.
- Polymorphism - OOD 언어는 유사한 작업을 수행하지만 인수가 다른 메서드에 동일한 이름을 할당 할 수있는 메커니즘을 제공합니다. 이를 다형성 (polymorphism)이라고하며 단일 인터페이스가 다양한 유형에 대한 작업을 수행 할 수 있도록합니다. 함수가 호출되는 방법에 따라 코드의 각 부분이 실행됩니다.
디자인 과정
소프트웨어 설계 프로세스는 일련의 잘 정의 된 단계로 인식 될 수 있습니다. 디자인 접근 방식 (기능 지향 또는 객체 지향)에 따라 다르지만 다음 단계가 포함될 수 있습니다.
- 솔루션 설계는 요구 사항 또는 이전에 사용한 시스템 및 / 또는 시스템 시퀀스 다이어그램에서 생성됩니다.
- 객체는 속성 특성의 유사성을 대신하여 식별되고 클래스로 그룹화됩니다.
- 클래스 계층 구조 및 이들 간의 관계가 정의됩니다.
- 애플리케이션 프레임 워크가 정의됩니다.
소프트웨어 설계 접근 방식
다음은 소프트웨어 설계를위한 두 가지 일반적인 접근 방식입니다.
하향식 설계
우리는 시스템이 하나 이상의 하위 시스템으로 구성되고 여러 구성 요소를 포함하고 있음을 알고 있습니다. 또한 이러한 하위 시스템 및 구성 요소는 하위 시스템 및 구성 요소의 집합을 가질 수 있으며 시스템에서 계층 구조를 만듭니다.
하향식 설계는 전체 소프트웨어 시스템을 하나의 엔티티로 취한 다음이를 분해하여 일부 특성에 따라 둘 이상의 하위 시스템 또는 구성 요소를 달성합니다. 그런 다음 각 하위 시스템 또는 구성 요소는 시스템으로 처리되고 추가로 분해됩니다. 이 프로세스는 하향식 계층 구조에서 가장 낮은 수준의 시스템에 도달 할 때까지 계속 실행됩니다.
하향식 설계는 일반화 된 시스템 모델에서 시작하여 더 구체적인 부분을 계속 정의합니다. 모든 구성 요소가 구성되면 전체 시스템이 존재합니다.
하향식 설계는 소프트웨어 솔루션을 처음부터 설계해야하고 특정 세부 사항을 알 수없는 경우에 더 적합합니다.
상향식 설계
상향식 설계 모델은 가장 구체적이고 기본적인 구성 요소로 시작됩니다. 기본 또는 하위 수준의 구성 요소를 사용하여 더 높은 수준의 구성 요소 구성을 진행합니다. 원하는 시스템이 하나의 단일 구성 요소로 발전하지 않을 때까지 더 높은 수준의 구성 요소를 계속 생성합니다. 각 수준이 높을수록 추상화의 양이 증가합니다.
상향식 전략은 새로운 시스템에서 기본 프리미티브를 사용할 수있는 기존 시스템에서 시스템을 생성해야 할 때 더 적합합니다.
하향식 및 상향식 접근 방식은 모두 개별적으로 실용적이지 않습니다. 대신 두 가지의 좋은 조합이 사용됩니다.
사용자 인터페이스는 사용자가 소프트웨어를 사용하기 위해 상호 작용하는 프런트 엔드 애플리케이션보기입니다. 사용자는 사용자 인터페이스를 통해 하드웨어뿐만 아니라 소프트웨어를 조작하고 제어 할 수 있습니다. 오늘날 사용자 인터페이스는 컴퓨터, 휴대폰, 자동차, 음악 플레이어, 비행기, 선박 등 디지털 기술이 존재하는 거의 모든 곳에서 찾을 수 있습니다.
사용자 인터페이스는 소프트웨어의 일부이며 소프트웨어에 대한 사용자 통찰력을 제공 할 수 있도록 설계되었습니다. UI는 인간-컴퓨터 상호 작용을위한 기본 플랫폼을 제공합니다.
UI는 기본 하드웨어 및 소프트웨어 조합에 따라 그래픽, 텍스트 기반, 오디오-비디오 기반이 될 수 있습니다. UI는 하드웨어 나 소프트웨어 또는 둘의 조합 일 수 있습니다.
사용자 인터페이스가 다음과 같으면 소프트웨어가 더 많이 사용됩니다.
- Attractive
- 간편한 사용
- 단시간에 대응
- 이해하기 쉬움
- 모든 인터페이스 화면에서 일관됨
UI는 크게 두 가지 범주로 나뉩니다.
- 명령 줄 인터페이스
- 그래픽 사용자 인터페이스
명령 줄 인터페이스 (CLI)
CLI는 비디오 디스플레이 모니터가 등장 할 때까지 컴퓨터와 상호 작용하는 훌륭한 도구였습니다. CLI는 많은 기술 사용자와 프로그래머의 첫 번째 선택입니다. CLI는 소프트웨어가 사용자에게 제공 할 수있는 최소 인터페이스입니다.
CLI는 사용자가 명령을 입력하고 시스템에 공급하는 위치 인 명령 프롬프트를 제공합니다. 사용자는 명령 구문과 사용법을 기억해야합니다. 이전 CLI는 사용자 오류를 효과적으로 처리하도록 프로그래밍되지 않았습니다.
명령은 시스템에서 실행될 것으로 예상되는 명령 집합에 대한 텍스트 기반 참조입니다. 사용자가 쉽게 조작 할 수 있도록하는 매크로, 스크립트와 같은 방법이 있습니다.
CLI는 GUI에 비해 적은 양의 컴퓨터 리소스를 사용합니다.
CLI 요소
텍스트 기반 명령 줄 인터페이스에는 다음 요소가 포함될 수 있습니다.
Command Prompt-주로 사용자가 작업하고있는 상황을 보여주는 텍스트 기반 알림입니다. 소프트웨어 시스템에 의해 생성됩니다.
Cursor-입력하는 동안 문자의 위치를 나타 내기 위해 작은 가로줄 또는 줄 높이의 세로 막대입니다. 커서는 대부분 깜박임 상태에서 발견됩니다. 사용자가 무언가를 쓰거나 삭제할 때 이동합니다.
Command-명령은 실행 가능한 명령입니다. 하나 이상의 매개 변수가있을 수 있습니다. 명령 실행에 대한 출력은 화면에 인라인으로 표시됩니다. 출력이 생성되면 다음 줄에 명령 프롬프트가 표시됩니다.
그래픽 사용자 인터페이스
그래픽 사용자 인터페이스는 시스템과 상호 작용할 수있는 사용자 그래픽 수단을 제공합니다. GUI는 하드웨어와 소프트웨어의 조합이 될 수 있습니다. 사용자는 GUI를 사용하여 소프트웨어를 해석합니다.
일반적으로 GUI는 CLI보다 리소스를 더 많이 소비합니다. 진보 된 기술을 통해 프로그래머와 디자이너는 더 높은 효율성, 정확성 및 속도로 작동하는 복잡한 GUI 디자인을 만듭니다.
GUI 요소
GUI는 소프트웨어 또는 하드웨어와 상호 작용하는 구성 요소 집합을 제공합니다.
모든 그래픽 구성 요소는 시스템 작업 방법을 제공합니다. GUI 시스템에는 다음과 같은 요소가 있습니다.
Window-응용 프로그램의 내용이 표시되는 영역입니다. 창이 파일 구조를 나타내는 경우 창의 내용을 아이콘 또는 목록 형식으로 표시 할 수 있습니다. 사용자가 탐색 창에서 파일 시스템을 탐색하는 것이 더 쉽습니다. 창을 화면 크기에 맞게 최소화, 크기 조정 또는 최대화 할 수 있습니다. 화면 어디로 든 이동할 수 있습니다. 창에는 자식 창이라고하는 동일한 응용 프로그램의 다른 창이 포함될 수 있습니다.
Tabs -응용 프로그램이 자신의 여러 인스턴스를 실행하도록 허용하면 화면에 별도의 창으로 나타납니다. Tabbed Document Interface같은 창에서 여러 문서를 열었습니다. 이 인터페이스는 응용 프로그램에서 기본 설정 패널을 보는데도 도움이됩니다. 모든 최신 웹 브라우저는이 기능을 사용합니다.
Menu-메뉴는 함께 그룹화되어 응용 프로그램 창 내부의 보이는 위치 (일반적으로 상단)에 배치되는 표준 명령의 배열입니다. 메뉴는 마우스 클릭시 나타나거나 숨기도록 프로그래밍 할 수 있습니다.
Icon-아이콘은 관련 응용 프로그램을 나타내는 작은 그림입니다. 이러한 아이콘을 클릭하거나 두 번 클릭하면 응용 프로그램 창이 열립니다. 아이콘은 시스템에 설치된 응용 프로그램과 프로그램을 작은 그림으로 표시합니다.
Cursor-마우스, 터치 패드, 디지털 펜 등 상호 작용하는 장치는 GUI에 커서로 표시됩니다. 화면 커서는 거의 실시간으로 하드웨어의 지시를 따릅니다. 커서는 GUI 시스템에서 포인터라고도합니다. 메뉴, 창 및 기타 응용 프로그램 기능을 선택하는 데 사용됩니다.
애플리케이션 별 GUI 구성 요소
애플리케이션의 GUI에는 나열된 GUI 요소 중 하나 이상이 포함됩니다.
Application Window -대부분의 응용 프로그램 창은 운영 체제에서 제공하는 구성을 사용하지만 대부분은 응용 프로그램의 내용을 포함하기 위해 고객이 만든 창을 사용합니다.
Dialogue Box -사용자에 대한 메시지와 취해야 할 조치를 요청하는 하위 창입니다. 예 : 응용 프로그램은 사용자로부터 파일 삭제를 확인하는 대화 상자를 생성합니다.
Text-Box -사용자가 텍스트 기반 데이터를 입력하고 입력 할 수있는 영역을 제공합니다.
Buttons -실제 버튼을 모방하고 소프트웨어에 입력을 제출하는 데 사용됩니다.
Radio-button-선택 가능한 옵션을 표시합니다. 제공되는 모든 항목 중 하나만 선택할 수 있습니다.
Check-box-목록 상자와 유사한 기능. 옵션을 선택하면 상자가 선택된 것으로 표시됩니다. 확인란으로 표시되는 여러 옵션을 선택할 수 있습니다.
List-box -선택 가능한 항목 목록을 제공합니다. 하나 이상의 항목을 선택할 수 있습니다.
다른 인상적인 GUI 구성 요소는 다음과 같습니다.
- Sliders
- Combo-box
- Data-grid
- 드롭 다운 목록
사용자 인터페이스 디자인 활동
사용자 인터페이스를 디자인하기 위해 수행되는 여러 활동이 있습니다. GUI 설계 및 구현 프로세스는 SDLC와 비슷합니다. Waterfall, Iterative 또는 Spiral Model 사이에서 GUI 구현을 위해 모든 모델을 사용할 수 있습니다.
GUI 디자인 및 개발에 사용되는 모델은 이러한 GUI 특정 단계를 수행해야합니다.
GUI Requirement Gathering-설계자는 GUI의 모든 기능 및 비 기능 요구 사항 목록을 갖고 싶어 할 수 있습니다. 이것은 사용자와 기존 소프트웨어 솔루션에서 가져올 수 있습니다.
User Analysis-디자이너는 소프트웨어 GUI를 사용할 사람을 연구합니다. 사용자의 지식과 역량 수준에 따라 디자인 세부 사항이 변경되므로 대상 고객이 중요합니다. 사용자가 기술에 정통한 경우 고급 및 복잡한 GUI를 통합 할 수 있습니다. 초보 사용자의 경우 소프트웨어 사용 방법에 대한 자세한 정보가 포함되어 있습니다.
Task Analysis-설계자는 소프트웨어 솔루션으로 수행 할 작업을 분석해야합니다. 여기 GUI에서는 어떻게 할 것인지는 중요하지 않습니다. 작업은 하나의 주요 작업을 더 작은 하위 작업으로 더 나눌 수있는 계층 적 방식으로 표현 될 수 있습니다. 태스크는 GUI 프리젠 테이션에 대한 목표를 제공합니다. 하위 작업 간의 정보 흐름은 소프트웨어에서 GUI 콘텐츠의 흐름을 결정합니다.
GUI Design & implementation-디자이너는 요구 사항, 작업 및 사용자 환경에 대한 정보를 얻은 후 GUI를 설계하고 코드에 구현하고 백그라운드에서 작업 또는 더미 소프트웨어와 함께 GUI를 내장합니다. 그런 다음 개발자가 자체 테스트합니다.
Testing-GUI 테스트는 다양한 방법으로 수행 할 수 있습니다. 조직은 사내 검사, 사용자 직접 참여 및 베타 버전 출시를 할 수 있습니다. 테스트에는 유용성, 호환성, 사용자 수용 등이 포함될 수 있습니다.
GUI 구현 도구
디자이너가 마우스 클릭으로 전체 GUI를 만들 수있는 여러 도구를 사용할 수 있습니다. 일부 도구는 소프트웨어 환경 (IDE)에 포함될 수 있습니다.
GUI 구현 도구는 강력한 GUI 컨트롤을 제공합니다. 소프트웨어 사용자 정의를 위해 디자이너는 그에 따라 코드를 변경할 수 있습니다.
서로 다른 용도 및 플랫폼에 따라 GUI 도구의 여러 세그먼트가 있습니다.
예
모바일 GUI, 컴퓨터 GUI, 터치 스크린 GUI 등. 다음은 GUI를 구축하는 데 유용한 몇 가지 도구 목록입니다.
- FLUID
- AppInventor (Android)
- LucidChart
- Wavemaker
- 비주얼 스튜디오
사용자 인터페이스 황금 규칙
다음 규칙은 Shneiderman과 Plaisant가 저서 (Designing the User Interface)에서 설명한 GUI 디자인의 황금 규칙으로 언급됩니다.
Strive for consistency-유사한 상황에서 일관된 일련의 조치가 필요합니다. 프롬프트, 메뉴 및 도움말 화면에서 동일한 용어를 사용해야합니다. 전체적으로 일관된 명령을 사용해야합니다.
Enable frequent users to use short-cuts-사용 빈도에 따라 상호 작용 횟수를 줄이고 자하는 사용자의 욕구가 증가합니다. 약어, 기능 키, 숨겨진 명령 및 매크로 기능은 전문 사용자에게 매우 유용합니다.
Offer informative feedback-모든 운영자 조치에 대해 시스템 피드백이 있어야합니다. 빈번하고 사소한 조치의 경우 응답은 겸손해야하며, 드문 및 주요 조치의 경우 응답이 더 중요해야합니다.
Design dialog to yield closure-일련의 행동은 시작, 중간, 끝이있는 그룹으로 구성되어야합니다. 일련의 작업 완료시 유익한 피드백은 운영자에게 성취에 대한 만족도, 안도감, 비상 계획 및 옵션을 마음에서 버리라는 신호를 제공하며, 이는 다음을 준비 할 수있는 방법이 분명함을 나타냅니다. 행동 그룹.
Offer simple error handling-가능한 한 사용자가 심각한 오류를 범하지 않도록 시스템을 설계하십시오. 오류가 발생하면 시스템은 오류를 감지하고 오류를 처리하기위한 간단하고 이해 가능한 메커니즘을 제공 할 수 있어야합니다.
Permit easy reversal of actions-이 기능은 사용자가 오류를 되돌릴 수 있다는 것을 알고 있기 때문에 불안감을 덜어줍니다. 손쉬운 작업 반전은 익숙하지 않은 옵션의 탐색을 장려합니다. 가역성 단위는 단일 작업, 데이터 입력 또는 전체 작업 그룹 일 수 있습니다.
Support internal locus of control-숙련 된 운영자는 자신이 시스템을 담당하고 있으며 시스템이 자신의 행동에 반응한다는 느낌을 강하게 원합니다. 사용자가 응답자가 아닌 행동의 시작자가되도록 시스템을 설계하십시오.
Reduce short-term memory load -단기 기억에서 인간 정보 처리의 한계는 디스플레이를 단순하게 유지하고, 여러 페이지 디스플레이를 통합하고, 창 이동 빈도를 줄이고, 코드, 니모닉 및 일련의 작업에 충분한 교육 시간을 할당해야합니다.
복잡성이라는 용어는 여러 개의 상호 연결된 링크와 매우 복잡한 구조를 가진 이벤트 또는 사물의 상태를 나타냅니다. 소프트웨어 프로그래밍에서 소프트웨어 설계가 실현됨에 따라 요소의 수와 상호 연결이 점차 커져서 한 번에 이해하기가 너무 어려워집니다.
소프트웨어 설계 복잡성은 복잡성 메트릭 및 측정을 사용하지 않고 평가하기가 어렵습니다. 세 가지 중요한 소프트웨어 복잡성 측정을 살펴 보겠습니다.
Halstead의 복잡성 측정
1977 년에 Maurice Howard Halstead는 소프트웨어 복잡성을 측정하는 메트릭을 도입했습니다. Halstead의 메트릭은 프로그램의 실제 구현과 그 측정 값에 따라 달라지며, 이는 정적 방식으로 소스 코드의 연산자와 피연산자에서 직접 계산됩니다. C / C ++ / Java 소스 코드에 대한 테스트 시간, 어휘, 크기, 난이도, 오류 및 노력을 평가할 수 있습니다.
Halstead에 따르면 "컴퓨터 프로그램은 연산자 또는 피연산자로 분류 할 수있는 토큰 모음으로 간주되는 알고리즘의 구현입니다". Halstead 메트릭은 프로그램을 일련의 연산자 및 관련 피연산자로 생각합니다.
모듈의 복잡성을 확인하기 위해 다양한 지표를 정의합니다.
매개 변수 | 의미 |
---|---|
n1 | 고유 연산자 수 |
n2 | 고유 한 피연산자 수 |
N1 | 연산자의 총 발생 수 |
N2 | 피연산자의 총 발생 수 |
Metric Viewer에서 복잡성 세부 정보를보기 위해 소스 파일을 선택하면 Metric Report에 다음 결과가 표시됩니다.
미터법 | 의미 | 수학적 표현 |
---|---|---|
엔 | 어휘 | n1 + n2 |
엔 | 크기 | N1 + N2 |
V | 음량 | 길이 * Log2 어휘 |
디 | 어려움 | (n1 / 2) * (N1 / n2) |
이자형 | 노력 | 난이도 * 볼륨 |
비 | 오류 | 볼륨 / 3000 |
티 | 테스트 시간 | 시간 = 노력 / S, 여기서 S = 18 초. |
순환 복잡성 측정
모든 프로그램은 어떤 작업을 수행하기 위해 실행할 명령문과 실행해야 할 명령문을 결정하는 기타 의사 결정 명령문을 포함합니다. 이러한 의사 결정 구조는 프로그램의 흐름을 변경합니다.
같은 크기의 두 프로그램을 비교하면 프로그램 제어가 자주 점프하므로 의사 결정문이 더 많은 프로그램이 더 복잡해집니다.
McCabe는 1976 년에 주어진 소프트웨어의 복잡성을 정량화하기 위해 Cyclomatic Complexity Measure를 제안했습니다. if-else, do-while, repeat-until, switch-case 및 goto 문과 같은 프로그램의 의사 결정 구조를 기반으로하는 그래프 기반 모델입니다.
흐름 제어 그래프를 만드는 과정 :
- 의사 결정 구조로 구분 된 작은 블록으로 프로그램을 중단하십시오.
- 이러한 각 노드를 나타내는 노드를 만듭니다.
- 다음과 같이 노드를 연결하십시오.
제어가 블록 i에서 블록 j로 분기 할 수있는 경우
호 그리기
출구 노드에서 입구 노드로
호를 그립니다.
프로그램 모듈의 순환 복잡도를 계산하기 위해 다음 공식을 사용합니다.
V(G) = e – n + 2
Where
e is total number of edges
n is total number of nodes
위 모듈의 순환 복잡성은 다음과 같습니다.
e = 10
n = 8
Cyclomatic Complexity = 10 - 8 + 2
= 4
P. Jorgensen에 따르면 모듈의 순환 복잡성은 10을 초과하지 않아야합니다.
기능 포인트
소프트웨어의 크기를 측정하는 데 널리 사용됩니다. Function Point는 시스템에서 제공하는 기능에 집중합니다. 시스템의 특징과 기능은 소프트웨어 복잡성을 측정하는 데 사용됩니다.
기능 포인트는 외부 입력, 외부 출력, 논리적 내부 파일, 외부 인터페이스 파일 및 외부 조회로 명명 된 5 개의 매개 변수에 포함됩니다. 소프트웨어의 복잡성을 고려하기 위해 각 매개 변수는 단순, 평균 또는 복합으로 추가로 분류됩니다.
기능 포인트의 매개 변수를 보겠습니다.
외부 입력
외부에서 시스템에 대한 모든 고유 한 입력은 외부 입력으로 간주됩니다. 두 개의 입력이 동일한 형식을 가져서는 안되므로 입력의 고유성이 측정됩니다. 이러한 입력은 데이터 또는 제어 매개 변수 일 수 있습니다.
Simple -입력 수가 적고 내부 파일에 영향을 덜 미치는 경우
Complex -입력 수가 많고 더 많은 내부 파일에 영향을 미치는 경우
Average -단순함과 복잡함 사이.
외부 출력
시스템에서 제공하는 모든 출력 유형이이 범주에 포함됩니다. 출력 형식 및 / 또는 처리가 고유 한 경우 출력은 고유 한 것으로 간주됩니다.
Simple -출력 카운트가 낮은 경우
Complex -출력 카운트가 높은 경우
Average -단순함과 복잡함 사이.
논리적 내부 파일
모든 소프트웨어 시스템은 기능 정보를 유지하고 올바르게 작동하기 위해 내부 파일을 유지합니다. 이 파일은 시스템의 논리 데이터를 보유합니다. 이 논리 데이터에는 기능 데이터와 제어 데이터가 모두 포함될 수 있습니다.
Simple -레코드 유형 수가 적은 경우
Complex -레코드 유형 수가 많은 경우
Average -단순함과 복잡함 사이.
외부 인터페이스 파일
소프트웨어 시스템은 파일을 일부 외부 소프트웨어와 공유해야하거나 처리를 위해 파일을 전달하거나 일부 기능에 매개 변수로 전달해야 할 수 있습니다. 이러한 모든 파일은 외부 인터페이스 파일로 계산됩니다.
Simple -공유 파일의 레코드 유형 수가 적은 경우
Complex -공유 파일의 레코드 유형 수가 많은 경우
Average -단순함과 복잡함 사이.
외부 문의
조회는 입력과 출력의 조합으로 사용자가 조회 할 데이터를 입력으로 보내고 시스템은 조회 결과를 처리하여 사용자에게 응답합니다. 쿼리의 복잡성은 외부 입력 및 외부 출력 이상입니다. 입력 및 출력이 형식 및 데이터 측면에서 고유 한 경우 쿼리는 고유하다고합니다.
Simple -쿼리가 낮은 처리를 필요로하고 소량의 출력 데이터를 생성하는 경우
Complex -쿼리에 높은 프로세스가 필요하고 많은 양의 출력 데이터가 생성되는 경우
Average -단순함과 복잡함 사이.
시스템의 각 매개 변수에는 클래스 및 복잡성에 따라 가중치가 부여됩니다. 아래 표에는 각 매개 변수에 주어진 가중치가 나와 있습니다.
매개 변수 | 단순한 | 평균 | 복잡한 |
---|---|---|---|
입력 | 삼 | 4 | 6 |
출력 | 4 | 5 | 7 |
문의 | 삼 | 4 | 6 |
파일 | 7 | 10 | 15 |
인터페이스 | 5 | 7 | 10 |
위의 표는 원시 기능 포인트를 산출합니다. 이러한 기능 포인트는 환경 복잡성에 따라 조정됩니다. 시스템은 14 개의 다른 특성을 사용하여 설명됩니다.
- 데이터 통신
- 분산 처리
- 성능 목표
- 작업 구성 부하
- 거래 율
- 온라인 데이터 입력,
- 최종 사용자 효율성
- 온라인 업데이트
- 복잡한 처리 로직
- Re-usability
- 설치 용이성
- 운영 용이성
- 여러 사이트
- 변화를 촉진하려는 열망
이러한 특성 요소는 아래에 언급 된대로 0에서 5까지 등급이 지정됩니다.
- 영향 없음
- Incidental
- Moderate
- Average
- Significant
- Essential
그런 다음 모든 등급이 N으로 합산됩니다. N 값의 범위는 0에서 70까지입니다 (14 가지 특성 유형 x 5 가지 등급 유형). 다음 공식을 사용하여 복잡성 조정 계수 (CAF)를 계산하는 데 사용됩니다.
CAF = 0.65 + 0.01N
그때,
Delivered Function Points (FP)= CAF x Raw FP
이 FP는 다음과 같은 다양한 메트릭에서 사용할 수 있습니다.
Cost = $ / FP
Quality = 오류 / FP
Productivity = FP / 인-월
이 장에서는 소프트웨어 구현의 프로그래밍 방법, 문서 및 과제에 대해 연구합니다.
구조적 프로그래밍
코딩 과정에서 코드 줄이 계속 늘어나므로 소프트웨어 크기가 증가합니다. 점차적으로 프로그램의 흐름을 기억하는 것이 거의 불가능 해집니다. 소프트웨어와 그 기본 프로그램, 파일, 절차가 어떻게 구성되는지 잊어 버리면 프로그램을 공유, 디버그 및 수정하기가 매우 어려워집니다. 이에 대한 해결책은 구조화 된 프로그래밍입니다. 개발자가 코드에서 간단한 점프를 사용하는 대신 서브 루틴과 루프를 사용하도록 장려하여 코드를 명확하게하고 효율성을 향상시킵니다. 구조화 된 프로그래밍은 프로그래머가 코딩 시간을 줄이고 코드를 적절하게 구성하는 데 도움이됩니다.
구조적 프로그래밍은 프로그램을 코딩하는 방법을 나타냅니다. 구조적 프로그래밍은 세 가지 주요 개념을 사용합니다.
Top-down analysis-소프트웨어는 항상 합리적인 작업을 수행하도록 만들어집니다. 이 합리적인 작업은 소프트웨어 용어의 문제로 알려져 있습니다. 따라서 문제를 해결하는 방법을 이해하는 것이 매우 중요합니다. 하향식 분석에서 문제는 각각의 중요성이있는 작은 조각으로 나뉩니다. 각 문제는 개별적으로 해결되고 문제 해결 방법에 대한 단계가 명확하게 설명됩니다.
Modular Programming-프로그래밍하는 동안 코드는 더 작은 명령 그룹으로 나뉩니다. 이러한 그룹을 모듈, 서브 프로그램 또는 서브 루틴이라고합니다. 하향식 분석에 대한 이해를 기반으로 한 모듈 식 프로그래밍. 프로그램에서 'goto'문을 사용하는 점프를 권장하지 않아 프로그램 흐름을 추적 할 수없는 경우가 많습니다. 구조화 된 프로그래밍에서는 점프가 금지되고 모듈 형식이 권장됩니다.
Structured Coding -하향식 분석과 관련하여 구조화 된 코딩은 모듈을 실행 순서에 따라 더 작은 코드 단위로 세분화합니다. 구조적 프로그래밍은 프로그램의 흐름을 제어하는 제어 구조를 사용하는 반면 구조적 코딩은 제어 구조를 사용하여 정의 가능한 패턴으로 명령을 구성합니다.
함수형 프로그래밍
함수형 프로그래밍은 수학 함수의 개념을 사용하는 프로그래밍 언어의 스타일입니다. 수학의 함수는 항상 동일한 인수를받을 때 동일한 결과를 생성해야합니다. 절차 적 언어에서 프로그램의 흐름은 절차를 통해 실행됩니다. 즉, 프로그램의 제어가 호출 된 절차로 전송됩니다. 제어 흐름이 한 프로 시저에서 다른 프로 시저로 전송되는 동안 프로그램은 상태를 변경합니다.
프로 시저 프로그래밍에서는 프로 시저를 호출하는 동안 프로그램 자체가 다른 상태에있을 수 있으므로 동일한 인수로 호출 될 때 프로 시저가 다른 결과를 생성 할 수 있습니다. 이것은 프로 시저 실행의 순서 나 타이밍이 중요 해지는 프로 시저 프로그래밍의 단점이자 속성입니다.
함수형 프로그래밍은 프로그램 상태에 관계없이 결과를 생성하는 수학 함수로 계산 수단을 제공합니다. 이를 통해 프로그램의 동작을 예측할 수 있습니다.
함수형 프로그래밍은 다음 개념을 사용합니다.
First class and High-order functions -이 함수는 다른 함수를 인수로 받아들이거나 다른 함수를 결과로 반환하는 기능이 있습니다.
Pure functions -이러한 기능은 파괴적인 업데이트를 포함하지 않습니다. 즉, I / O 또는 메모리에 영향을주지 않으며 사용하지 않을 경우 프로그램의 나머지 부분을 방해하지 않고 쉽게 제거 할 수 있습니다.
Recursion-재귀는 함수가 자신을 호출하고 미리 정의 된 일부 조건이 일치하지 않는 한 프로그램 코드를 반복하는 프로그래밍 기술입니다. 재귀는 함수형 프로그래밍에서 루프를 만드는 방법입니다.
Strict evaluation-함수에 인자로 전달 된 표현식을 평가하는 방법입니다. 함수형 프로그래밍에는 strict (eager) 또는 non-strict (lazy)의 두 가지 평가 방법이 있습니다. 엄격한 평가는 항상 함수를 호출하기 전에 표현식을 평가합니다. 비 엄격 평가는 필요한 경우가 아니면 식을 평가하지 않습니다.
λ-calculus-대부분의 함수형 프로그래밍 언어는 유형 시스템으로 λ- 미적분을 사용합니다. λ- 표현식은 발생시 평가하여 실행됩니다.
Common Lisp, Scala, Haskell, Erlang 및 F #은 함수형 프로그래밍 언어의 몇 가지 예입니다.
프로그래밍 스타일
프로그래밍 스타일은 모든 프로그래머가 코드를 작성하는 일련의 코딩 규칙입니다. 여러 프로그래머가 동일한 소프트웨어 프로젝트에서 작업하는 경우 다른 개발자가 작성한 프로그램 코드로 작업해야하는 경우가 많습니다. 모든 개발자가 프로그램을 코딩 할 때 표준 프로그래밍 스타일을 따르지 않으면 이것은 지루하거나 때로는 불가능 해집니다.
적절한 프로그래밍 스타일에는 의도 된 작업과 관련된 함수 및 변수 이름 사용, 잘 배치 된 들여 쓰기 사용, 독자의 편의를위한 코드 주석 달기 및 전체 코드 표시가 포함됩니다. 이를 통해 모든 사람이 프로그램 코드를 읽고 이해할 수 있으므로 디버깅 및 오류 해결이 더 쉬워집니다. 또한 적절한 코딩 스타일은 문서화 및 업데이트를 용이하게합니다.
코딩 지침
코딩 스타일의 실습은 조직, 운영 체제 및 코딩 언어 자체에 따라 다릅니다.
다음 코딩 요소는 조직의 코딩 지침에 따라 정의 될 수 있습니다.
Naming conventions -이 섹션에서는 함수, 변수, 상수 및 전역 변수의 이름을 지정하는 방법을 정의합니다.
Indenting -줄의 시작 부분에 남겨진 공간으로, 보통 2-8 개의 공백 또는 단일 탭입니다.
Whitespace -일반적으로 줄 끝에서 생략됩니다.
Operators-수학, 할당 및 논리 연산자 작성 규칙을 정의합니다. 예를 들어 대입 연산자 '='는 "x = 2"와 같이 앞뒤에 공백이 있어야합니다.
Control Structures -if-then-else, case-switch, while-until 및 제어 흐름 문을 단독으로 중첩 된 방식으로 작성하는 규칙.
Line length and wrapping-한 줄에 몇 개의 문자가 있어야하는지 정의합니다. 대부분 한 줄은 80 자입니다. 줄 바꿈은 줄이 너무 긴 경우 줄 바꿈 방법을 정의합니다.
Functions -매개 변수를 사용하거나 사용하지 않고 함수를 선언하고 호출하는 방법을 정의합니다.
Variables -다양한 데이터 유형의 변수를 선언하고 정의하는 방법을 언급합니다.
Comments-이것은 코드에 포함 된 주석이 코드가 실제로 수행하는 작업과 기타 모든 관련 설명을 설명하므로 중요한 코딩 구성 요소 중 하나입니다. 이 섹션은 다른 개발자를위한 도움말 문서를 만드는데도 도움이됩니다.
소프트웨어 문서
소프트웨어 문서는 소프트웨어 프로세스의 중요한 부분입니다. 잘 작성된 문서는 소프트웨어 프로세스에 대해 알아야하는 정보 저장소의 훌륭한 도구와 수단을 제공합니다. 소프트웨어 문서는 제품 사용 방법에 대한 정보도 제공합니다.
잘 관리 된 문서에는 다음 문서가 포함되어야합니다.
Requirement documentation -이 문서는 소프트웨어 설계자, 개발자 및 테스트 팀이 각자의 작업을 수행 할 수있는 핵심 도구로 작동합니다. 이 문서에는 의도 된 소프트웨어의 모든 기능, 비 기능 및 동작 설명이 포함되어 있습니다.
이 문서의 출처는 고객 측에서 이미 실행중인 소프트웨어, 고객의 인터뷰, 설문지 및 연구에 대한 이전에 저장된 데이터 일 수 있습니다. 일반적으로 고급 소프트웨어 관리 팀과 함께 스프레드 시트 또는 워드 프로세싱 문서 형태로 저장됩니다.
이 문서는 개발할 소프트웨어의 기초로 작동하며 주로 검증 및 검증 단계에서 사용됩니다. 대부분의 테스트 케이스는 요구 사항 문서에서 직접 작성됩니다.
Software Design documentation -이 문서에는 소프트웨어를 구축하는 데 필요한 모든 정보가 포함되어 있습니다. 다음을 포함합니다.(a) 높은 수준의 소프트웨어 아키텍처, (b) 소프트웨어 설계 세부 사항, (c) 데이터 흐름 다이어그램, (d) 데이터베이스 디자인
이러한 문서는 개발자가 소프트웨어를 구현할 수있는 저장소 역할을합니다. 이 문서는 프로그램 코딩 방법에 대한 세부 정보를 제공하지 않지만 코딩 및 구현에 필요한 모든 정보를 제공합니다.
Technical documentation-이 문서는 개발자와 실제 코더가 관리합니다. 이러한 문서는 전체적으로 코드에 대한 정보를 나타냅니다. 코드를 작성하는 동안 프로그래머는 코드의 목적, 작성한 사람, 필요한 위치, 수행하는 작업 및 수행하는 방법, 코드에서 사용하는 기타 리소스 등을 언급합니다.
기술 문서는 동일한 코드에서 작업하는 다양한 프로그래머 간의 이해를 높입니다. 코드의 재사용 기능을 향상시킵니다. 디버깅을 쉽고 추적 할 수 있습니다.
다양한 자동화 도구를 사용할 수 있으며 일부는 프로그래밍 언어 자체와 함께 제공됩니다. 예를 들어 자바는 코드의 기술 문서를 생성하는 JavaDoc 도구를 제공합니다.
User documentation-이 문서는 위에서 설명한 모든 문서와 다릅니다. 모든 이전 문서는 소프트웨어 및 개발 프로세스에 대한 정보를 제공하기 위해 유지됩니다. 그러나 사용자 문서는 소프트웨어 제품이 작동하는 방법과 원하는 결과를 얻기 위해 사용하는 방법을 설명합니다.
이러한 문서에는 소프트웨어 설치 절차, 방법 가이드, 사용자 가이드, 제거 방법 및 라이선스 업데이트 등과 같은 자세한 정보를 얻기위한 특수 참조가 포함될 수 있습니다.
소프트웨어 구현 과제
소프트웨어를 구현하는 동안 개발 팀이 직면 한 몇 가지 문제가 있습니다. 그들 중 일부는 아래에 언급되어 있습니다.
Code-reuse-현재 언어의 프로그래밍 인터페이스는 매우 정교하고 거대한 라이브러리 기능을 갖추고 있습니다. 그러나 최종 제품의 비용을 낮추기 위해 조직 경영진은 이전에 다른 소프트웨어 용으로 생성 된 코드를 재사용하는 것을 선호합니다. 프로그래머가 호환성 검사와 재사용 할 코드의 양을 결정하기 위해 직면하는 큰 문제가 있습니다.
Version Management-새로운 소프트웨어가 고객에게 발행 될 때마다 개발자는 버전 및 구성 관련 문서를 유지해야합니다. 이 문서는 매우 정확하고 적시에 사용할 수 있어야합니다.
Target-Host-조직에서 개발중인 소프트웨어 프로그램은 고객 측에서 호스트 머신 용으로 설계되어야합니다. 그러나 때로는 대상 컴퓨터에서 작동하는 소프트웨어를 설계하는 것이 불가능합니다.
소프트웨어 테스팅은 사용자 및 시스템 사양에서 수집 한 요구 사항에 대해 소프트웨어를 평가하는 것입니다. 테스트는 소프트웨어 개발 수명주기의 단계 수준 또는 프로그램 코드의 모듈 수준에서 수행됩니다. 소프트웨어 테스트는 검증과 검증으로 구성됩니다.
소프트웨어 검증
유효성 검사는 소프트웨어가 사용자 요구 사항을 충족하는지 여부를 검사하는 프로세스입니다. SDLC가 끝날 때 수행됩니다. 소프트웨어가 만들어진 요구 사항과 일치하면 유효성이 검사됩니다.
- 검증을 통해 개발중인 제품이 사용자 요구 사항에 맞는지 확인합니다.
- 검증은 "이 소프트웨어에서 사용자가 필요로하는 모든 것을 시도하는 제품을 개발하고 있습니까?"라는 질문에 답합니다.
- 유효성 검사는 사용자 요구 사항을 강조합니다.
소프트웨어 검증
검증은 소프트웨어가 비즈니스 요구 사항을 충족하는지 확인하는 프로세스이며 적절한 사양 및 방법론에 따라 개발됩니다.
- 검증은 개발중인 제품이 설계 사양에 맞는지 확인합니다.
- 검증은 "모든 설계 사양을 굳게 준수하여이 제품을 개발하고 있습니까?"라는 질문에 답합니다.
- 검증은 설계 및 시스템 사양에 중점을 둡니다.
테스트 대상은-
Errors-개발자가 저지른 실제 코딩 실수입니다. 또한 소프트웨어의 출력과 원하는 출력의 차이가있어 오류로 간주됩니다.
Fault-오류가있는 경우 오류가 발생합니다. 버그라고도하는 결함은 시스템 실패를 유발할 수있는 오류의 결과입니다.
Failure -실패는 시스템이 원하는 작업을 수행 할 수 없음을 말합니다. 시스템에 오류가 있으면 오류가 발생합니다.
수동 대 자동 테스트
테스트는 수동으로 수행하거나 자동화 된 테스트 도구를 사용하여 수행 할 수 있습니다.
Manual-이 테스트는 자동화 된 테스트 도구의 도움없이 수행됩니다. 소프트웨어 테스터는 코드의 다양한 섹션 및 레벨에 대한 테스트 케이스를 준비하고 테스트를 실행하고 결과를 관리자에게보고합니다.
수동 테스트에는 시간과 리소스가 많이 소모됩니다. 테스터는 올바른 테스트 케이스가 사용되는지 여부를 확인해야합니다. 테스트의 주요 부분에는 수동 테스트가 포함됩니다.
Automated이 테스트는 자동화 된 테스트 도구를 사용하여 수행되는 테스트 절차입니다. 수동 테스트의 한계는 자동화 된 테스트 도구를 사용하여 극복 할 수 있습니다.
테스트는 Internet Explorer에서 웹 페이지를 열 수 있는지 확인해야합니다. 이것은 수동 테스트로 쉽게 수행 할 수 있습니다. 그러나 웹 서버가 100 만명의 사용자를 감당할 수 있는지 확인하기 위해 수동으로 테스트하는 것은 매우 불가능합니다.
테스터가 부하 테스트, 스트레스 테스트, 회귀 테스트를 수행하는 데 도움이되는 소프트웨어 및 하드웨어 도구가 있습니다.
접근 방식 테스트
테스트는 두 가지 접근 방식을 기반으로 수행 할 수 있습니다.
- 기능 테스트
- 구현 테스트
실제 구현을 고려하지 않고 기능을 테스트하는 것을 블랙 박스 테스트라고합니다. 다른 측면은 기능을 테스트 할뿐만 아니라 구현 방식도 분석하는 화이트 박스 테스트로 알려져 있습니다.
철저한 테스트는 완벽한 테스트를 위해 가장 바람직한 방법입니다. 입력 및 출력 값 범위에서 가능한 모든 값이 테스트됩니다. 값의 범위가 큰 경우 실제 시나리오에서 모든 값을 테스트 할 수 없습니다.
블랙 박스 테스트
프로그램의 기능을 테스트하기 위해 수행됩니다. '행동'테스트라고도합니다. 이 경우 테스터는 일련의 입력 값과 각각의 원하는 결과를 가지고 있습니다. 입력을 제공 할 때 출력이 원하는 결과와 일치하면 프로그램이 '정상'으로 테스트되고 그렇지 않으면 문제가 있습니다.
이 테스트 방법에서 코드의 디자인과 구조는 테스터에게 알려지지 않으며 테스트 엔지니어와 최종 사용자는 소프트웨어에서이 테스트를 수행합니다.
블랙 박스 테스트 기술 :
Equivalence class-입력은 유사한 클래스로 나뉩니다. 클래스의 한 요소가 테스트를 통과하면 모든 클래스가 통과 된 것으로 간주됩니다.
Boundary values-입력은 상한값과 하한값으로 나뉩니다. 이 값이 테스트를 통과하면 그 사이의 모든 값도 통과 할 수 있다고 가정합니다.
Cause-effect graphing-이전 두 방법 모두 한 번에 하나의 입력 값만 테스트합니다. 원인 (입력) – 효과 (출력)는 입력 값의 조합을 체계적으로 테스트하는 테스트 기술입니다.
Pair-wise Testing-소프트웨어의 동작은 여러 매개 변수에 따라 다릅니다. 쌍대 검정에서 여러 매개 변수는 서로 다른 값에 대해 쌍 단위로 검정됩니다.
State-based testing-시스템은 입력 제공시 상태를 변경합니다. 이러한 시스템은 상태 및 입력에 따라 테스트됩니다.
화이트 박스 테스트
코드 효율성이나 구조를 개선하기 위해 프로그램 및 구현을 테스트하기 위해 수행됩니다. '구조적'테스트라고도합니다.
이 테스트 방법에서는 코드의 디자인과 구조가 테스터에게 알려져 있습니다. 코드 프로그래머는 코드에서이 테스트를 수행합니다.
다음은 몇 가지 화이트 박스 테스트 기술입니다.
Control-flow testing-제어 흐름 테스트의 목적은 모든 문과 분기 조건을 포함하는 테스트 케이스를 설정합니다. 분기 조건은 참과 거짓 모두에 대해 테스트되므로 모든 진술을 다룰 수 있습니다.
Data-flow testing-이 테스트 기법은 프로그램에 포함 된 모든 데이터 변수를 포함하도록 강조합니다. 변수가 선언되고 정의 된 위치와 사용 또는 변경된 위치를 테스트합니다.
테스트 수준
테스트 자체는 다양한 수준의 SDLC에서 정의 될 수 있습니다. 테스트 프로세스는 소프트웨어 개발과 동시에 실행됩니다. 다음 단계로 넘어 가기 전에 단계를 테스트, 검증 및 확인합니다.
소프트웨어에 숨겨진 버그 나 문제가 없는지 확인하기 위해 별도로 테스트가 수행됩니다. 소프트웨어는 다양한 수준에서 테스트됩니다.
단위 테스트
코딩하는 동안 프로그래머는 해당 프로그램 단위에 대해 몇 가지 테스트를 수행하여 오류가 없는지 확인합니다. 테스트는 화이트 박스 테스트 방식으로 수행됩니다. 단위 테스트는 개발자가 프로그램의 개별 단위가 요구 사항에 따라 작동하고 오류가 없는지 결정하는 데 도움이됩니다.
통합 테스트
소프트웨어 단위가 개별적으로 잘 작동하더라도 함께 통합하면 단위가 오류없이 작동하는지 확인할 필요가 있습니다. 예를 들어 인수 전달 및 데이터 업데이트 등이 있습니다.
시스템 테스트
소프트웨어는 제품으로 컴파일 된 다음 전체적으로 테스트됩니다. 다음 테스트 중 하나 이상을 사용하여 수행 할 수 있습니다.
Functionality testing -요구 사항에 대해 소프트웨어의 모든 기능을 테스트합니다.
Performance testing-이 테스트는 소프트웨어의 효율성을 증명합니다. 소프트웨어가 원하는 작업을 수행하는 데 걸리는 효과와 평균 시간을 테스트합니다. 성능 테스트는 소프트웨어가 다양한 환경 조건에서 높은 사용자 및 데이터 부하를받는 부하 테스트 및 스트레스 테스트를 통해 수행됩니다.
Security & Portability -이 테스트는 소프트웨어가 다양한 플랫폼에서 작동하도록되어 있고 여러 사람이 액세스 할 때 수행됩니다.
수락 테스트
소프트웨어가 고객에게 전달 될 준비가되면 사용자 상호 작용 및 응답을 테스트하는 마지막 테스트 단계를 거쳐야합니다. 소프트웨어가 모든 사용자 요구 사항을 충족하고 사용자가 표시되거나 작동하는 방식이 마음에 들지 않으면 거부 될 수 있기 때문에 이는 중요합니다.
Alpha testing-개발자 팀이 작업 환경에서 사용하는 것처럼 시스템을 사용하여 알파 테스트를 직접 수행합니다. 그들은 사용자가 소프트웨어의 어떤 행동에 어떻게 반응하고 시스템이 입력에 어떻게 반응해야하는지 알아 내려고합니다.
Beta testing-소프트웨어는 내부적으로 테스트 한 후 사용자에게 넘겨서 테스트 목적으로 만 프로덕션 환경에서 사용하도록합니다. 이것은 아직 배송 된 제품이 아닙니다. 개발자는이 단계의 사용자가 참석하지 못한 사소한 문제를 가져올 것으로 예상합니다.
회귀 테스트
소프트웨어 제품이 새로운 코드, 기능 또는 기능으로 업데이트 될 때마다 추가 된 코드의 부정적인 영향이 있는지 감지하기 위해 철저하게 테스트됩니다. 이를 회귀 테스트라고합니다.
테스트 문서
테스트 문서는 여러 단계에서 준비됩니다.
테스트하기 전에
테스트는 테스트 케이스 생성으로 시작됩니다. 참조를 위해 다음 문서가 필요합니다.
SRS document -기능 요구 사항 문서
Test Policy document -제품 출시 전 테스트를 얼마나 진행해야하는지 설명합니다.
Test Strategy document -테스트 팀, 책임 매트릭스 및 테스트 관리자 및 테스트 엔지니어의 권리 / 책임에 대한 세부 사항을 언급합니다.
Traceability Matrix document-요구 사항 수집 프로세스와 관련된 SDLC 문서입니다. 새로운 요구 사항이 발생하면이 매트릭스에 추가됩니다. 이러한 매트릭스는 테스터가 요구 사항의 출처를 파악하는 데 도움이됩니다. 앞뒤로 추적 할 수 있습니다.
테스트 중
테스트가 시작되고 수행되는 동안 다음 문서가 필요할 수 있습니다.
Test Case document-이 문서에는 수행해야하는 테스트 목록이 포함되어 있습니다. 단위 테스트 계획, 통합 테스트 계획, 시스템 테스트 계획 및 수락 테스트 계획이 포함됩니다.
Test description -이 문서는 모든 테스트 케이스와이를 실행하기위한 절차에 대한 자세한 설명입니다.
Test case report -이 문서에는 테스트 결과로 테스트 케이스 보고서가 포함되어 있습니다.
Test logs -이 문서에는 모든 테스트 사례 보고서에 대한 테스트 로그가 포함되어 있습니다.
테스트 후
테스트 후 다음 문서가 생성 될 수 있습니다.
Test summary-이 테스트 요약은 모든 테스트 보고서 및 로그를 종합적으로 분석 한 것입니다. 소프트웨어를 시작할 준비가되었는지 요약하고 결론을 내립니다. 소프트웨어가 출시 될 준비가되면 버전 관리 시스템으로 출시됩니다.
테스트 대 품질 관리, 품질 보증 및 감사
소프트웨어 테스트는 소프트웨어 품질 보증, 소프트웨어 품질 관리 및 소프트웨어 감사와 다르다는 것을 이해해야합니다.
Software quality assurance-소프트웨어 개발 프로세스 모니터링 수단으로 조직의 기준에 따라 모든 조치를 취하고 있음을 보증합니다. 이 모니터링은 적절한 소프트웨어 개발 방법을 따랐는지 확인하기 위해 수행됩니다.
Software quality control-소프트웨어 제품의 품질을 유지하기위한 시스템입니다. 여기에는 조직의 영업권을 향상시키는 소프트웨어 제품의 기능적 및 비 기능적 측면이 포함될 수 있습니다. 이 시스템은 고객이 자신의 요구 사항에 맞는 고품질의 제품을 받고 있으며 '사용에 적합'하다고 인증 된 제품을 제공합니다.
Software audit-조직에서 소프트웨어를 개발하기 위해 사용한 절차에 대한 검토입니다. 개발 팀과는 독립적 인 감사 팀이 소프트웨어 프로세스, 절차, 요구 사항 및 SDLC의 기타 측면을 검사합니다. 소프트웨어 감사의 목적은 소프트웨어와 해당 개발 프로세스가 모두 표준, 규칙 및 규정을 준수하는지 확인하는 것입니다.
소프트웨어 유지 관리는 현재 SDLC의 일부로 널리 받아 들여지고 있습니다. 소프트웨어 제품 배송 후 수행되는 모든 수정 및 업데이트를 나타냅니다. 수정이 필요한 이유에는 여러 가지가 있으며 그중 일부는 아래에 간략하게 설명되어 있습니다.
Market Conditions -과세와 같이 시간이 지남에 따라 변경되는 정책과 부기 유지 방법과 같은 새로 도입 된 제약은 수정이 필요할 수 있습니다.
Client Requirements -시간이 지남에 따라 고객은 소프트웨어의 새로운 기능을 요청할 수 있습니다.
Host Modifications -대상 호스트의 하드웨어 및 / 또는 플랫폼 (예 : 운영 체제)이 변경되면 적응성을 유지하기 위해 소프트웨어를 변경해야합니다.
Organization Changes -조직력 저하, 타 기업 인수, 신규 사업 진출 등 고객 측의 업무 수준 변화가있을 경우 원본 소프트웨어 수정이 필요할 수 있습니다.
유지 관리 유형
소프트웨어 수명 동안 유지 관리 유형은 특성에 따라 다를 수 있습니다. 일부 사용자가 발견 한 일부 버그로 일상적인 유지 관리 작업 일 수도 있고 유지 관리 규모 나 특성에 따라 그 자체로 큰 이벤트 일 수도 있습니다. 다음은 특성에 따른 몇 가지 유지 관리 유형입니다.
Corrective Maintenance -여기에는 사용자가 발견하거나 사용자 오류 보고서로 결론을 내린 문제를 수정하거나 수정하기 위해 수행 된 수정 및 업데이트가 포함됩니다.
Adaptive Maintenance -여기에는 소프트웨어 제품을 최신 상태로 유지하고 끊임없이 변화하는 기술 및 비즈니스 환경의 세계에 맞추기 위해 적용된 수정 및 업데이트가 포함됩니다.
Perfective Maintenance-여기에는 소프트웨어를 장기간 사용할 수 있도록하기위한 수정 및 업데이트가 포함됩니다. 여기에는 소프트웨어를 개선하고 안정성과 성능을 개선하기위한 새로운 기능, 새로운 사용자 요구 사항이 포함됩니다.
Preventive Maintenance-여기에는 소프트웨어의 향후 문제를 방지하기위한 수정 및 업데이트가 포함됩니다. 현재로서는 중요하지 않지만 향후 심각한 문제를 야기 할 수있는 문제에 대처하는 것을 목표로합니다.
유지 보수 비용
보고서에 따르면 유지 관리 비용이 높습니다. 소프트웨어 유지 관리 추정에 대한 연구에 따르면 유지 관리 비용이 전체 소프트웨어 프로세스주기 비용의 67 %에 이릅니다.
평균적으로 소프트웨어 유지 관리 비용은 모든 SDLC 단계의 50 % 이상입니다. 유지 관리 비용이 높아지는 요인은 다음과 같습니다.
유지 관리 비용에 영향을 미치는 실제 요인
- 모든 소프트웨어의 표준 연령은 최대 10 ~ 15 년으로 간주됩니다.
- 메모리와 저장 용량이 적은 느린 시스템에서 작동하도록 의도 된 구형 소프트웨어는 최신 하드웨어에서 새로 출시되는 향상된 소프트웨어에 대해 도전 할 수 없습니다.
- 기술이 발전함에 따라 오래된 소프트웨어를 유지하는 데 비용이 많이 듭니다.
- 대부분의 유지 보수 엔지니어는 초보자이며 시행 착오 방법을 사용하여 문제를 수정합니다.
- 종종 변경 사항은 소프트웨어의 원래 구조를 쉽게 손상시켜 후속 변경을 어렵게 만듭니다.
- 변경 사항은 종종 문서화되지 않은 채로 남겨져 향후 더 많은 충돌을 일으킬 수 있습니다.
유지 관리 비용에 영향을 미치는 소프트웨어 끝 요소
- 소프트웨어 프로그램의 구조
- 프로그래밍 언어
- 외부 환경에 의존
- 직원 신뢰성 및 가용성
유지 보수 활동
IEEE는 순차적 유지 관리 프로세스 활동을위한 프레임 워크를 제공합니다. 반복적으로 사용할 수 있으며 사용자 정의 된 항목 및 프로세스를 포함 할 수 있도록 확장 할 수 있습니다.
이러한 활동은 다음 각 단계와 함께 진행됩니다.
Identification & Tracing-수정 또는 유지 보수 요구 사항 식별과 관련된 활동을 포함합니다. 사용자에 의해 생성되거나 시스템 자체가 로그 또는 오류 메시지를 통해보고 할 수 있으며 여기에서 유지 보수 유형도 분류됩니다.
Analysis-변경 사항이 안전 및 보안 영향을 포함하여 시스템에 미치는 영향을 분석합니다. 예상되는 영향이 심각한 경우 대체 솔루션을 찾습니다. 그런 다음 필요한 수정 세트가 요구 사항 사양으로 구체화됩니다. 수정 / 유지 보수 비용이 분석되고 추정이 완료됩니다.
Design-교체 또는 수정이 필요한 새 모듈은 이전 단계에서 설정 한 요구 사항 사양에 따라 설계되었습니다. 검증 및 검증을 위해 테스트 케이스가 생성됩니다.
Implementation -새로운 모듈은 설계 단계에서 생성 된 구조화 된 설계의 도움으로 코딩되며 모든 프로그래머는 병렬로 단위 테스트를 수행해야합니다.
System Testing-새로 생성 된 모듈 간의 통합 테스트를 수행합니다. 통합 테스트는 새로운 모듈과 시스템간에 수행됩니다. 마지막으로 시스템은 회귀 테스트 절차에 따라 전체적으로 테스트됩니다.
Acceptance Testing-시스템 내부 테스트 후 사용자의 도움을 받아 합격 여부를 테스트합니다. 이 상태에서 사용자가 몇 가지 문제를 불만을 제기하면 다음 반복에서 해결하거나 해결해야합니다.
Delivery-수락 테스트 후 시스템은 소규모 업데이트 패키지 또는 시스템의 새로 설치를 통해 조직 전체에 배포됩니다. 최종 테스트는 소프트웨어가 제공된 후 클라이언트 측에서 수행됩니다.
필요한 경우 사용 설명서의 하드 카피와 함께 교육 시설이 제공됩니다.
Maintenance management-구성 관리는 시스템 유지 관리의 필수 부분입니다. 버전, 반 버전 또는 패치 관리를 제어하기 위해 버전 제어 도구를 사용합니다.
소프트웨어 리엔지니어링
기능에 영향을주지 않고 현재 시장에 유지하기 위해 소프트웨어를 업데이트해야하는 경우 소프트웨어 리엔지니어링이라고합니다. 소프트웨어 디자인을 변경하고 프로그램을 다시 작성하는 철저한 프로세스입니다.
레거시 소프트웨어는 시장에서 구할 수있는 최신 기술로 계속 조정할 수 없습니다. 하드웨어가 노후화되면 소프트웨어 업데이트가 골칫거리가됩니다. 소프트웨어가 시간이 지남에 따라 오래 되어도 기능은 그렇지 않습니다.
예를 들어, 처음에는 Unix가 어셈블리 언어로 개발되었습니다. 언어 C가 등장했을 때 어셈블리 언어로 작업하는 것이 어려웠 기 때문에 Unix는 C로 다시 엔지니어링되었습니다.
이 외에도 프로그래머는 소프트웨어의 일부가 다른 부분보다 더 많은 유지 관리가 필요하고 리엔지니어링이 필요하다는 사실을 알아 차립니다.
재 설계 프로세스
- Decide리엔지니어링 할 것. 전체 소프트웨어입니까, 아니면 일부입니까?
- Perform 기존 소프트웨어의 사양을 얻기 위해 리버스 엔지니어링.
- Restructure Program필요한 경우. 예를 들어, 기능 지향 프로그램을 객체 지향 프로그램으로 변경합니다.
- Re-structure data 필요에 따라.
- Apply Forward engineering 리엔지니어링 된 소프트웨어를 얻기위한 개념.
소프트웨어 리엔지니어링에 사용되는 중요한 용어는 거의 없습니다.
리버스 엔지니어링
기존 시스템을 철저히 분석하고 이해하여 시스템 사양을 달성하는 과정입니다. 이 프로세스는 역 SDLC 모델로 볼 수 있습니다. 즉, 더 낮은 추상화 수준을 분석하여 더 높은 추상화 수준을 얻으려고합니다.
기존 시스템은 이전에 구현 된 설계로, 우리는 아무것도 모릅니다. 그런 다음 디자이너는 코드를보고 리버스 엔지니어링을 수행하고 디자인을 얻으려고합니다. 디자인을 손에 들고 사양을 마무리하려고합니다. 따라서 코드에서 시스템 사양으로 반대로 이동합니다.
프로그램 구조 조정
기존 소프트웨어를 재구성하고 재구성하는 프로세스입니다. 동일한 프로그래밍 언어로 또는 한 프로그래밍 언어에서 다른 언어로 소스 코드를 재배 열하는 것이 전부입니다. 재구성은 소스 코드 재구성과 데이터 재구성 또는 둘 다를 가질 수 있습니다.
구조 조정은 소프트웨어의 기능에 영향을주지 않고 안정성과 유지 관리 성을 향상시킵니다. 오류를 매우 자주 발생시키는 프로그램 구성 요소는 구조 조정을 통해 변경되거나 업데이트 될 수 있습니다.
구식 하드웨어 플랫폼에 대한 소프트웨어의 의존성은 재구성을 통해 제거 할 수 있습니다.
포워드 엔지니어링
포워드 엔지니어링은 리버스 엔지니어링을 통해 가져온 사양에서 원하는 소프트웨어를 얻는 프로세스입니다. 과거에 이미 수행 된 일부 소프트웨어 엔지니어링이 있다고 가정합니다.
포워드 엔지니어링은 소프트웨어 엔지니어링 프로세스와 동일하지만 한 가지 차이점 만 있습니다. 항상 리버스 엔지니어링 후에 수행됩니다.
부품 재사용 성
구성 요소는 시스템에서 독립적 인 작업을 실행하는 소프트웨어 프로그램 코드의 일부입니다. 작은 모듈 또는 하위 시스템 자체 일 수 있습니다.
예
웹에서 사용되는 로그인 절차는 구성 요소로 볼 수 있으며 소프트웨어의 인쇄 시스템은 소프트웨어의 구성 요소로 볼 수 있습니다.
구성 요소는 기능의 응집력이 높고 결합 속도가 낮습니다. 즉, 독립적으로 작동하고 다른 모듈에 의존하지 않고 작업을 수행 할 수 있습니다.
OOP에서 객체는 해당 관심사에 매우 구체적이며 다른 소프트웨어에서 사용할 가능성이 적습니다.
모듈 식 프로그래밍에서 모듈은 여러 다른 소프트웨어 프로그램에서 사용할 수있는 특정 작업을 수행하도록 코딩됩니다.
소프트웨어 구성 요소의 재사용을 기반으로하며 CBSE (구성 요소 기반 소프트웨어 엔지니어링)로 알려진 완전히 새로운 수직 영역이 있습니다.
다양한 수준에서 재사용이 가능합니다.
Application level -전체 애플리케이션이 새로운 소프트웨어의 하위 시스템으로 사용되는 경우.
Component level -애플리케이션의 하위 시스템이 사용되는 경우.
Modules level -기능 모듈이 재사용되는 곳.
소프트웨어 구성 요소는 서로 다른 구성 요소 간의 통신을 설정하는 데 사용할 수있는 인터페이스를 제공합니다.
재사용 프로세스
요구 사항을 동일하게 유지하고 구성 요소를 조정하거나 구성 요소를 동일하게 유지하고 요구 사항을 수정하는 두 가지 방법을 채택 할 수 있습니다.
Requirement Specification -소프트웨어 제품이 기존 시스템, 사용자 입력 또는 둘 모두의 도움을 받아 준수해야하는 기능 및 비 기능 요구 사항이 지정됩니다.
Design-이것은 또한 소프트웨어 용어로 요구 사항이 정의되는 표준 SDLC 프로세스 단계입니다. 전체 시스템 및 하위 시스템의 기본 아키텍처가 생성됩니다.
Specify Components -소프트웨어 설계를 연구함으로써 설계자는 전체 시스템을 더 작은 구성 요소 또는 하위 시스템으로 분리합니다. 하나의 완전한 소프트웨어 디자인은 함께 작동하는 거대한 구성 요소 모음으로 바뀝니다.
Search Suitable Components -소프트웨어 구성 요소 저장소는 기능 및 의도 된 소프트웨어 요구 사항을 기반으로 일치하는 구성 요소를 검색하기 위해 설계자가 참조합니다.
Incorporate Components -일치하는 모든 구성 요소가 함께 포장되어 완전한 소프트웨어로 형성됩니다.
CASE는 C컴퓨터 A이드 Software Engineering. 그것은 다양한 자동화 소프트웨어 도구의 도움으로 소프트웨어 프로젝트의 개발 및 유지 보수를 의미합니다.
CASE 도구
CASE 도구는 SDLC 활동을 자동화하는 데 사용되는 소프트웨어 응용 프로그램 세트입니다. CASE 도구는 소프트웨어 프로젝트 관리자, 분석가 및 엔지니어가 소프트웨어 시스템을 개발하는 데 사용됩니다.
분석 도구, 설계 도구, 프로젝트 관리 도구, 데이터베이스 관리 도구, 문서화 도구 등 소프트웨어 개발 수명주기의 다양한 단계를 단순화하는 데 사용할 수있는 CASE 도구가 많이 있습니다.
CASE 도구를 사용하면 프로젝트 개발을 가속화하여 원하는 결과를 생성하고 소프트웨어 개발의 다음 단계로 진행하기 전에 결함을 발견하는 데 도움이됩니다.
CASE 도구의 구성 요소
CASE 도구는 특정 SDLC 단계에서의 사용에 따라 크게 다음 부분으로 나눌 수 있습니다.
Central Repository-CASE 도구에는 공통적이고 일관된 통합 정보의 소스 역할을 할 수있는 중앙 저장소가 필요합니다. 중앙 저장소는 제품 사양, 요구 사항 문서, 관련 보고서 및 다이어그램, 기타 관리 관련 유용한 정보가 저장되는 중앙 저장소입니다. 중앙 저장소는 데이터 사전 역할도합니다.
Upper Case Tools -상위 CASE 도구는 SDLC의 계획, 분석 및 설계 단계에서 사용됩니다.
Lower Case Tools -낮은 CASE 도구는 구현, 테스트 및 유지 관리에 사용됩니다.
Integrated Case Tools -통합 CASE 도구는 요구 사항 수집에서 테스트 및 문서화에 이르기까지 SDLC의 모든 단계에서 유용합니다.
CASE 도구는 유사한 기능, 프로세스 활동 및 다른 도구와 통합되는 기능이있는 경우 함께 그룹화 할 수 있습니다.
케이스 도구의 범위
CASE 도구의 범위는 SDLC 전체에 적용됩니다.
케이스 도구 유형
이제 다양한 CASE 도구를 간단히 살펴 보겠습니다.
다이어그램 도구
이러한 도구는 다양한 소프트웨어 구성 요소 및 시스템 구조 간의 시스템 구성 요소, 데이터 및 제어 흐름을 그래픽 형식으로 나타내는 데 사용됩니다. 예를 들어, 최신 순서도를 만들기위한 Flow Chart Maker 도구입니다.
프로세스 모델링 도구
프로세스 모델링은 소프트웨어를 개발하는 데 사용되는 소프트웨어 프로세스 모델을 생성하는 방법입니다. 프로세스 모델링 도구는 관리자가 소프트웨어 제품의 요구 사항에 따라 프로세스 모델을 선택하거나 수정할 수 있도록 도와줍니다. 예 : EPF Composer
프로젝트 관리 도구
이러한 도구는 프로젝트 계획, 비용 및 노력 추정, 프로젝트 일정 및 자원 계획에 사용됩니다. 관리자는 소프트웨어 프로젝트 관리에서 언급 된 모든 단계에서 프로젝트 실행을 엄격하게 준수해야합니다. 프로젝트 관리 도구는 조직 전체에서 실시간으로 프로젝트 정보를 저장하고 공유하는 데 도움이됩니다. 예 : Creative Pro Office, Trac Project, Basecamp.
문서화 도구
소프트웨어 프로젝트의 문서화는 소프트웨어 프로세스 이전에 시작되어 SDLC의 모든 단계와 프로젝트 완료 후에 진행됩니다.
문서화 도구는 기술 사용자와 최종 사용자를위한 문서를 생성합니다. 기술 사용자는 대부분 시스템 설명서, 참조 설명서, 교육 설명서, 설치 설명서 등을 참조하는 개발 팀의 사내 전문가입니다. 최종 사용자 문서는 사용자 설명서와 같은 시스템의 기능 및 방법을 설명합니다. 예를 들어 문서의 경우 Doxygen, DrExplain, Adobe RoboHelp가 있습니다.
분석 도구
이러한 도구는 요구 사항을 수집하고 다이어그램의 불일치, 부정확성, 데이터 중복 또는 잘못된 누락을 자동으로 확인하는 데 도움이됩니다. 예를 들어 Accept 360, Accompa, CaseComplete (요구 사항 분석), Visible Analyst (전체 분석)입니다.
디자인 도구
이러한 도구는 소프트웨어 설계자가 소프트웨어의 블록 구조를 설계하는 데 도움이되며, 미세 조정 기술을 사용하여 더 작은 모듈로 세분화 될 수 있습니다. 이러한 도구는 각 모듈 및 모듈 간의 상호 연결에 대한 세부 정보를 제공합니다. 예 : 애니메이션 소프트웨어 디자인
구성 관리 도구
소프트웨어 인스턴스는 하나의 버전으로 릴리스됩니다. 구성 관리 도구는 –
- 버전 및 개정 관리
- 기본 구성 관리
- 변경 제어 관리
CASE 도구는 자동 추적, 버전 관리 및 릴리스 관리를 통해이를 지원합니다. 예를 들어, Fossil, Git, Accu REV.
변경 제어 도구
이러한 도구는 구성 관리 도구의 일부로 간주됩니다. 기준이 수정 된 후 또는 소프트웨어가 처음 출시 될 때 소프트웨어의 변경 사항을 처리합니다. CASE 도구는 변경 추적, 파일 관리, 코드 관리 등을 자동화합니다. 또한 조직의 변경 정책을 시행하는 데 도움이됩니다.
프로그래밍 도구
이러한 도구는 IDE (통합 개발 환경), 내장 모듈 라이브러리 및 시뮬레이션 도구와 같은 프로그래밍 환경으로 구성됩니다. 이러한 도구는 소프트웨어 제품 구축에 포괄적 인 지원을 제공하며 시뮬레이션 및 테스트 기능을 포함합니다. 예를 들어 Cscope는 C, Eclipse에서 코드를 검색합니다.
프로토 타이핑 도구
소프트웨어 프로토 타입은 의도 한 소프트웨어 제품의 시뮬레이션 버전입니다. Prototype은 제품의 초기 모양과 느낌을 제공하며 실제 제품의 일부 측면을 시뮬레이션합니다.
프로토 타이핑 CASE 도구는 기본적으로 그래픽 라이브러리와 함께 제공됩니다. 하드웨어 독립적 인 사용자 인터페이스와 디자인을 만들 수 있습니다. 이러한 도구는 기존 정보를 기반으로 신속한 프로토 타입을 구축하는 데 도움이됩니다. 또한 소프트웨어 프로토 타입의 시뮬레이션을 제공합니다. 예를 들어 Serena 프로토 타입 작곡가, Mockup Builder가 있습니다.
웹 개발 도구
이러한 도구는 양식, 텍스트, 스크립트, 그래픽 등과 같은 모든 관련 요소로 웹 페이지를 디자인하는 데 도움이됩니다. 웹 도구는 또한 개발중인 내용과 완료 후 어떻게 보일지에 대한 실시간 미리보기를 제공합니다. 예 : Fontello, Adobe Edge Inspect, Foundation 3, Brackets.
품질 보증 도구
소프트웨어 조직의 품질 보증은 조직 표준에 따른 품질 준수를 보장하기 위해 소프트웨어 제품을 개발하기 위해 채택 된 엔지니어링 프로세스 및 방법을 모니터링합니다. QA 도구는 구성 및 변경 제어 도구와 소프트웨어 테스트 도구로 구성됩니다. 예 : SoapTest, AppsWatch, JMeter.
유지 관리 도구
소프트웨어 유지 관리에는 소프트웨어 제품이 인도 된 후의 수정이 포함됩니다. 자동 로깅 및 오류보고 기술, 자동 오류 티켓 생성 및 근본 원인 분석은 SDLC의 유지 관리 단계에서 소프트웨어 조직을 돕는 소수의 CASE 도구입니다. 예를 들어, 결함 추적을위한 Bugzilla, HP Quality Center.