ユーフォリア-フロー制御

プログラム実行フローとは、プログラムステートメントが実行される順序を指します。デフォルトでは、ステートメントは次々に実行されます。

しかしながら; 多くの場合、タスクを実行するには、実行の順序をデフォルトの順序から変更する必要があります。

Euphoriaには、ステートメントの実行順序を調整するために使用できるフロー制御ステートメントがいくつかあります。

終了声明

ループの終了はキーワードで行われます exit。これにより、フローは現在のループをすぐに終了し、ループの終了後に最初のステートメントから再開します。

構文

exitステートメントの構文は次のとおりです-

exit [ "Label Name" ] [Number]

ザ・ exit ステートメントは、オプションのラベル名または番号が指定されるまで、最新の最も内側のループを終了します。

の特別な形 exit N です exit 0。これにより、深さに関係なく、すべてのレベルのループが残ります。制御は、最も外側のループブロックの後で続行されます。同様に、exit-1は2番目に外側のループを終了します。

#!/home/euphoria-4.0b2/bin/eui

integer b

for a = 1 to 16 do
   printf(1, "value of a %d\n", a)
   
   if a = 10 then
      b = a
      exit
   end if
end for

printf(1, "value of b %d\n", b)

これにより、次の結果が生成されます-

value of a 1
value of a 2
value of a 3
value of a 4
value of a 5
value of a 6
value of a 7
value of a 8
value of a 9
value of a 10
value of b 10

ブレーク声明

ザ・ break ステートメントは、 exit ステートメントですが、あらゆる種類のループステートメントではなく、ifステートメントまたはswitchステートメントに適用されます。

構文

breakステートメントの構文は次のとおりです-

break [ "Label Name" ] [Number]

ザ・ break ステートメントは、オプションのラベル名または番号が指定されるまで、最新の最も内側のifまたはswitchブロックを終了します。

の特別な形 break N です break 0。これにより、深さに関係なく、最も外側のifまたはswitchブロックが残ります。制御は最も外側のブロックの後で続行されます。同様に、break -1は、2番目に外側のifまたはswitchブロックをブレークします。

#!/home/euphoria-4.0b2/bin/eui

integer a, b
sequence s = {'E','u', 'p'}

if s[1] = 'E' then
   a = 3
   
   if s[2] = 'u' then
      b = 1
      if s[3] = 'p' then
         break 0 -- leave topmost if block
      end if
      a = 2
   else
      b = 4
   end if
else
   a = 0
   b = 0
end if

printf(1, "value of a %d\n", a)
printf(1, "value of b %d\n", b)

これにより、次の結果が生成されます-

value of a 3
value of b 1

引き続き声明

ザ・ continue ステートメントは、次の反復に進み、残りの反復をスキップすることによって、適用されるループの実行を続行します。

次の反復に進むということは、条件変数インデックスをテストし、それがまだ範囲内にあるかどうかを確認することを意味します。

構文

continueステートメントの構文は次のとおりです-

continue [ "Label Name" ] [Number]

ザ・ continue ステートメントは、オプションのラベル名または番号が指定されるまで、最新の最も内側のループを繰り返します。

の特別な形 continue N です continue 0。これにより、深さに関係なく、最も外側のループが繰り返されます。同様に、continue -1は、2番目に外側のループから始まります。

#!/home/euphoria-4.0b2/bin/eui

for a = 3 to 6 do
   printf(1, "value of a %d\n", a)

   if a = 4 then
      puts(1,"(2)\n")
      continue
   end if

   printf(1, "value of a %d\n", a*a)
end for
This would produce following result:

value of a 3
value of a 9
value of a 4
(2)
value of a 5
value of a 25
value of a 6
value of a 36

再試行の声明

ザ・ retry ステートメントは、次の反復に進み、残りの反復をスキップすることによって、適用されるループの実行を続行します。

構文

再試行ステートメントの構文は次のとおりです-

retry [ "Label Name" ] [Number]

ザ・ retryステートメントは、適用されるループの現在の反復の実行を再試行します。このステートメントは、指定されたループの最初のステートメントに分岐し、何もテストせず、forループインデックスをインクリメントしません。

の特別な形 retry N です retry 0。これにより、深さに関係なく、最も外側のループの実行が再試行されます。同様に、retry -1は、2番目に外側のループを再試行します。

通常、retryステートメントを含むサブブロックには、exit、continue、breakなどの別のフロー制御キーワードも含まれます。そうしないと、反復が際限なく実行されます。

#!/home/euphoria-4.0b2/bin/eui

integer errors = 0
integer files_to_open = 10

for i = 1 to length(files_to_open) do
   fh = open(files_to_open[i], "rb")
   
   if fh = -1 then
      if errors > 5 then
         exit
      else
         errors += 1
         retry
      end if
   end if
   file_handles[i] = fh
end for

再試行してもiの値は変更されず、同じファイルを再度開こうとするため、exitステートメントが提供するループから抜け出す方法が必要です。

gotoステートメント

ザ・ goto ステートメントは、ラベル付けされた場所でコードの実行を再開するようにコンピューターに指示します。

実行を再開する場所は、ステートメントのターゲットと呼ばれます。現在のルーチン、またはルーチン外の場合は現在のファイル内にあるように制限されています。

構文

gotoステートメントの構文は次のとおりです-

goto "Label Name"

gotoステートメントのターゲットは、アクセス可能な任意のものにすることができます label ステートメント-

label "Label Name"

ラベル名は二重引用符で囲まれた定数文字列である必要があります。Euphoria識別子で無効な文字は、通常の文字列であるため、ラベル名に表示される場合があります。

#!/home/euphoria-4.0b2/bin/eui

integer a = 0

label "FIRST"
printf(1, "value of a %d\n", a)
a += 10

if a < 50 then
   goto "FIRST"
end if 
printf(1, "Final value of a %d\n", a)

これにより、次の結果が生成されます-

value of a 0
value of a 10
value of a 20
value of a 30
value of a 40
Final value of a 50