프레임워크(Framework)란?
컴퓨터 프로그래밍에서, 소프트웨어 프레임워크(software framework)는 복잡한 문제를 해결하거나 서술하는 데 사용되는 기본 개념 구조이다. 간단히 뼈대, 골조(骨組), 프레임워크(framework)라고도 한다.
- 위키백과 -
프레임워크는 애플리케이션 개발 시 필수적인 코드, 알고리즘, DB 커넥션 등의 기능들을 위해 뼈대(구조)를 제공한다.
개발자는 이러한 뼈대 위에서 코드를 작성해 원하는 애플리케이션을 개발할 수 있다.
프레임워크는 소프트웨어의 구체적인 부분에 해당하는 설계와 구현을 재사용이 가능하게끔 상호 협력하는 클래스와 인터페이스의 집합이라고 할 수 있다.
쉽게 말해 프레임워크는 개발자가 개발을 쉽게 할 수 있도록 뼈대를 제공해준다고 생각하면 된다.
앱/서버 등의 구동, 메모리 관리, 이벤트 루프 등의 공통된 부분은 프레임워크가 관리하며, 사용자는 프레임워크가 정해준 방식대로 클래서, 메서드들을 구현하면 된다.
예시
- Java 서버 개발에 사용되는 Spring
- Python 서버 개발에 사용되는 Django, Flask
- 안드로이드 앱 개발에 사용되는 Android
- 아이폰 앱 개발에 사용되는 Cocoa Touch
- 웹 개발에 사용되는 Angular, Vue.js 등
- 자바 기반의 JSP를 위한 프레임 워크 Struts
- 루비로 작성된 MVC패턴을 이용하는 Ruby on Rails
라이브러리(Library)란?
라이브러리는 주로 소프트웨어를 개발할 때 컴퓨터 프로그램이 사용하는 비휘발성 자원의 모임이다. 여기에는 구성 데이터, 문서, 도움말 자료, 메시지 틀, 미리 작성된 코드, 서브루틴, 클래스, 값, 자료형 사양을 포함할 수 있다.
- 위키백과 -
라이브러리는 개발에 필요한 것들을 미리 구현해놓은 도구라고 할 수 있다.
재사용이 가능한 기능을 미리 구현해놓고 필요한 곳에서 호출하여 사용 가능하도록 만들어진 집합이다.
예시
- Python pip로 설치한 패키지/모듈 (tensorflow, pandas, beautifulsoup 등등)
- C++의 표준 템플릿 라이브러리 (STL)
- Node.js에서 npm으로 설치한 모듈
- HTML의 클라이언트 사이드 조작을 단순화하는 JQuery
- 웹에서 사용자 인터페이스 개발에 사용되는 React.js
엥? 왜 React가 라이브러리이지? React는 프레임워크가 아닌가요?
React.js는 웹 서비스 중에서 사용자 인터페이스 개발을 위해 사용되는 라이브러리입니다.
앵귤러? 뷰? 리액트?
- 앵귤러와 뷰는 웹 개발을 할 때 필요한 모든 기능과 툴을 포함하고 있기 때문에 프레임워크라고 할 수 있다.
- 리액트는 어플리케이션의 흐름을 제어하는 권한, 즉 제어의 역전 개념이 없다. 단순히 UI를 만드는 기능만을 제공하기 때문에 라이브러리라고 할 수 있다.
프레임워크 vs 라이브러리
프레임워크는 단지 미리 만들어준 반제품이나, 확장해서 사용할 수 있도록 준비된 추상 라이브러리의 집합이 아니다. 프레임워크가 어떤 것인지 이해하려면 라이브러리와 프레임워크가 어떻게 다른지 알아야 한다.
라이브러리를 사용하는 애플리케이션 코드는 애플리케이션 흐름을 직접 제어한다.
단지 동작하는 중에 필요한 기능이 있을 때 능동적으로 라이브러리를 사용할 뿐이다.반면에 프레임워크는 거꾸로 애플리케이션 코드가 프레임워크에 의해 사용된다.
프레임워크에는 분명한 [제어의 역전] 개념이 적용되어 있어야 한다.애플리케이션 코드는 프레임워크가 짜 놓은 틀에서 수동적으로 동작해야 한다.
- 토비의 스프링中 -
프레임워크와 라이브러리의 차이점은 "제어 흐름"의 권한이 어디에 있는가입니다.
1. 라이브러리
라이브러리의 객체나 함수를 개발자가 직접 호출하여 사용한다.
- 사용자는 애플리케이션 코드의 흐름을 직접 제어해야 한다.
- 개발 시 필요한 기능이 있을 경우 능동적으로 라이브러리를 호출하여 사용하거나 기존에 구성된 함수나 코드를 가져다 써야 한다.
2. 프레임워크
개발자가 구현한 메서드가 프레임워크에 의해 호출된다.
- 애플리케이션의 코드가 프레임워크에 의해 사용된다.
- 애플리케이션 코드는 프레임워크가 짜 놓은 틀에서 수동적으로 동작하기 때문에 제어의 흐름은 프레임워크가 가지고 있고 사용자가 그 안에 필요한 코드를 작성하게 된다. (→ 제어의 역전)
제어의 역전(IoC, Inversion of Control)이란,
프로그램의 제어 흐름을 직접 제어하는 것이 아니라 외부에서 관리하는 것을 말한다.
- 어떠한 일을 하도록 만들어진 Framework에 Control 권한을 위임하는 것을 의미한다.
- 간단히 말해 프로그램의 제어 흐름 구조가 뒤바뀐 것을 뜻한다.
- 라이브러리의 경우 애플리케이션의 흐름을 사용자가 직접 제어해야 하지만
- 프레임워크의 경우 코드를 연결할 수 있는 위치를 제공하고 필요에 따라 사용자가 연결한 코드를 호출하는 제어 흐름 권한을 가지고 있다.
이전에는 개발자가 객체를 생성하고 관리하며 프로그램의 제어 흐름을 스스로 조종했다. 하지만 Spring을 사용하면 스프링 컨테이너가 프로그램의 제어흐름을 제어하게 된다.
참고 자료
https://curryyou.tistory.com/363
'CS > 개발상식' 카테고리의 다른 글
[개발상식] API란 무엇인가? (0) | 2023.08.16 |
---|---|
[개발상식] 디자인 패턴 (0) | 2023.07.01 |
[개발상식] 객체 지향 프로그래밍 (OOP) (0) | 2023.06.29 |
[개발상식] 프로그래밍 패러다임 (0) | 2023.06.25 |