您目前已離線,請等候您的網際網路重新連線

FIX: System.ArgumentOutOfRangeException 發生間歇地使用 ADO.NET

重要:本文是以 Microsoft 機器翻譯軟體翻譯而成,而非使用人工翻譯而成。Microsoft 同時提供使用者人工翻譯及機器翻譯兩個版本的文章,讓使用者可以依其使用語言使用知識庫中的所有文章。但是,機器翻譯的文章可能不盡完美。這些文章中也可能出現拼字、語意或文法上的錯誤,就像外國人在使用本國語言時可能發生的錯誤。Microsoft 不為內容的翻譯錯誤或客戶對該內容的使用所產生的任何錯誤或損害負責。Microsoft也同時將不斷地就機器翻譯軟體進行更新。

按一下這裡查看此文章的英文版本:836874
依現狀不再更新的知識庫內容免責聲明
本文旨在說明 Microsoft 不再提供支援的產品。因此,本文係依「現狀」提供,不會再更新。
徵狀
ADO.NET 應用程式中可能會間歇地收到下列的例外狀況錯誤訊息:
System.ArgumentOutOfRangeException: 索引超出範圍。 必須是非負數且小於集合的大小。 參數名稱: 索引
發生的原因
您收到這個錯誤訊息如果您建立或終結相關的資料集物件 (例如 DataView 物件) 在 DataSet 物件的事件處理常式或 DataSet 物件相關聯的物件。比方說這個錯誤已在應用程式,並在其中包含已建立子 DataView 物件為方格的 ListChanged 事件處理常式中的方格控制項中重製。這可讓位置,它應保持靜態基礎 資料集 物件來變更作業期間的內部狀態。
解決方案
支援的 Hotfix 現在可以從 Microsoft,但它只用來修正本文所述的問題。僅適用於發生此特定問題的系統。此 Hotfix 可能會接受其他測試。因此,如果您不會嚴重影響這個問題,我們建議您等候下一個包含此 Hotfix 的 Service Pack。

如果要立即解決這個問題,洽詢 Microsoft 技術支援部以取得該 Hotfix。如需 Microsoft 產品支援服務電話號碼及支援成本的相關資訊的完整清單,請造訪下列 Microsoft 網站]:附註 在特殊情況下通常會因支援電話所產生的費用可能就不收取如果 Microsoft 支援人員認為某特定更新程式可以解決您的問題。平常的支援成本將會套用到其他支援問題是所做不限定特定有問題的更新程式。此 Hotfix 的英文版具有檔案屬性 (或更新) 中如下表所列。這些檔案的日期和時間為 Coordinated Universal Time (UTC)。當您檢視檔案資訊時,會將它轉換為當地時間。若要到 UTC 與當地時間差異使用 [中日期] 和 [時間] 工具,在 [控制台] 中的 [時區] 索引標籤]。
   Date         Time   Version            Size    File name   --------------------------------------------------------------   02-Mar-2004  18:39  1.1.4322.1007   1,294,336  System.data.dll                                             
其他可行方案
請勿建立或摧毀 DataSet 物件的事件處理常式內的資料集相關的物件 (例如 DataView 物件)。
狀況說明
Microsoft 已確認這是本文 < 適用於 > 一節中所列的 Microsoft 產品中的問題。
這個例外狀況呼叫堆疊取決於您的應用程式功能和錯誤的確切原因。以下是 ListChanged 事件處理常式的控制項中建立子 DataView 物件時所發生的兩個範例:

範例呼叫堆疊 1

System.Collections.ArrayList.get_Item(Int32 index)Sstem.Data.DataTable.RecordStateChanged(Int32 record1, DataViewRowState oldState1, DataViewRowState newState1, Int32 record2, DataViewRowState oldState2, DataViewRowState newState2)System.Data.DataTable.SetNewRecord(DataRow row, Int32 proposedRecord, DataRowAction action, Boolean isInMerge)System.Data.DataRow.EndEdit()System.Data.DataRow.set_Item(DataColumn column, Object value)System.Data.DataRow.set_Item(String columnName, Object value)

範例呼叫堆疊 2

System.Collections.ArrayList.get_Item(Int32 index)System.Data.DataTable.ResetIndexes()System.Data.Merger.MergeTable(DataTable src, DataTable dst)System.Data.Merger.MergeTableData(DataTable src)System.Data.Merger.MergeDataSet(DataSet source)System.Data.DataSet.Merge(DataSet dataSet, Boolean preserveChanges, MissingSchemaAction missingSchemaAction)

附註這些是僅範例,不是唯一的呼叫堆疊,可能會發生這個錯誤。
参考
如需詳細資訊按一下 [下面的文件編號,檢視 「 Microsoft 知識庫 」 中的發行項]:
824684用來描述 Microsoft 軟體更新標準術語的說明
取得更多資訊有關所發生的舊版 ADO.NET 類似的例外狀況按一下 [下面的文件編號,檢視 「 Microsoft 知識庫 」 中的發行項]:
332215FIX:"System.ArgumentOutOfRangeException: 索引超出範圍 」 與 SqlClient.SqlConnection.Open() 就會發生錯誤
附註微軟知識庫文件 332215 此修正程式已經包含在.NET Framework 1.1 版中。
indexoutofrangeexception sqlclient

警告:本文為自動翻譯

內容

文章識別碼:836874 - 最後檢閱時間:06/01/2006 09:24:01 - 修訂: 2.1

Microsoft ADO.NET 1.1

  • kbmt kbhotfixserver kbqfe KB836874 KbMtzh
意見反應