의견.png

프로그래밍

해시넷
Rhkd1456 (토론 | 기여)님의 2019년 9월 16일 (월) 10:57 판 (참고자료)
이동: 둘러보기, 검색

프로그래밍(programming)이란 프로그램을 짜는 행위를 말한다. 즉, 수식 또는 작업을 컴퓨터 처리 방식에 맞게 정리하여 순서를 정하고, 특유의 명령어로 고쳐 쓰는 작업이다. 컴퓨터 프로그래밍(computer programming)이라고 한다.

개요

프로그래밍이란 프로그램 작성에 관한 전반적인 사항, 즉 프로그램의 설계, 코딩, 테스트, 디버깅 등 프로그램의 설계를 시작해서 완전한 프로그램이 작성될 때까지의 일련의 작업을 말한다. 명령 코드를 쓰는 작업은 코딩이라고 하는데, 컴퓨터가 처음 나타난 초기까지의 프로그래밍은 숫자를 나열한 명령코드를 쓰는 기계어였다. 그러나 기계어는 틀리기 쉽고, 또한 틀린 곳을 발견하기가 어렵다는 단점이 있어서 인간이 외우기 쉬운 언어·수식 등을 사용해 프로그램을 쓰고, 그것을 컴퓨터에 넣어서 컴퓨터가 자신의 명령코드로 고쳐 계산을 실시하는 방식이 고안되었다.[1]

역사

컴퓨터인스트럭션은 0과 1로 이루어져 있다. 이런 형태의 인스트럭션을 기계어라 한다. 0과 1은 컴퓨터 내부의 전기 신호 중 하나로 0또는 1 중 하나의 값을 갖는다고 해서 ‘이진’이라고 한다. 그리고 그 값을 비트라고 한다.

  • 1940년~50년대 : 컴퓨터의 기판 상에 있는 작은 전선들을 조작해서 연결이 이루어진 곳은 1을, 연결이 없는 곳은 0을 나타나게 해놓았고, 이 전선 연결의 조합이 당시의 프로그래밍이었다. 이런 형태의 배선은 만드는 데 아주 오랜 시간이 걸리고, 에러가 발생했을 때 찾아내는 것이 거의 불가능했다.
  • 1950~60년대 : 컴퓨터 메모리 내의 값을 이용하여 프로그래밍을 하기 시작했다. 빠른 프로그램 수정을 가능하게 해주었지만 수많은 0과 1로 이루어진 패턴과 싸움하는 것은 예전과 마찬가지였다. 사람들은 보다 쉽게 기억하기 위해 비트 패턴 대신 일종의 약어를 사용하기 시작했다. 약어는 비트 패턴의 기능 설명으로부터 만들어진 용어로 어셈블러(assembler)라 불리우는 프로그램에 의해 이진수 패턴 형태로 바뀐다. 이렇게 축약어로 일어진 언어를 어셈블리어(assembly language)라고 한다.
  • 1970~-80년대 : 프로그래밍 분야에 절차적 언어가 유행하게 된다. 대표적인 절차적 언어는 파스칼(Pascal)과 C 언어이다. 이 언어가 등장하기 전의 프로그램은 코드를 길게 늘어뜨려, 프로그램 내의 각 파트를 구분지어 주는 어떤 경계도 없었다. 때문에 프로그래밍 중 어느 한 곳에서 다른 곳으로 이동하려면, 긴 코드 전체를 뒤져서 이동하는 과정을 거쳐야 했다. 절차적 언어는 이를 보안하여 코드를 몇 개의 단위로 구분지어 주었다. 절차적 언어가 등장하기 전에도 프로시저(procedure)가 존재하기는 했지만 절차를 표준화하고 보다 예측 가능한 형태로 쓰일 수 있게 보편화된 것은 절차적 언어 등장 이후이다.
객체 지향은 코드를 절차로 그룹짓는 것에서 한 걸음 더 나아가 절차를 또 다시 객체로 그룹짓는 것이다. 객체(object)는 특정 작업을 수행해 주는 코드뿐만 아니라 그 작업에서 다루는 모든 데이터도 포함한다. 객체 지향 방식에서는 모든 코드를 그 코드가 다룰 데이터와 함께 묶어 객체로 구분해서 독립시켰다. 각 객체는 오직 자신의 데이터만을 바꿀 수 있고, 다른 객체의 데이터는 변경시킬 수 없다. 한 객체의 데이터에 문제가 생긴다면 그 객체 안의 코드만 살펴보면 된다. 이 방식이 등장하기 전에는 다른 사람이 만든 코드를 이용하는 것이 쉬운 일이 아니었다. 각 코드를 기능별로 객체화해서 완성해 두었기 때문에 보다 많은 코드들이 재사용될 수 있게 되었고 이는 프로그래밍 작업의 생산성 증가와 비용 감소로 이어졌다.

