디시인사이드 갤러리

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

갤러리 본문 영역

Ada 프로그래밍: 4.2.3 for 루프

나르시갤로그로 이동합니다. 2025.08.12 04:44:42
조회 70 추천 0 댓글 0

4.2.3 for 루프

for 루프는 확정적 반복을 위한 기본적인 구문으로, 일련의 문장들을 지정된 횟수만큼 실행하도록 설계되었습니다. 이 횟수는 루프가 시작되기 전에 한 번만 평가되는 이산 범위(discrete range)에 의해 결정됩니다.

Ada에서 이산 타입(discrete type)은 값들 사이에 명확하고 뚜렷한 구분이 있는 타입을 의미합니다. 이 범주에는 다음이 포함됩니다.

  • 정수 타입 (예: Integer, Natural, Positive)
  • 사전 정의된 Boolean Character 타입을 포함하는 열거형 타입.

값들이 셀 수 있고 순서가 있기 때문에, 루프는 각 값을 순차적으로 반복할 수 있습니다. 이처럼 반복 횟수를 미리 알 수 있다는 결정론적(deterministic) 특성은 for 루프의 핵심적인 특징입니다. Float이나 String과 같은 비이산 타입에는 사용할 수 없습니다.

루프는 루프 파라미터(loop parameter)를 도입하는데, 이는 각 반복마다 이산 범위 내의 연속된 원소 값을 갖는 식별자입니다. 이 루프 파라미터는 세 가지 중요한 속성을 가집니다.

  1. 루프 자체에 의해 암묵적으로 선언됩니다. 별도의 선언이 필요하지 않습니다.
  2.  스코프(scope) loop 키워드부터 end loop 키워드까지의 루프 본문으로 제한됩니다. 루프 밖에서는 보이지 않습니다.
  3. 루프 내에서 상수(constant)입니다. 그 값은 각 반복이 시작될 때 루프 메커니즘에 의해 자동으로 갱신되며, 루프 본문 안의 코드로는 수정할 수 없습니다.

이산 범위 반복 (Iteration over Discrete Ranges)

가장 흔한 형태는 .. 연산자로 명시된 값의 범위를 반복하는 것입니다. 루프는 오름차순(기본값)으로 진행하거나 reverse 키워드를 사용하여 내림차순으로 진행할 수 있습니다.

예제 (정수 범위):

with Ada.Text_IO;

