Скопировать пары n k/v из Hashtable
У меня есть хеш-таблица с n количеством записей. Мне нужно скопировать записи между х и у и перебрать их.
Как бы я это сделал?
Пример:
HT1.Count = 500;
HT2 = HT1 [0] - HT1 [100];
--редактировать--
Просто, чтобы вы знали, причина этого в том, что я генерирую PDF-файлы из файлов.MSG. Проблема возникает для конечного пользователя, что, когда они получают PDF 12 ГБ, это вызывает проблемы:P
Мне нужно разбить PDF-файлы на 250 сообщений, а затем начать новый PDF. Таким образом, порядок не имеет значения, равно как и каждый раз возвращать одни и те же записи, поскольку это будет сделано только один раз.
3 ответа
Моя ставка будет делать пользовательские функции, такие как это:
public IEnumerable<object> GetRange(Hashtable ht, int min, int max) {
int i = 0;
foreach (var key in ht.Keys) {
i++;
if (i > max) {
yield break;
}
if (i >= min) {
yield return ht[key];
} else continue;
}
}
Однако следует учитывать, что порядок ключей не гарантируется, поэтому это может иметь неупорядоченную последовательность объектов.
Как уже говорили другие, вы не можете перебирать хеш-таблицу так, как вам кажется. Если, с другой стороны, вы хотите получить результат, когда ключи находятся в этом диапазоне, вы можете сделать что-то вроде этого:
public IDictionary<int, T> GetRange<T>(
IDictionary<int, T> source, int min, int max)
{
// add error checking for min,max, null, etc...
int capacity = Math.Max(0, max - min);
Dictionary<int, T> target = new Dictionary<int, T>(capacity);
for (int key = min; key < max; key++)
{
if (source.ContainsKey(key))
{
target.Add(key, source[key]);
}
}
return target;
}
Обратите внимание, что я использую общую версию (Dictionary
) вместо старого Hashtable
, но идея была бы той же.
Я предлагаю вам обратиться к ссылке на хэш-таблицы. Хеш-таблицы обычно неупорядочены, поэтому ваш вопрос не имеет смысла.