我正在为 ArcGIS 开发一个将与 ArcView 集成的自定义工具。该工具使用 C# 开发,基本上连接到 SQL 数据库,将数据提取到本地数据结构,执行大量统计分析,然后将结果显示为新层。
崩溃发生在此代码执行期间。
LinkedList<SegmentDbRecord> segmentData = new LinkedList<SegmentDbRecord>();
while( dataReader.Read() )
{
SegmentDbRecord record = new SegmentDbRecord();
record.first_stop_id = dataReader.GetInt32(0);
record.first_stopway = dataReader.GetString(1);
record.first_stopway_X = dataReader.GetString(2);
record.second_stop_id = dataReader.GetInt32(3);
record.second_stopway = dataReader.GetString(4);
record.second_stopway_X = dataReader.GetString(5);
record.segment_start = Tools.timeToFloat((DateTime)dataReader.GetValue(6));
record.segment_finish = Tools.timeToFloat((DateTime)dataReader.GetValue(7));
record.stop1_long = dataReader.GetFloat(8);
record.stop1_lat = dataReader.GetFloat(9);
record.stop2_long = dataReader.GetFloat(10);
record.stop2_lat = dataReader.GetFloat(11);
record.max_speed = dataReader.GetInt32(12);
record.avg_speed = dataReader.GetInt32(13);
record.route_hnd = dataReader.GetInt32(14);
record.seq_1 = dataReader.GetInt32(15);
record.seq_2 = dataReader.GetInt32(16);
record.route_name = dataReader.GetString(17);
segmentData.AddFirst(record);
}
在这个阶段,我只是将查询的结果保存在一个链表中。我很确定崩溃发生在内存分配期间,但我知道仍然有大量内存剩余,并且查询没有返回如此大的数据集。运行一个分配新“记录”的简单循环也会很快崩溃。你们中是否有人知道 ArcGIS 运行时中的内置保护可能会阻止我分配超过一定数量的内存?
谢谢 !