foreachとはループをさせる構文ですが配列やListなどを全件ループさせる時に使用します。
1 2 3 4 |
var list = new List<int>(); list.Add(10); list.Add(11); list.Add(9); |
foreach文でこんな感じで書けます。
1 2 3 4 |
foreach (var val in list) { Console.WriteLine("A:" + val.ToString()); } |
【結果】
A:10
A:11
A:9
【書き方】
foreach (リスト等の中身の型 自由な変数名 in ループしたいリストや配列)
{
リスト等の中身が順番に「自由な変数名」の中に入ってきます。
}
foreachを使わなくてもfor文で同じことはできます。
1 2 3 4 |
for (int i = 0; i < list.Count; i++) { Console.WriteLine("B:" + list[i].ToString()); } |
【結果】
B:10
B:11
B:9
ただ,全件を順番通りにループするだけなら,私はforeachのほうがおすすめです。
forの場合はインデックスを使うのでバグの入り込む可能性が高まります。
配列の0番目指定を1から指定してしまったり,list.Countの値で配列を参照してしまうなどインデックス境界外の例外が出る不具合が入り込みやすくなります。
途中からループしたい!とか逆回しにループしたい!などという場合はforを使うのがいいと思います。
あと,パフォーマンスに関してはforのほうが速い可能性があります。
大量件数を扱うときは検証してみてください。
breakとcontinueの使い方
FOREACHでもFORでも同じですが,ループ中にBREAKやCONTINUEが使用できます。ループを完全に抜けるのがbreakループの途中で次のループに飛ぶのがcontinueです。
次のような場合は10より大きな値が現れた時点でループを完全に抜けるので結果は「C:10」のみとなります。
1 2 3 4 5 6 7 8 9 |
foreach (var val in list) { if (val > 10) { break; } Console.WriteLine("C:" + val.ToString()); } |
これをcontinueを使った場合だと次のループに進むため「10」と「9」が処理されます。
1 2 3 4 5 6 7 8 9 |
foreach (var val in list) { if (val > 10) { continue; } Console.WriteLine("D:" + val.ToString()); } |
【結果】
D:10
D:9
簡単ですが,foreachに関する解説は以上となります。
最後までお読みいただきありがとうございました。
■4700人以上が受講している動画コースはこちらからご確認ください
#S1_01_はじめに
#S1_02_インデックスとは
#S1_03_インデックスの有無実演
#S1_04_SQLServerのインストール
#S2_01_データベースとテーブルの作成
#S2_02_データの作成
#S2_03_全件検索
#S2_04_キャッシュとは
#S2_05_検索条件ありで検索
#S2_06_テーブルスキャンとは
#S2_07_インデックスの種類
#S2_08_非クラスター化インデックスの作成
#S2_09_非クラスター化インデックスの内部構造
#S2_10_インデックスのない列の検索とインデックスの有効化無効化
#S2_11_クラスター化インデックスの作成
#S2_12_クラスター化インデックスの内部構造
#S2_13_クラスター化インデックスの検索
#S2_14_インデックスの検索補足
#S2_15_付加列インデックス
#S2_16_プライマリキーとユニークキー
#S2_17_インデックス作成手順
#S2_18_インデックスの注意点
おわりに
■4700人以上が受講している動画コースはこちらからご確認ください