ユーフォリア-フロー制御
プログラム実行フローとは、プログラムステートメントが実行される順序を指します。デフォルトでは、ステートメントは次々に実行されます。
しかしながら; 多くの場合、タスクを実行するには、実行の順序をデフォルトの順序から変更する必要があります。
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