디시인사이드 갤러리

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

갤러리 본문 영역

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

나르시갤로그로 이동합니다. 2025.08.11 00:26:17
조회 69 추천 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/08/25 - -
2881405 하루 한 번 헤르미온느 찬양 헤르 미온느갤로그로 이동합니다. 08.14 87 0
2881404 AI 가 답해주는 포럼 웹사이트 만듬 프갤러(211.55) 08.14 83 0
2881402 게임 1인 개발 성공하니까 단나더 생각나네 ㅇㅇ(125.182) 08.14 138 1
2881400 게임개발하고싶어서 컴공 진학 희망하는 학생인데 진짜 궁금한거 있음. [15] 프갤러(58.78) 08.14 206 0
2881399 패턴 템플릿을 만들어두고 세부 구현 주의사항을 제네릭하게 만들어서 [1] ㅆㅇㅆ(124.216) 08.14 99 0
2881397 시스템 명세 짜고 설명붙이고 구현하고 ㅆㅇㅆ(124.216) 08.14 78 0
2881396 하루 평균 클래스 40개의 명세, 함수, 메서드 약 200개여개 명세 [1] ㅆㅇㅆ(124.216) 08.14 110 0
2881381 근데 개발자 취업시장 안좋은건 [22] 프갤러(118.235) 08.14 529 0
2881370 참 공부를 하면서 느낀다 루도그담당(58.239) 08.14 81 0
2881369 프갤에 글이 없네 ㅋㅋ [2] 프갤러(121.139) 08.14 100 1
2881368 냉면 먹어야겠다 ㄱ ㅐ ㅆ ㅣ빨썌끼들아!!!!!! 프갤러(121.139) 08.14 62 0
2881366 님이 사용 중인 어플들 러스트가 아니라 C/C++로 만든거다 나르시갤로그로 이동합니다. 08.14 84 0
2881365 납품 준비 하나 끝. 아 존나 힘들다 ㅆㅇㅆ(124.216) 08.14 63 0
2881364 식당 술값이 폭리면? 주식 수익은 부당 이익이냐? 나르시갤로그로 이동합니다. 08.14 63 0
2881363 식당 술값이 폭리면? 개발비도 폭리냐? 나르시갤로그로 이동합니다. 08.14 64 0
2881360 GC없는, (메모리 등) 안전 대세 언어: Ada 나르시갤로그로 이동합니다. 08.14 89 0
2881359 러스트가 확실히 대세가 아닌 이유 나르시갤로그로 이동합니다. 08.14 104 0
2881351 개인적으로 개발 세부 구현사항은 문서화 안하지만 전반적으로 ㅆㅇㅆ(124.216) 08.14 86 0
2881348 그리고 기본적으로 마소 예제는 나름대로 기술 분석 해두는게 좋더라 [2] ㅆㅇㅆ(124.216) 08.14 121 0
2881347 뇌과학적으로 고소득층 사람들은 물건보다 '이것'에 집착합니다 발명도둑잡기갤로그로 이동합니다. 08.14 62 0
2881346 아인슈타인의 ‘그 논문’ 50년간 묻혔다가 과학계 레전드로 역주행 발명도둑잡기갤로그로 이동합니다. 08.14 79 0
2881345 나는 대부분 내가 만들어보거나 해본 것들 어지간하면 적어둠 [8] ㅆㅇㅆ(124.216) 08.14 120 0
2881344 나는 크롤링 전문이 아니라서, 그냥 기초 원리만 아는거. [3] ㅆㅇㅆ(124.216) 08.14 112 0
2881343 아씨발나스닥왜자꾸올라개새끼야!!!!!!! [3] 아스카영원히사랑해갤로그로 이동합니다. 08.14 103 0
2881342 웹 크롤링 뷰티풀 스프 사용하는 방법 [2] ㅆㅇㅆ(124.216) 08.14 107 0
2881341 나도 어제 좆개판으로 크롤러 짯는데 [2] 루도그담당(58.239) 08.14 94 0
2881340 R 스크립트 짜면서 느끼는데 유독 파이썬 R은 GPT가 잘짜 ㅆㅇㅆ(124.216) 08.14 81 0
2881338 개발 항상 하면 느끼지만 가장 큰 적은 '돌아가는데 굳이..' 이거임 [2] ㅆㅇㅆ(124.216) 08.13 99 0
2881337 그 약이라는게 그렇게 끊기가 힘듬?? 계속 생각나?? [7] ㅇㅇ(223.39) 08.13 131 0
2881336 파이썬 질문있습니다 [3] 프갤러(211.105) 08.13 100 0
2881335 ㅆㅇㅆ님 이 글에 대해 의견좀 [1] 발명도둑잡기갤로그로 이동합니다. 08.13 100 0
2881331 내가 ai 안쓰는 이유 프갤러(121.139) 08.13 101 0
2881330 금융 로직의 문제는 뭐냐면 [1] 밀우갤로그로 이동합니다. 08.13 109 0
2881327 프갤러들 제국주의자 되는 과정 발명도둑잡기갤로그로 이동합니다. 08.13 68 0
2881326 이직했는데 존나어렵다 [1] 프갤러(220.70) 08.13 121 0
2881324 코테 문제들 어질어질하노 [1] 프갤러(220.85) 08.13 359 0
2881321 ㅇㅣ거 뭐냐 ㅇㅇ(211.105) 08.13 54 0
2881317 요즘 식당, 술집들 보면 술로 너무 폭리 취함 [19] 야옹아저씨갤로그로 이동합니다. 08.13 416 6
2881315 챗티씨에 코드 맡기고 나는 누워잇는중 [1] 헬마스터갤로그로 이동합니다. 08.13 82 0
2881312 도대체 영화관리를 어떻게 하길래 벌써 XX티비에 영화가 다떴지?? [6] ㅇㅇ(223.39) 08.13 110 0
2881309 잡코리아에서 AI 공모전으로 채용까지 하네요 프갤러(114.203) 08.13 63 0
2881302 퍼플렉시티랑 지피티 듀오로 가야하나 프갤러(61.79) 08.13 68 0
2881300 빌게이츠 이새낀 좇센 왜오는거?? 미국에선 총기맞을까봐 오는거?? 타이밍뒷통수한방(1.213) 08.13 69 0
2881297 카페 와이파이를 쓰면 안 되는 이유 발명도둑잡기갤로그로 이동합니다. 08.13 72 0
2881294 리눅스 예전에는 좋았던거 같은데 점점 성능이 내려가는느낌임 타이밍뒷통수한방(1.213) 08.13 75 0
2881292 형님들 엑셀 도움좀 주실분요 ㅠㅠ [1] 프갤러(180.69) 08.13 71 0
2881291 다들 웹사이트 만들 때 폰트 뭐 씀? ㅇㅇ갤로그로 이동합니다. 08.13 59 0
2881286 러스트가 확실히 요증 대세는 맞네 ㅇㅇ(125.179) 08.13 86 0
2881284 asp.net core 문서 보면서 공부나 해야겠다 루도그담당(58.239) 08.13 69 0
2881283 나도 MCP 만들어서 쓰는데 굳이 한국 토종 MCP 써야할 무언가인가 [4] ㅆㅇㅆ(124.216) 08.13 101 0
뉴스 아이브, 신보 '아이브 시크릿' 발매…장원영 작사 참여 디시트렌드 18:00
갤러리 내부 검색
제목+내용게시물 정렬 옵션

오른쪽 컨텐츠 영역

실시간 베스트

1/8

뉴스

디시미디어

디시이슈

1/2