디시인사이드 갤러리

갤러리 이슈박스, 최근방문 갤러리

갤러리 본문 영역

Ada 프로그래밍: 8. 동시성 및 실시간 프로그래밍

나르시갤로그로 이동합니다. 2025.08.11 00:26:17
조회 89 추천 0 댓글 0

8. 동시성 및 실시간 프로그래밍

Ada의 특징 중 하나는 동시성, 즉 병렬 처리를 위한 내장 지원입니다. 외부 라이브러리(예: C의 pthreads)나 플랫폼별 API에 의존하는 많은 언어와 달리, Ada의 동시성 기능은 언어 명세의 필수적인 부분입니다. 이는 이식성, 안전성, 정확성에 영향을 미칩니다. 동시성 Ada 프로그램은 작은 베어-메탈 임베디드 시스템에서부터 멀티코어 서버에 이르기까지 호환되는 컴파일러가 있는 모든 플랫폼으로 이식 가능하며, 동시성 의미론은 일관성이 보장됩니다. 컴파일러는 동시성 구조를 인지하고 있어 라이브러리 기반 접근 방식으로는 불가능한 검사와 최적화를 수행할 수 있습니다.

Ada는 표현력, 성능, 형식적 분석 가능성 사이의 트레이드오프 공간에서 서로 다른 지점에 적합한 다양한 도구를 제공하는 동시성 모델의 스펙트럼을 제공합니다.

8.1 태스킹 모델

Ada에서 동시성의 기본 단위는 task입니다. 태스크는 프로그램의 다른 태스크와 동시에 실행되는 독립적인 제어 스레드입니다. 패키지나 서브프로그램처럼, 태스크는 두 부분으로 정의됩니다: 공개 인터페이스를 정의하는 태스크 명세와 실행 코드를 포함하는 태스크 본체입니다.

태스크는 자동으로 활성화됩니다. 프로그램 실행이 태스크가 선언된 범위에 진입하면, 태스크는 자신을 선언한 코드(마스터)와 병렬로 실행을 시작합니다. 범위(예: 서브프로그램 또는 블록)는 그 안에 선언된 모든 태스크가 실행을 완료할 때까지 종료되지 않습니다. 이는 간단하고 견고한 형태의 동기화를 제공합니다.

with Ada.Text_IO;

procedure demonstrate_tasking is
  task T; -- 태스크 명세 (여기에는 공개 인터페이스 없음)

  task body T is -- 태스크 구현
  begin
    for i in 1 .. 5 loop
      Ada.Text_IO.put_line ("Task T is running...");
    end loop;
  end T;

begin -- 주 프로시저 실행 시작
  Ada.Text_IO.put_line ("Main procedure is running.");
  -- 주 프로시저는 이제 태스크 T가 종료될 때까지 여기서 대기함
end demonstrate_tasking;

Ada는 또한 태스크 형식을 지원하여, 단일 템플릿에서 여러 태스크를 선언할 수 있게 합니다. 이는 클래스에서 여러 객체를 생성하는 것과 유사합니다. 예를 들어, 작업자 태스크의 배열을 만드는 데 유용합니다.

8.2 동기화 및 통신: 랑데부

Ada에서 태스크 간의 직접적이고 동기적인 통신 및 동기화를 위한 원래 메커니즘은 랑데부(rendezvous)입니다. 이것은 클라이언트-서버 스타일 상호작용을 위한 모델입니다.

랑데부는 두 가지 구조를 기반으로 합니다:

  • entry: 엔트리는 태스크의 명세에 선언되며, 프로시저와 유사하게 공개적으로 호출 가능한 진입점 역할을 합니다. 상호작용을 위한 인터페이스를 정의합니다.

  • accept: accept 문은 태스크의 본체에 위치합니다. 태스크의 실행이 accept 문에 도달하면, 다른 태스크가 해당 entry를 호출할 때까지 대기합니다.

클라이언트 태스크가 엔트리를 호출하고 서버 태스크가 일치하는 accept 문에 있을 때, 두 태스크는 랑데부에서 동기화됩니다. 클라이언트 태스크는 서버 태스크가 accept 문의 do ... end 블록 내의 코드를 실행하는 동안 차단됩니다. 이 블록은 엔트리의 매개변수를 통해 데이터를 교환하는 데 사용될 수 있습니다. 서버가 accept 블록을 완료하면 랑데부가 끝나고, 두 태스크는 독립적으로 실행을 계속합니다.