procedure integer_loop_example is
begin
  -- 1부터 10까지 반복
  for i in 1 .. 10 loop
    Ada.Text_IO.put_line ("Ascending: " & Integer'image (i));
  end loop;

  Ada.Text_IO.new_line;

  -- 10부터 1까지 반복
  for i in reverse 1 .. 10 loop
    Ada.Text_IO.put_line ("Descending: " & Integer'image (i));
  end loop;
end integer_loop_example;

예제 (열거형 범위): 이 예제는 사용자 정의 열거형 타입을 반복하는 것을 보여줍니다.

with Ada.Text_IO;

procedure enum_loop_example is
  type Day_Of_Week is (Monday, Tuesday, Wednesday, Thursday, Friday, Saturday, Sunday);
begin
  for day in Day_Of_Week'range loop  -- 'range는 전체 범위를 제공
    Ada.Text_IO.put (Day_Of_Week'image (day) & " ");
  end loop;
  Ada.Text_IO.new_line;

  -- 열거형의 일부 범위만 반복
  for day in Wednesday .. Friday loop
    Ada.Text_IO.put_line ("Workday: " & Day_Of_Week'image (day));
  end loop;
end enum_loop_example;

단일 범위 평가의 원칙 (The Principle of Single Range Evaluation)

Ada for 루프의 결정적인 특징은 그 이산 범위가 단 한 번만 평가된다는 점입니다. 이는 첫 반복이 시작되기 전에 범위가 완전히 계산되고 그 경계가 고정됨을 의미합니다. 이 단일 평가는 루프 파라미터를 위한 불변의 값 시퀀스를 설정하며, 결과적으로 반복 횟수는 루프 본문이 실행되기 전에 결정됩니다.

이 원칙은 null 범위(null range)를 가진 루프의 동작을 직접적으로 관장합니다. 범위의 하한이 상한보다 크면 (예: 5 .. 1) 그 범위는 null로 간주됩니다. 범위가 null일 때, 루프는 즉시 완료되며 0번의 반복을 수행합니다. 루프 본문 안의 문장들은 전혀 실행되지 않습니다.

reverse 키워드는 범위의 경계를 맞바꾸지 않으므로, 범위 자체의 유효성이 아닌 반복의 방향에만 영향을 미친다는 점을 이해해야 합니다. 이러한 이유로 for j in reverse 1 .. 0 loop 루프는 실행되지 않습니다. 범위 1 .. 0 reverse 키워드가 반복 순서를 위해 고려되기 전에 null로 결정됩니다. 이는 안전하고 예측 가능한 결과를 제공합니다.

예제: Null 범위의 동작

다음 예제는 null 범위를 가진 루프가 reverse 키워드를 사용하더라도 그 본문을 실행하지 않음을 보여줍니다.

with Ada.Text_IO;

procedure null_range_example is
  use Ada.Text_IO;
  loop_1_executed : Boolean := False;
  loop_2_executed : Boolean := False;
begin
  -- 이 루프는 5가 1보다 크므로 실행되지 않음
  for i in 5 .. 1 loop
    loop_1_executed := True;
  end loop;

  if not loop_1_executed then
    put_line ("Loop with range 5 .. 1 did not execute.");
  end if;

  -- 'reverse'를 사용해도 null 범위는 유효해지지 않음
  -- 이 루프 또한 1이 0보다 크므로 실행되지 않음
  for j in reverse 1 .. 0 loop
    loop_2_executed := True;
  end loop;

  if not loop_2_executed then
    put_line ("Loop with range 'reverse 1 .. 0' did not execute.");
  end if;
end null_range_example;

출력:

Loop with range 5 .. 1 did not execute.
Loop with range 'reverse 1 .. 0' did not execute.

이러한 설계는 for 루프가 예측 가능하고 결정론적임을 보장합니다. 매 반복 전에 종료 조건을 재평가하고 루프 내에서 수정할 수 있는 C 언어의 for 루프와 달리, Ada for 루프의 반복 횟수는 루프 본문 안에서 범위의 경계값을 변경해도 영향을 받지 않습니다.

예제: 불변의 반복 횟수

다음 코드는 루프의 범위를 정의하는 데 사용된 변수가 루프 내에서 수정되더라도, 원래의 반복 횟수는 변하지 않음을 보여줍니다.

with Ada.Text_IO;

procedure immutable_bounds_example is
  use Ada.Text_IO;
  upper_bound : Integer := 3;
begin
  put_line ("Loop will start with range 1 .. " & Integer'image (upper_bound));
  new_line;

  -- '1 .. upper_bound' 범위는 여기서 '1 .. 3'으로 평가됨
  -- 이제 루프는 정확히 3번 실행되도록 고정됨
  for i in 1 .. upper_bound loop
    put_line ("Start of iteration " & Integer'image (i) &
              ": upper_bound is " & Integer'image (upper_bound));

    if i = 2 then
      upper_bound := 10; -- 이 변경은 루프의 실행 기간에 영향을 주지 않음
      put_line (" -> upper_bound changed to 10 inside the loop.");
    end if;
  end loop;

  new_line;
  put_line ("Loop finished. It executed 3 times as determined initially.");
  put_line ("Final value of upper_bound: " & Integer'image (upper_bound));
end immutable_bounds_example;

출력:

Loop will start with range 1 ..  3

Start of iteration  1: Upper_Bound is  3
Start of iteration  2: Upper_Bound is  3
 -> Upper_Bound changed to 10 inside the loop.
Start of iteration  3: Upper_Bound is  10

Loop finished. It executed 3 times as determined initially.
Final value of Upper_Bound:  10

이 동작은 우발적인 무한 루프나 조기 종료와 같은 흔한 종류의 오류를 방지하여 프로그램의 안전성과 신뢰성을 향상시킵니다. 또한 프로그래머가 루프의 선언만 보고도 정확한 반복 횟수를 결정할 수 있게 하여 코드 가독성을 높입니다.

배열 및 컨테이너 반복 (Array and Container Iteration)

for 루프는 배열이나 반복 가능한 컨테이너의 원소들을 반복하는 데에도 사용될 수 있습니다.

  • 배열 인덱스 반복: 'range 속성은 배열 인덱스의 범위를 제공하며, 각 원소를 인덱스로 접근하는 데 유용합니다.

    buffer : String (1 .. 10);
    -- ... (buffer가 초기화됨)
    for i in buffer'range loop
      if buffer (i) /= ' ' then
        Ada.Text_IO.put (buffer (i));
      end if;
    end loop;
    
  • 배열 원소 반복 (컴포넌트 반복): Ada는 배열의 구성 요소(원소)를 직접 반복하는 것을 허용합니다. 이 경우 루프 파라미터는 원소를 직접 가리킵니다. 만약 배열이 상수가 아니라면 루프 파라미터는 변수가 되어, 배열 원소의 직접적인 수정이 가능합니다.

    my_array : array (1 .. 5) of Integer := [10, 20, 30, 40, 50];
    begin
      for element of my_array loop
        element := element * 2; -- my_array의 원소를 수정함
      end loop;
    end;
    

반복자 필터 (Iterator Filter)

when 절을 가진 iterator_filter for 루프에 추가하여 특정 조건을 만족하는 값에 대해서만 루프 본문을 조건부로 실행할 수 있습니다.

예제: 이 루프는 범위 내의 홀수만 처리합니다.

for i in 1 .. 10 when i mod 2 /= 0 loop
  Ada.Text_IO.put_line ("Processing odd number: " & Integer'image (i));
end loop;

 

추천 비추천

0

고정닉 0

0

댓글 영역

전체 댓글 0
본문 보기

하단 갤러리 리스트 영역

왼쪽 컨텐츠 영역

갤러리 리스트 영역

갤러리 리스트
번호 제목 글쓴이 작성일 조회 추천
설문 시구, 시축 했다가 이미지가 더 나빠진 스타는? 운영자 25/08/11 - -
AD 가전디지털, 휴대폰 액세서리 SALE 운영자 25/08/08 - -
2880940 추악한 모습을 드러내야 하는데요. 프갤러(220.84) 08.12 48 0
2880937 집에 5공화국 쉴드치는 돼지가 살아요. 넥도리아(223.38) 08.12 33 0
2880935 클리우드 엔지니어쪽 생각하고 있는데 프갤러(211.235) 08.12 49 0
2880931 대규모시스템설계기초책 재밌네 [1] 밀우갤로그로 이동합니다. 08.12 44 0
2880929 찐윤이랑 윤석열이 국민 삶 의료질 다 망쳐나서.. [1] 넥도리아(223.38) 08.12 48 0
2880927 아는 형님이 크롤링 만들어달래서 루도그담당(58.239) 08.12 64 1
2880926 영어 좆도 모르면 프로그래밍 못 할 정도임? [15] 냥이펀치갤로그로 이동합니다. 08.12 116 0
2880917 이거 ODD 수리 하는게 좋을까요. 어떻게 살릴까요? [1] 넥도리아(223.38) 08.12 49 0
2880915 야옹아저씨 글 자체가 적페 넥도리아(223.38) 08.12 37 0
2880914 기호식품이 담배, 술 지원금으로 사는인간들 적페 넥도리아(223.38) 08.12 38 0
2880909 조직스토킹 전파무기 벽투시기 방사성물질테러로부터 안전할권리를 만듭시다 손발이시립디다갤로그로 이동합니다. 08.12 45 0
2880905 권리를 쟁취하자 손발이시립디다갤로그로 이동합니다. 08.12 27 0
2880904 스카이넷좌를 석방하라 조직스토킹으로부터 안전할권리 손발이시립디다갤로그로 이동합니다. 08.12 25 0
2880903 조직스토킹으로부터 안전할권리 스카이넷좌와 함께합니다 손발이시립디다갤로그로 이동합니다. 08.12 28 0
2880902 7 만언 ! 받는법 정리~~~ ! ㅇㅇ(106.101) 08.12 30 0
2880899 파이썬 계 김영한 없냐? [2] 프갤러(121.137) 08.12 136 0
2880897 니들 정치인하고싶냐? [3] 헬마스터갤로그로 이동합니다. 08.12 64 1
2880896 PM님이 사무실에서 일본어 공부하는 저를 발견하셨어요 [2] 아스카영원히사랑해갤로그로 이동합니다. 08.12 77 1
2880891 그냥 어느 레이어에 따라서 필요한 멘탈 모델이 달라진다는게 핵심이지 ㅆㅇㅆ(124.216) 08.12 33 0
2880889 애초에 프로그래밍은 유일한 절대적 최적해가 아닌 ㅆㅇㅆ(124.216) 08.12 41 0
2880888 한국에서는 논리적 사고를 수학적 사고랑 동치화해서 그래 ㅆㅇㅆ(124.216) 08.12 30 0
2880887 수학적 사고력이라는게 뭘까 [1] 프갤러(211.186) 08.12 39 0
2880886 토스는 개발자의 회사보다는 기획자의 회사가 더 맞지 않나 싶은데 난 [2] ㅆㅇㅆ(124.216) 08.12 84 0
2880883 토스 다크패턴은 진짜 UI/UX 설계중에서도 악질중에 악질임 [3] ㅆㅇㅆ(124.216) 08.12 87 0
2880881 토스부러윤이유 [2] 밀우갤로그로 이동합니다. 08.12 61 0
2880880 토스 다크패턴 느낀게 [2] 루도그담당(211.184) 08.12 79 0
2880874 네이버나 이런 애들은 뭔가 그래도 오픈소스로 혁신기술 만들어팔잖아 [4] ㅆㅇㅆ(124.216) 08.12 65 0
2880872 토스의 서사라는게 그건 10년대 초반이나 통했지 지금은 20년대 중반인데 ㅆㅇㅆ(124.216) 08.12 39 0
2880871 내가 느끼는 것은 구직 시장에서 서사를 어떻게 파느냐가 중요한듯 ㅆㅇㅆ(124.216) 08.12 56 0
2880868 왜 애들은 토스를 가고 싶어할까. [4] ㅆㅇㅆ(124.216) 08.12 99 0
2880864 구강. 편광. 표리의 틈새. 까마귀와 성명 공기역학갤로그로 이동합니다. 08.12 28 0
2880862 토뱅은 또갑자기 집중채용이네 [3] 밀우갤로그로 이동합니다. 08.12 116 0
2880856 ㅆㅇㅆ 게이 요즘 cs 위주 글 안 써줘서 ㅁㅈㅎ [2] 루도그담당(211.184) 08.12 66 0
2880854 너는 따땃한 회사의 응딩이에 붙어있지만 나는 고객한테 구걸해야한다 [4] ㅆㅇㅆ(124.216) 08.12 63 0
2880853 몇 년만에 왔는데 멍유 아직도 살아있었네 [1] ㅇㅇ(211.185) 08.12 40 0
2880852 구직단념자가 왜 되는지 알것같다 [3] ㅇㅇ(223.38) 08.12 80 0
2880851 당연히 명세랑 구조는 내가 직접짜지 게이야 [2] ㅆㅇㅆ(124.216) 08.12 46 0
2880850 나는 현존하는 모든 LLM아레나에 있는 모든 모델 다쓰고 있는데 [2] ㅆㅇㅆ(124.216) 08.12 58 0
2880848 걍 질문을 존나 상세하게 해야하는게 귀찮음 [2] 루도그담당(211.184) 08.12 52 0
2880846 운동 다시 시작해야 하는데 좆됐노 프갤러(61.79) 08.12 29 0
2880845 나는 api 쓰면 비용 너무 많이 나와서 에이전트도 꺼둔 사람임 ㅆㅇㅆ(124.216) 08.12 53 0
2880842 GPT 질문을 제대로 하기위해서 질문을 래퍼하고 있는 이게 맞는거냐? [2] ㅆㅇㅆ(124.216) 08.12 46 0
2880840 일단 GPT 5용 시스템 카드 읽고 질문 프롬프트 템플릿 만듬 ㅆㅇㅆ(124.216) 08.12 26 0
2880839 지피티 이거 처음 나왔을땐 충격이였는데 [1] 루도그담당(211.184) 08.12 56 0
2880836 GPT 5 시스템 카드 읽어보고 어떻게 최고수준의 질문할지 생각해봄 [2] ㅆㅇㅆ(124.216) 08.12 64 1
2880833 GPT 5 이거 라우팅 모델이라는게 결국 질문을 잘해야 좋은 모델 쓰게 [2] ㅆㅇㅆ(124.216) 08.12 48 0
2880830 아 공부 며칠간 쉴까 [3] 루도그담당(211.184) 08.12 47 0
2880829 상사가 그냥이란건 없다. 모든 것엔 이유가 있어야 된다길래 [3] 프갤러(211.36) 08.12 54 0
2880828 나는 좀 궁금한게 통진당 해산이 됐으면 당연히 국힘도 해산되야하지 않나. [5] ㅆㅇㅆ(124.216) 08.12 45 0
2880825 집에 가고싶다 루도그담당(211.184) 08.12 22 0
뉴스 '평택호 물빛축제' 9월 13일 개막 디시트렌드 08.13
갤러리 내부 검색
제목+내용게시물 정렬 옵션

오른쪽 컨텐츠 영역

실시간 베스트

1/8

뉴스

디시미디어

디시이슈

1/2