종류

멀티 프로그래밍

하나의 처리 장치에 의해서 둘 이상의 컴퓨터 프로그램을 교대로 배치하여 실행하는 기능을 갖춘 조작 형태이다. 하나의 컴퓨터로 복수 개의 프로그램을 겉보기로 동시에 실행하는 것이며, 멀티프로그래밍의 목적은 처리 장치, 기억 장치, 입출력 장리, 채널 등의 컴퓨터 자원을 병렬적으로 사용하여 시스템 전체의 사용 효능을 높이는 것이다.

장점 : 동시에 여러 프로그램을 실행할 수 있어 처리 능력이 좋음

단점 : 여러 프로그램을 관리하기 때문에 운영체제의 구조가 복잡

모듈 프로그래밍

프로그램을 모듈화하여 독립성을 갖게 함으로써 다른 모듈에 영향을 받지 않고 모듈의 일부 개량이나 재번역을 가능하게 하는 프로그래밍 기법이다. 각 모듈인 기능이나 서브루틴은 국소적 변수를 써서 독립성을 높이고 있으며, 통합된 기능별로 모듈화 한다. 모듈러 프로그램 작성의 목적은 크고 복잡한 프로그램을 유지를 쉽게 하고, 신뢰성을 높이는 것이다. 모듈러 프로그래밍에서 즁요한 점은 하나의 모듈은 한 가지 일만 하도록 작성해야 한다는 것이다. 이런 프로그램이 유지보수 또한 간편하다. 모듈은 오직 한 개의 상태만 가질 수 있는데, 일반적인 기능을 하는 프로시져를 다른 하나의 모듈로 묶어서 각각의 모듈이 독립적인 데이터를 가질 수 있도록 한다. 이 말은 모듈 내의 프로시져가 호출됨으로써 생기게 되는 변경사항에 대해 해당 모듈이 이를 관리할수 있다라는 말이며 독립성을 지니고 있다.

마이크로프로그래밍

1951년, 모리스 월크스는 마이크로프로그래밍이라는 용어를 만들었다.[2] 마이크로프로그래밍, 이를테면 마이크로코드는 CPU 안에 기계어를 상대적으로 쉽게 추가할 수 있도록 이용하는 빙속으로 다른 방식들에 비해 하드웨어를 덜 사용한다. 매우 상세하면서도 기초가 되는 가장 낮은 수준에 루틴의 모임이며 이러한 루틴은 특정한 명령어를 수행하는 데 필요한 동작들을 제어하고 나열한다. 또, 이따금씩 이들을 해석하기도 한다. 그러므로 일련의 마이크로 명령어가 추가한 기계어는 인터프리터가 기계어를 사용하여 고급 프로그래밍 언어의 명령문을 추가하는 방식과 비슷하다고 볼 수 있다.[2]

메타프로그래밍

메타프로그래밍이란 자기 자신 혹은 다른 컴퓨터 프로그램을 데이터로 처리함으로써 프로그램을 작성·수정하는 프로그램을 작성하는 것을 말한다. 넓은 의미에서, 런 타임에 수행해야 할 작업의 일부를 컴파일 타임 동안 수행하는 프로그램을 말하기도 한다. 구현되는 언어로는 Java, Python, Go, Lisp 등이 있다.

동작 방식의 종류

  1. 런타임 엔진의 코드를 API를 통해 프로그램에 노출시키는 방식
  2. 문자열이나 혹은 다른 형태로 된 프로그래밍 명령을 동적으로 수행시키는 방식
  3. 해당 언어의 범주를 완전히 벗어나는 방식, 범용 프로그램 변환 시스템은 일반적인 메타프로그래밍을 직접 구현

메타프로그래밍의 종류

  • 타입 내성 또는 타입 자기성찰 : 수행중인 프로그램에서 변수나 함수들이 타입이나 속성을 알아냄
  • 반영 : 실행중인 프로그램 자신의 구조와 행동을 조사하고 자가성찰하고 변경
  • 자기-수정 코드 : 코드를 스스로 고칠 수 있는 것


각주

  1. 프로그래밍〉, 《네이버 지식백과》
  2. 2.0 2.1 마이크로코드〉, 《위키백과》

참고자료

같이 보기


  의견.png 이 프로그래밍 문서는 프로그래밍에 관한 토막글입니다. 위키 문서는 누구든지 자유롭게 편집할 수 있습니다. [편집]을 눌러 이 문서의 내용을 채워주세요.