task Server is
  entry request_data (value : out Integer);
end Server;

task body Server is
  current_value : Integer := 0;
begin
  loop
    current_value := current_value + 1;
    accept request_data (value : out Integer) do
      value := current_value; -- 이것은 랑데부 중에 발생함
    end request_data;
  end loop;
end Server;

-- 클라이언트 태스크에서:
declare
  my_data : Integer;
begin
  Server.request_data (my_data); -- 클라이언트는 엔트리를 호출하고, 랑데부가 완료될 때까지 차단됨
end;

더 복잡한 상황을 처리하기 위해, 태스크는 select 문을 사용하여 여러 엔트리에 대한 호출을 동시에 기다리거나, 특정 기간 내에 호출이 도착하지 않으면 시간 초과(또는 delay)하거나, 즉시 랑데부가 불가능할 경우 대안적인 조치(else)를 취할 수 있습니다.

8.3 공유 데이터를 위한 보호 객체

랑데부는 공유 데이터 접근을 관리하는 일반적인 문제에 비효율적일 수 있지만, Ada 95는 protected 형식을 도입했습니다. 보호 객체(protected object)는 개인 데이터를 캡슐화하고 이에 대한 상호 배타적인 접근을 보장하는 수동적인 데이터 구조입니다. 이는 임계 구역 문제에 대한 직접적이고 효율적인 해결책입니다.

보호 객체는 세 가지 종류의 연산을 제공합니다:

  • 프로시저: 개인 데이터에 대한 배타적인 읽기-쓰기 접근을 제공합니다. 언어 런타임은 주어진 보호 객체의 프로시저를 한 번에 하나의 태스크만 실행할 수 있도록 보장합니다.

  • 함수: 개인 데이터에 대한 공유 읽기 전용 접근을 제공합니다. 여러 태스크가 동일한 보호 객체의 함수를 동시에 실행할 수 있습니다.

  • 엔트리: 태스크 엔트리와 유사하지만, 불리언 베리어(barrier) 조건이 있습니다. 보호 엔트리를 호출하는 태스크는 엔트리의 베리어가 참으로 평가될 때까지 대기열에 추가되고 차단됩니다. 접근은 여전히 상호 배타적입니다.

protected type Shared_Counter is
  procedure increment;
  function get_value return Integer;
private
  value : Integer := 0;
end Shared_Counter;

protected body Shared_Counter is
  procedure increment is
  begin
    value := value + 1; -- 배타적 접근 보장
  end increment;

  function get_value return Integer is
  begin
    return value; -- 공유 읽기 전용 접근
  end get_value;
end Shared_Counter;

보호 객체를 사용하면 프로그래머가 데이터와 연산을 선언하고, 컴파일러와 런타임 시스템이 기본 잠금 메커니즘을 자동으로 처리합니다. 이는 경쟁 조건과 교착 상태를 구조적으로 방지하여, 동시성 프로그래밍을 더 안전하고 간단하게 만듭니다.

8.4 Ravenscar 프로파일

안전이 중요한 하드 실시간 시스템의 경우, Ada 동시성 기능의 전체 집합은 타이밍 동작과 스케줄링 가능성을 형식적으로 분석하기에 너무 복잡할 수 있습니다. 이를 해결하기 위해 Ravenscar 프로파일(Ravenscar Profile)이 개발되어 Ada 2005에서 표준화되었습니다.

Ravenscar 프로파일은 실시간 프로그래밍에 충분히 강력하면서도 형식적 정적 분석에 적합할 만큼 간단한, 선택된 Ada 태스킹 기능의 하위 집합입니다. 그 제한 사항은 일반적으로 다음을 포함합니다:

  • 동적 생성이나 종료가 없는 고정된 수의 태스크.
  • 일반적으로 보호 객체로 제한되는 단순화된 태스크 통신 모델.
  • else 부분이 있는 복잡한 랑데부나 select 문 없음.
  • 단순하고 예측 가능한 스케줄링 정책.

