最初に簡単な例を挙げて私の要点を確認します (単なる通常のリスト)。
private void button1_Click(object sender, EventArgs e)
{
List<string> Olle = new List<string>();
Olle.Add("Niklas");
Olle.Add("Peter");
Olle.Add("Tobias");
RemoveFirst(Olle);
MessageBox.Show(Olle.Count().ToString());
}
private void RemoveFirst(List<string> O)
{
O.Remove(O.First());
}
リストは参照によるものであるため、メッセージ ボックスには 2 be が表示されます。
IQueryable または IEnumerable スネア (Linq から Sql) のリストに対して同じ動作を期待していましたが、驚いたことに値変数になりました。すなわち。メソッドを渡して戻ってきた後、メソッドはリストをフィルタリングすることでした! 以下の例によると:
private void foo(int therecord)
{
var FooList = DataContext.MyTable.Where
(l => l.ID == therecord).OrderBy(l => l.FirstName).ToList();
//Lets say the result is 15 records.
MessageBox.Show(FooList.Count().ToString());
//filter method
RemoveDoubletItems(FooList);
//Still 15 records - why? It should pass by refernce right?
//and show 14 - But its not !
MessageBox.Show(FooList.Count().ToString());
}
private void RemoveDoubletItems(List<MyTable> FooList)
{
var remList = new List<MyTable>();
remList.Add(FooList.First());//Just an example
FooList = FooList.Except(remList).ToList();
//Shows 14
MessageBox.Show(FooList.Count().ToString())
}
どうしてこれなの?