1

重複の可能性:
.Union()はアイテムの順序を変更しますか?

この質問によると(シナリオ/例なし;あなたはそれを削除する必要があります、私はできません)これは私の問題です:

コレクション間Unionではなく、を実行すると、アイテムの順序が「変更される」可能性があることに気付きました。IntersectAttachment[]

これは私のコードです:

    GalleryDataClassesDataContext db = new GalleryDataClassesDataContext();
    List<Attachment> Allegati = db.ExecuteQuery<Attachment>("EXEC SelectAttachmentsByKey @Key={0}, @IDCliente={1}", new object[] { "", "47" }).ToList();
    List<Attachment> AllegatiPerCategorie = new List<Attachment>();

    AllegatiPerCategorie = AllegatiPerCategorie.Union(db.AttachmentAttachmentCategories.Where(aac => aac.IDAttachmentCategory == 72).OrderBy(p => p.Ordine == null ? 1 : 0).ThenBy(p => p.Ordine).Select(aac => aac.Attachment)).ToList();
    Allegati = Allegati.Intersect(AllegatiPerCategorie).ToList();

    count = 0;
    foreach (Attachment a in AllegatiPerCategorie)
    {
        Response.Write(count.ToString() + " - " + a.IDAttachment + "<br />");
        count++;
    }

    Response.Write("<br />### FILTERED ###<br /><br />");

    count = 0;
    foreach (Attachment a in Allegati)
    {
        Response.Write(count.ToString() + " - " + a.IDAttachment + "<br />");
        count++;
    }

そして、出力は次のとおりです。

0 - 6769
1 - 6792
2 - 6771
3 - 6699
4 - 6632
5 - 6774
6 - 6595
7 - 6602
8 - 6641
9 - 6643
10 - 6764
11 - 6634
12 - 6642
13 - 6660
14 - 6640
15 - 6665
16 - 6673
17 - 6767
18 - 6772
19 - 6766
20 - 6763
21 - 6768
22 - 6644
23 - 6635
24 - 6633
25 - 6793
26 - 6677
27 - 6608
28 - 6610
29 - 6558
30 - 6563
31 - 6631
32 - 6604
33 - 6606
34 - 6607
35 - 6596
36 - 6597
37 - 6598
38 - 6599
39 - 6600
40 - 6471
41 - 6470
42 - 6469
43 - 6601
44 - 6603
45 - 6663
46 - 6664
47 - 6645
48 - 6637
49 - 6638
50 - 6609
51 - 6611
52 - 6612
53 - 6613
54 - 6614
55 - 6615
56 - 6616
57 - 6617
58 - 6618
59 - 6619
60 - 6620
61 - 6622
62 - 6567
63 - 6568
64 - 6569
65 - 6570
66 - 6571
67 - 6572
68 - 6573
69 - 6575
70 - 6576
71 - 6577
72 - 6579
73 - 6580
74 - 6581
75 - 6582
76 - 6583
77 - 6584
78 - 6585
79 - 6586
80 - 6587
81 - 6588
82 - 6589
83 - 6590
84 - 6591
85 - 6592
86 - 6593
87 - 6594
88 - 6765

### FILTERED ###

0 - 6769
1 - 6792
2 - 6771
3 - 6699
4 - 6774
5 - 6595
6 - 6602
7 - 6634
8 - 6642
9 - 6640
10 - 6660
11 - 6665
12 - 6673
13 - 6772
14 - 6766
15 - 6768
16 - 6644
17 - 6635
18 - 6633
19 - 6793
20 - 6677

たとえば、リスト内の値66606640AllegatiPerCategorieの順序に注意してください:6640の前の6660(位置1314)。

ここで、同じ値の順序で見てAllegatiください:6640は6660の前です(位置910)。

なぜこの振る舞い?どうすれば修正できますか?ありがとうございました

4

2 に答える 2

6

MSDNの状態:

このメソッドによって返されるオブジェクトが列挙されると、Unionは1番目と2番目をこの順序で列挙し、まだ生成されていない各要素を生成します。

動作を示す短い例を次に示します。

new int[] {1}.Union(new int[] {1, 2, 3}) // returns: 1,2,3
new int[] {2}.Union(new int[] {1, 2, 3}) // returns: 2,1,3
new int[] {3}.Union(new int[] {1, 2, 3}) // returns: 3,1,2

new int[] {1,3,5}.Union(new int[] {2, 4}) // returns: 1,3,5,2,4
于 2012-09-21T10:34:49.527 に答える
0

ユニオン

デフォルトの等式比較器を使用して、2つのシーケンスの集合和を生成します。

定義によるセットには重複が含まれておらず、固有の並べ替えもありません。

また:

このメソッドは、戻りセットから重複を除外します。Concat<TSource>これは、重複を含む入力シーケンスのすべての要素を返すメソッドとは異なる動作です。

と:

このメソッドによって返されるオブジェクトが列挙されると、Unionは1番目と2番目をこの順序で列挙し、まだ生成されていない各要素を生成します。

于 2012-09-21T10:28:12.587 に答える