이 프로파일을 준수함으로써, 개발자는 교착 상태의 부재 및 하드 데드라인 충족과 같은 속성을 증명할 수 있는 동시성 시스템을 구축할 수 있습니다. 이는 항공 전자 공학의 DO-178C와 같은 안전 표준에 대해 Ada 소프트웨어를 인증하는 것을 가능하게 합니다.

추천 비추천

0

고정닉 0

0

댓글 영역

전체 댓글 0
본문 보기

하단 갤러리 리스트 영역

왼쪽 컨텐츠 영역

갤러리 리스트 영역

갤러리 리스트
번호 제목 글쓴이 작성일 조회 추천
설문 현대물보다 사극에서 더 빛나는 남자 배우는? 운영자 25/09/08 - -
AD 신학기 레벨업~!! 운영자 25/09/05 - -
2883244 [애니뉴스] 잡지 1호 귀인환등초 제작중! 프갤러(121.172) 08.21 68 0
2883243 [애니뉴스][잡지해설] 제작중 - 「귀인환등초」 「오후우」와 이야기의 핵 프갤러(121.172) 08.21 75 0
2883240 이제 기름진거 안 먹어야지 루도그담당(118.235) 08.21 82 0
2883238 KB증권 전산 문제 터졌냐? 아스카영원히사랑해갤로그로 이동합니다. 08.21 92 0
2883237 0.4% 확률이 허벌처럼 털렸습니다. [5] 헬마스터갤로그로 이동합니다. 08.21 120 0
2883236 나 진짜 이제 하루 10만줄 찍을 수 있을듯 [2] ㅆㅇㅆ(124.216) 08.21 129 0
2883235 아큐라스트를 팔아서 휫자를 먹으면 그게 피와살이되는것이오 손발이시립디다갤로그로 이동합니다. 08.21 72 0
2883234 아큐라스트 깔고 1코인이라도 받아놓으시요 [2] 손발이시립디다갤로그로 이동합니다. 08.21 103 0
2883232 나도 만들다 방치해둔 블루아카이브 가챠 사이트를 [6] 아스카영원히사랑해갤로그로 이동합니다. 08.21 129 0
2883231 지금 국비가면 ㄹㅇ 경계선들 넘쳐난다던데 [3] ㅇㅇ(220.120) 08.21 297 0
2883230 헬마년 당황해서 보둥지둥 대느라 댓글도 못다네 개멍청한유라갤로그로 이동합니다. 08.21 84 0
2883228 다뽑았는데요? [6] 개멍청한유라갤로그로 이동합니다. 08.21 129 0
2883227 점심 먹으러 나왔는데 [1] 루도그담당(118.235) 08.21 102 0
2883226 나는 mcp로 네이쳐 논문 출처 붙여서 써 그게 정배임 ㅆㅇㅆ(124.216) 08.21 97 0
2883225 떳냐?! [6] 개멍청한유라갤로그로 이동합니다. 08.21 123 0
2883224 나는 MCP 붙여서 원서 책 pdf 넣고 질문함 [3] ㅆㅇㅆ(124.216) 08.21 125 0
2883221 Mcp 좀 붙이면 [1] 루도그담당(118.235) 08.21 123 0
2883220 북한이나 남한이나 민족성이 왜그럴까 ㅋㅋ 커뮤 꾸준히 눈팅하면서 연구하자 뒷통수한방(1.213) 08.21 77 0
2883218 아 씨발 [1] 루도그담당(118.235) 08.21 91 0
2883217 진짜 MCP 직접 만들어서 붙이니까 일이 조오오오온나 편하다 [1] ㅆㅇㅆ(124.216) 08.21 111 0
2883216 빌게이츠도 이재명부류였네 퐁퐁남 ㅋㅋㅋㅋㅋㅋㅋ 뒷통수한방(1.213) 08.21 87 0
2883215 제미나이 MCP 붙이니까 조오오오온나 편하네 [2] ㅆㅇㅆ(124.216) 08.21 130 0
2883214 뉴프로 기프트콘 복귀 ㅅㅅ [9] 헬마스터갤로그로 이동합니다. 08.21 115 0
2883212 어제 몸살나서 진짜 죽는줄암... 얼마만에 아픈건지 모르겠네... ㅇㅇ(114.201) 08.21 88 0
2883210 자러간당~~ㅇㅅㅇ 헤르 미온느갤로그로 이동합니다. 08.21 70 0
2883206 오늘은 딱 6주년 되는 날입니다.. ㅇㅅㅇ 헤르 미온느갤로그로 이동합니다. 08.21 93 0
2883205 지피티 이거 너무 쓰레기같음 [1] 루도그담당(58.239) 08.21 121 0
2883203 비행기 ㅇㅅㅇ 헤르 미온느갤로그로 이동합니다. 08.21 74 0
2883202 태연 ㅇㅅㅇ 헤르 미온느갤로그로 이동합니다. 08.21 76 0
2883201 하루 한 번 헤르미온느 찬양 헤르 미온느갤로그로 이동합니다. 08.21 92 0
2883196 AI 문제가 코드 크기가 커질수록 애새끼가 병신이라 그런듯 [6] ㅆㅇㅆ(124.216) 08.21 165 0
2883195 인지과학조져라 손발이시립디다갤로그로 이동합니다. 08.21 104 0
2883194 코드 짜고 잘 준비하는데 MIT 보고서에 기업중에 AI로 돈버는곳 5% ㅆㅇㅆ(124.216) 08.21 108 0
2883151 오늘 허탕이네 진짜 아쉽다. 업워크 첫 외주 propasal이거 ㅆㅇㅆ(124.216) 08.21 118 0
2883148 나무위키 이번에 유저 이탈 받아먹으려는 떡밥위키보는데 ㅆㅇㅆ(124.216) 08.21 124 0
2883146 이번에 나무위키 터지더라 그래서 위키 하나 새로 팔려고 업자들이 ㅆㅇㅆ(124.216) 08.21 120 0
2883141 일단 이번에 영어권 외주하는 사람이랑 대화하는데 업워크 여기 봇쓰는듯 ㅆㅇㅆ(124.216) 08.21 84 0
2883140 저스틴 비버가 가장 유명한 연예인 탑 10안에 들어감? 디바(59.28) 08.21 112 0
2883139 요즘 느끼는게 프로그래밍 커뮤니티는 어린애건 늙은이건 정신못차리는듯 ㅆㅇㅆ(124.216) 08.21 107 0
2883138 23년 기준 박사연봉 현실적으로 4200만 선임 [2] ㅆㅇㅆ(124.216) 08.21 162 0
2883133 지금 한국 쉬었음 청년이전에 박사 졸업생 역대급이라 박사급 싸게 [7] ㅆㅇㅆ(124.216) 08.21 141 0
2883131 취준 하는 백수인데 [2] ㅇㅇ(104.28) 08.21 154 0
2883130 인생이란 뭘까 도전하는 재미가 아닐까 ㅆㅇㅆ(124.216) 08.21 79 0
2883128 실베에 환경 미화원인데 돈 벌어서 시기질투하는 사람 저 사람 욕먹은게 [1] ㅆㅇㅆ(124.216) 08.21 136 0
2883126 대부분 저 사람도 늙기전에 어렸을땐 이렇지 않았을텐데 ㅆㅇㅆ(124.216) 08.21 90 0
2883124 내가 느끼는게 대부분 별 볼일 없는 코더로 끝나는구나 10년차 20년차도 [2] ㅆㅇㅆㅆ(124.216) 08.21 144 1
2883120 나 대학 정보보안과 원서 넣을건대 코딩공부 뭐부터 해야해? ㅇㅇ(221.161) 08.21 107 0
2883110 요즘 엠지들 유행패션이라는데 [1] ㅇㅇ(14.5) 08.20 139 0
2883099 부트캠프히는 중인데 여기 애들 학벌이 왜이럼? [2] ㅇㅇ(220.85) 08.20 178 0
2883098 얼마나 할 일이 없으면 프갤러(59.16) 08.20 86 0
뉴스 '금쪽같은 내 스타' 송승헌, 매니저 완벽 빙의! 이엘 눈치 보며 엄정화 ‘완벽’ 케어 디시트렌드 14:00
갤러리 내부 검색
제목+내용게시물 정렬 옵션

오른쪽 컨텐츠 영역

실시간 베스트

1/8

뉴스

디시미디어

디시이슈

1/2