라이브러리와 프레임워크

YW K·2023년 4월 11일

Others

목록 보기
1/3

📌Library VS Framework

1) 프레임워크

  • 원하는 기능 구현에 집중하여 개발할 수 있도록 일정한 형태와 필요한 기능을 갖추고 있는 골격, 뼈대를 의미한다.

    애플리케이션 개발 시 필수적인 코드, 알고리즘, DB 연동과 같은 기능들을 위해 어느 정도 뼈대(구조)를 제공하며 이러한 뼈대 위에서 사용자는 코드를 작성하여 애플리케이션을 개발한다. 앱/서버 등의 구동, 메모리 관리, 이벤트 루프 등의 공통된 부분은 프레임워크가 관리하며, 사용자는 프레임워크가 정해준 방식대로 클래스, 메소드들을 구현하면 된다.

    다시말해, 프레임워크는 애플리케이션의 코드가 프레임워크에 의해 사용된다. 애플리케이션 코드는 프레임워크가 짜놓은 틀에 수동적으로 동작하기 때문에 제어의 흐름은 프레임워크가 가지고 있고 사용자가 그 안에 필요한 코드를 작성하게 된다.

1-1) 프레임워크 예시

  • Java 서버 개발에 사용되는 Spring
  • Python 서버 개발에 사용되는 Django, Flask
  • 안드로이드 앱 개발에 사용되는 Android
  • 아이폰 앱 개발에 사용되는 Cocoa Touch
  • 웹 개발에 사용되는 Angular, Vue.js etc

2) 라이브러리

  • 소프트웨어를 개발할 때 컴퓨터 프로그램이 사용하는 비휘발성 자원의 모임, 즉 특정 기능을 모아둔 코드, 함수들의 집합이며 코드 작성 시 활용 가능한 도구들을 의미한다.

    다시말해, 라이브러리를 사용할 때 사용자는 애플리케이션 코드의 흐름을 직접 제어해야한다. 개발 시 필요한 기능이 있을 경우 능동적으로 라이브러리를 호출하여 사용하거나 기존에 구성된 함수나 코드를 가져다 사용해야한다.

2-1) 라이브러리 예시

  • Python pip로 설치한 패키지/모듈 (Tensorflow, Pandas etc)
  • C++의 표준 라이브러리 (STL)
  • Node.js에서 npm으로 설치한 모듈
  • HTML의 클라이언트 사이드 조작을 단순화하는 JQuery
  • 웹에서 사용자 인터페이스 개발에 사용되는 React.js

3) 그렇다면 리액트는 프레임워크일까? 라이브러리일까?

React.js는 웹 서비스 중에 사용자 인터페이스 개발을 위해 사용되는 라이브러리이다. 리액트는 내가 부르는 것이며, 규칙이 존재하지 않아 라이브러리라한다. 그러나 리액트가 우리의 컴포넌트(프로그래밍에 있어 재사용이 가능한 각각의 독립된 모듈)를 부르기 때문에 이러한 경우에는 리액트를 '프레임워크'로 바라볼 수 있다. 즉 내가 컴포넌트를 작성하면 리액트가 이를 불러와 스크린에 보여준다. 따라서 리액트는 라이브러리이기도 하며, 프레임워크이기도 하다.
컴포넌트 설명

정리하면 라이브러리, 프레임워크는 모두 다른 누군가가 쓴 코드로 우리의 프로젝트를 위해서 갖다 사용하는 것이다. 따라서 내가 코드를 제어하는건지 VS 누군가의 규칙을 따라 코딩하는 것인지에 대한 차이가 있다.

  • 라이브러리의 가장 좋은 예시는 JQuery로 이는 웹사이트에 인터랙티브한 요소를 넣을 수 있다. 즉 내가 코딩을 하다가 필요할 때 제이쿼리를 소환할 수 있다. 반면 프레임워크는 부르는 게 아니라 프레임워크가 나를 부르는 것이다. 이게 라이브러리와 프레임워크의 가장 명확한 차이점이다. 프레임워크가 규칙을 정하고 우리에게 어디에 코드를 넣어야 하는지 등등을 알려준다. 프레임워크의 좋은 예시는 Django 웹 프레임워크이다.

👀 프레임워크 VS 라이브러리

프레임워크는 단지 미리 만들어둔 반제품이나, 확장해서 사용할 수 있도록 준비된 추상 라이브러이의 집합이 아니다. 프레임워크가 어떤 것인지 이해하려면 라이브러리와 프레임워크가 어떻게 다른지 알아야 한다.

라이브러리를 사용하는 애플리케이션 코드는 애플리케이션 흐름을 직접 제어한다. 단지 동작하는 중에 필요한 기능이 있을 때 능동적으로 라이브러리를 사용할 뿐이다.

반면 프레임워크는 거꾸로 애플리케이션 코드가 프레임워크에 의해 사용된다. 프레임워크에는 분명한 [제어의 역전]개념이 적용되어 있어야 한다.

애플리케이션 코드는 프레임워크가 짜 놓은 틀에서 수동적으로 동작해야 한다.

- 토비의 스프링 中

✨ 따라서 프레임워크와 라이브러리의 차이점은 "제어흐름"의 권한이 어디에 있는가이다.

여기서 제어의 역전(IoC, Inversion of Control)이란 어떠한 일을 하도록 만들어진 프레임워크에 제어(Control) 권한을 위임하는 것을 의미하는데, 간단히 말해 프로그램의 제어 흐름 구조가 뒤바뀐 것을 말한다.

라이브러리의 경우 애플리케이션의 흐름을 사용자가 직접 제어하지만 프레임워크의 경우 코드를 연결할 수 있는 위치를 제공하고 필요에 따라 사용자가 연결한 코드를 호출하는 제어 흐름 권한을 가지고 있다.

0개의 댓글