소프트웨어 분류 및 특성
01. 상용 소프트웨어
1) 상용 소프트웨어의 개념
- 상업적 목적이나 판매를 목적으로 생산
- 상업용으로 판매, 유통되는 소프트웨어
- 홍보를 위한 무료 소프트웨어를 포함
- 대부분의 상용 소프트웨어는 원시 코드를 제공하지 않고 실행 코드(기계어로 된 파일)만 제공하기 때문에 수정이나 추가 등이 불가능함
- 원시코드(Source Code)
- C 언어나 Java 언어 같은 프로그램 언어로 작성된 프로그램
- 대부분 영문으로 구성된 명령어의 집합체
- 컴퓨터가 이해할 수 있는 0과 1로 구성된 기계어로 변환되어야만 실행 가능
2) 상용 소프트웨어의 분류
1. 상용 소프트웨어
- 산업 범용 소프트웨어 : 시스템 소프트웨어, 미들웨어, 응용 소프트웨어
- 산업 특화 소프트웨어 : 자동차, 항공, 패션 의류, 조선, 건설, 농업, 의료, 국방, 게임, 공공, 교육, 물류, 인터넷 서비스
2. 산업 범용 소프트웨어
- 시스템 소프트웨어 : 운영체제, 데이터관리, 스토로지 소프트웨어, 소프트웨어 공학 도구, 가상화 소프트웨어, 시스템 보안
- 미들웨어 : 분산 소프트웨어, IT 자원 관리, 서비스 플랫폼, 네트워크 보안
- 응용 소프트웨어 : 영상 처리, CG/VR, 콘텐츠 배포, 자연언어 처리, 음성 처리, 기업용 소프트웨어
02. 시스템 소프트웨어
1) 시스템(System)
1. 시스템의 정의
- 하나의 공통적인 목적을 가지고 있는 구성 요소들을 상호 결합해 놓은 유기적인 집합체
2. 시스템의 기본 요소
- 입력(Input) : 처리 방법, 제어 조건, 처리할 데이터를 시스템에 투입하는 요소
- 출력(Output) : 처리된 결과를 시스템에서 출력하는 요소
- 처리(Process) : 입력된 자료를 처리 조건에 따라 변환 및 가공하는 요소
- 제어(Controll) : 시스템의 기본 요소들이 각 과정을 올바르게 행하는지 감독하는 요소
- 피드백(Feedback) : 처리된 결과를 측정, 파악하여 목표에 도달되었는가를 검사하며, 만일 불충분할 경우 목표 달성을 위해 다시 입력하는 요소
- 전수 피드백 : 출력되는 신호를 전부 피드백하는 방법
- 부분 피드백 : 지정된 일부의 내용만 제한된 시간 내에 피드백하는 방법
- 전략적 피드백 : 핵심적인 단위의 내용만을 선택하여 지정된 대로 피드백하는 방법
- 기호 피드백 : 기호가 붙어 있는 사항에 대해서만 피드백하는 방법
2) 시스템 소프트웨어의 개념
- 응용 프로그램을 실행하기 위한 환경을 제공하고 컴퓨터 하드웨어를 동작시키고 관리하는 소프트웨어
- 시스템 소프트웨어는 CPU 관리, 메모리 관리, 디스크 파일들을 관리하는 소프트웨어
- 컴퓨터 사용자가 하드웨어의 구조나 특성을 알지 못해도 컴퓨터를 이용할 수 있도록 지원
1) 플랫폼의 개념
- 많은 응용 프로그램들을 쉽고 편리하게 사용할 수 있도록 지원해주는 하드웨어나 소프트웨어 환경
- 응용 프로그램을 실행하기 위해 사용하는 하드웨어와 소프트웨어의 결합
- 소프트웨어 개발과 운영을 편안하게 할 수 있도록 지원
- 동일한 플랫폼에서 개발된 소프트웨어는 언제, 어디서나 손쉽게 실행 가능
- 현행 시스템을 분석하기 위해서는 현재 시스템의 구성 요소인 소프트웨어 및 하드웨어 플랫폼을 상세하게 분석해야 함
2) 플랫폼의 기능
- 소프트웨어의 개발 및 운영비용의 절약 가능
- 동일한 플랫폼 간의 공통 그룹을 형성하여 네트워크의 효과를 최대화할 수 있음
- 소프트웨어 개발의 생산성을 향상시킬 수 있음
3) 플랫폼의 성능 특성 분석 항목
- 가용성(Availability) : 정보 시스템은 적절한 방법으로 정보를 요구하는 사용자에게 정보 서비스를 제공해야 함
- 응답 시간(Response Time) : 명령이 주어지고, 반응하기까지 걸린 시간으로 반응 시간이라고도 부름
- 정확성(Accuracy) : 플랫폼에서 처리된 결과가 얼마나 올바른 값에 근접했는가를 측정하는 정도
- 사용률(Utilization) : 하드웨어 자원, 소프트웨어 자원, 네트워크 자원 등을 일정 시간 사용하는 정도
04. 프레임워크(Framework)
1) 프레임워크의 정의
- 프레임워크는 Frame + Work라는 두 단어가 합쳐진 것으로, '일정하게 짜여진 틀(뼈대)에서 일한다'하는 의미로 해석
- 프레임워크는 목적을 달성하기 위해 복잡하게 연결되어 있으며, 문제를 해결하기 위한 구조이자 소프트웨어 개발에 있어 하나의 뼈대 역할을 함
2) 소프트웨어 프레임워크
- 응용 프로그램 개발이나 문제 해결을 수월하게 하기 위해 설계와 구현을 재사용이 가능한 형태로 제공하는 소프트웨어 환경
- 효율적인 정보 시스템 개발을 위한 코드 라이브러리, 애플리케이션 인터페이스, 설정 정보 등의 집합으로써 재사용이 가능하도록 소프트웨어 구성에 필요한 기본 뼈대를 제공
- 다양한 소프트웨어 개발을 가능하게 하는 여러 형태의 컴포넌트
- 완전한 제품이 아니며, 개발자의 코드나 사용자 데이터가 필요
3) 소프트웨어 프레임워크의 특징
- 모듈화(Modularity) : 전체 프로그램을 한 번에 설계하지 않고 단일 기능을 갖출 수 있도록 부분적으로 묶어서 처리하는 기술
- 재사용성(Reusability) : 전체나 일부 소프트웨어가 다른 응용 목적으로 사용될 수 있는 정도
- 확장성(Extensibility) : 추가적인 설계 없이 확장이 얼마나 쉽고 가능한가에 대한 용이성
- 제어의 역 흐름(Inversion of Control) : 소프트웨어 프레임워크 코드가 전체 애플리케이션의 처리 흐름을 제어하여 특정한 이벤트가 발생할 때 다형성(Polymorphism)을 통해 애플리케이션이 확장한 메소드를 호출함으로써 제어가 소프트웨어 프레임워크부터 애플리케이션으로 거꾸로 흐르게 하는 것
4) 프레임워크를 적용할 경우 기대 효과
- 개발 용이성 : 공통적으로 필요한 기능들을 미리 제공 받아 소프트웨어를 개발함으로써 빠른 시간에 가발 가능
- 품질 보증 : 오류 발생 가능성을 최소화할 수 있으므로 품질이 향상
- 변경 용이성 : 개발자가 새로운 기능을 추가하거나 변경하더라도 부담 없이 변경 가능
- 유지보수 용이성 : 프레임워크로 적용된 소프트웨어는 보다 체계적이고 안정적이어서 변경이 되더라도 위험 부담을 줄일 수 있음
- 재사용성 향상 : 프레임워크 기반으로 개발된 컴포넌트들을 타 사업에서 쉽게 사용할 수 있어 재사용성이 극대화될 수 있음
- 표준화율 향상 : 정형화된 개발 기술화 방법을 제공함으로써 설계, 개발 등 시스템 구축 전반에 걸친 표준을 제시할 수 있음
- 상호 운용성 향상 : 전자 정부 표준 프레임워크 기반으로 개발된 시스템 간에 컴포넌트 연계가 용이하여 상호 운용성이 극대화될 수 있음
05. 기업용 소프트웨어
1) 오피스웨어(OfficeWare)
- 회사나 단체에서 업무에 사용되는 소프트웨어
- 워드 프로세서, 프레젠테이션, 스프레드시트 등의 업무용 오피스 소프트웨어와 그룹웨어를 포함하는 기업용 소프트웨어
- 조직의 업무 활동을 지원
2) ERP(Enterprise Resource Planning)
- 신속한 의사 결정을 위한 소프트웨어
- 경영 활동 프로세스들을 통합적으로 연계해서 관리하는 소프트웨어
- 기업에서 발생하는 정보들을 서로 공유하고 새로운 정보의 생성과 신속한 의사 결정을 도와줌으로써 전사적으로 자원을 관리
3) SCM(Supply Chain Management)
- 부품 공급자를 지원하는 소프트웨어
- 부품업자로부터 생산자, 배포자, 고객에 이르는 물류의 흐름을 하나의 가치 사슬 관점에서 파악하고, 필요한 정보가 원활히 흐르도록 지원하는 기술
4) BI(Business Intelligence)
- 구성원에게 적시에 의사 결정을 지원하는 소프트웨어
- 기업에서 데이터를 수집, 정리, 분석하고 활용하여 각 조직의 구성원에게 적시에 의사 결정을 할 수 있도록 지원하는 기술
5) CRM(Customer Relationship Management)
- 고객 특성에 기초한 마케팅 활동을 지원하는 소프트웨어
- 신규 고객을 획득하거나 기존 고객 유지 및 수익성 증대를 목적으로 고객 관련 자료를 분석하여 고객 특성에 기초한 마케팅 활동을 지원하는 기술
06. 컴포넌트(Component)
1) 컴포넌트의 개념
- 부품화된 프로그램을 모듈(Module), 모듈들의 집합을 라이브러리(Library), 라이브러리의 집단을 컴포넌트(Component)라고 함
- 라이브러리를 기능별로 분류하여 지원
- 독립적으로 사용 가능
2) 컴포넌트의 설계
- 컴포넌트 설계 시 협약(Contract)에 의한 설계를 따를 경우에 다음의 조건들이 포함되어야 함
- 컴포넌트의 오퍼레이션 사용 전에 참이 되어야 할 선행 조건
- 사용 후 만족되어야 할 결과 조건
- 오퍼레이션이 실행되는 동안 항상 만족되어야 할 불변 조건
3) CBD(Component Based Development)
- CBD는 컴포넌트 제작 기법을 통해 재사용성을 향상
- 개발 기간 단축으로 생산성과 품질을 향상
- 유지보수 비용을 최소화
- 시스템을 신속하게 구축, 새로운 기능 추가 및 확장을 용이하게 함
- CBD는 독립적인 컴포넌트 단위의 관리로 복잡성을 최소화
CBD 산출물 목록
- 분석 : 사용자 요구사항 정의서, 유스케이스 명세서, 요구사항 추적표
- 설계 : 클래스 설계서, 사용자 인터페이스 설계서, 컴포넌트 설계서, 인터페이스 설계서, 아키텍처 설계서, 총괄시험 계획서, 시스템 시험 시나리오, 엔티티 관계 모형 기술서, 데이터베이스 설계서, 통합 시험 시나리오, 단위 시럼 케이스, 데이터 전환 및 기초 데이터 설계서
- 구현 : 프로그램 코드, 단위 시험 결과서, 데이터베이스 테이블
- 시험 : 통합 시험 결과서, 시스템 시험 결과서, 사용자 지침서, 운영자 지침서, 시스템 설치 결과서, 인수 시험 시나리오, 인수 시험 결과서
07. 소프트웨어 공학(SE : Software Engineering)
1) 소프트웨어 공학의 개념
- 최소의 비용으로 높은 품질의 소프트웨어를 개발하기 위한 모든 도구 및 방법론을 총칭
- 소프트웨어 위기를 극복하기 위해 품질과 생산성 향상을 목적으로 연구하는 학문
- 소프트웨어 위기(문제점)
- 개발 비용 증대
- 유지보수 비용 증대
- 관리 측면 증대
- 개발 기간의 지연
- 소프트웨어 기술 발전 속도의 느림
- 대화 단절
- 성능 및 신뢰성 부족
- 품질 평가 기준 부재
- 개발 인력 부재
소프트웨어 공학 정의 및 목표
- 소프트웨어의 개발, 운용, 유지보수 및 파기에 대한 체계적인 접근 방법
- 소프트웨어 제품의 품질을 향상시키고 소프트웨어 생산성과 작업 만족도를 증대시키는 것이 목적
- 소프트웨어 공학의 궁극적 목표는 최소의 비용으로 계획된 일정보다 가능한 빠른 시일 내에 소프트웨어를 개발하는 것
- 신뢰성 있는 소프트웨어를 경제적인 비용으로 획득하기 위해 공학적 원리를 정립하고 이를 이요하는 것
2) 소프트웨어 공학의 기본 원칙
- 현대적인 프로그래밍 기술을 적용
- 지속적인 검증을 시행
- 결과에 관한 명확한 기록을 유지
- 품질 높은 소프트웨어 상품을 개발
3) 소프트웨어 공학의 등장 배경
- 소프트웨어 개발에 필요한 시간과 비용 예측력 부족
- 개발된 소프트웨어의 품질 수준 부족
- 하드웨어에 대한 소프트웨어의 상대적 비용 상승
- 유지보수의 역할 증대
- 하드웨어 및 소프트웨어 기술의 급속한 발전
- 크고 복잡한 소프트웨어에 대한 수요 증가
- 특정 개인에 의존한 시스템이 개발
4) 소프트웨어 공학의 도입
- 소프트웨어 개발 과정에 공학적인 접근을 시도하여 생산성과 신뢰성을 높이기 위한 기법과 원리를 다루기 위해 도입
- 방법(Method) : 소프트웨어를 구축하기 위한 방법을 제공
- 도구(Tool) : 방법을 지원하기 위한 자동화된 도구를 지원
- 절차(Procedure) : 방법과 도구를 결합하여 좀 더 향상된 프로그램을 개발하기 위한 절차