| « Поставить закладку » « Сделать стартовой » | |||
|
|||
|
Оптимизация построения дерева из базы данных в .NET
DataView. В общем, не плохой задел на будущее, код работал и я, до поры до времени, не возвращался к нему.Загрузить примеры к статье - 24.9 кб ВведениеНо недавно я начал использовать ANTS Profiler и обнаружил, что построение дерева было довольно медленным. Я проверил мой старый код снова и нашел способ значительно его ускорить... Эта статья объясняет, как рекуррентная основа Замечание: метод, который здесь представлен, не основывается на восходящей сортировке Что содержится в ZIP?ZIP-файл содержит код библиотеки для построения дерева и код тестового приложения. Также туда включено дерево С точки зрения дереваВ моем первоначальном коде я рассматривал проблему с точки зрения
дерева. У дерева всегда есть корневой узел (root node), так что я начал
именно с него и исследовал его узлы-потомки в
Класс public TreeNode LoadTree(DataView dataTree)
Метод Также, если вы попытаетесь загрузить сильно разветвленное дерево, то вы можете столкнуться с проблемой переполнения стека(stack overflow). ** Всему виной рекуррентность. Когда вызывается новая функция, программа обязана сохранить все необходимые данные (значение различных переменных - точнее их адреса), все это сохраняется в стеке (области памяти, которая выделяется под нужды программы), поэтому когда вы многократно вызываете такие рекуррентные функции, объем данных которые должна хранить программа растет и в определенный момент выделенной для хранения этих данных памяти не хватает(точнее чаще всего новые данные записываются поверх старых, а значит, старые данные теряются). И происходит сбой - обычно программа не может выйти из функции или восстановить значение переменных (т.к. эта информация была утеряна). С точки зрения DataView
Весь фокус в том, чтобы воплотить идею о том, что каждый объект
должен быть полноценным. Мне ничего не известно о родительском узле, но
я знаю ID, который он будет иметь. Так что я могу создать новый узел
зная только родительский ID и не имея самого родительского узла, и
сохранить его в public TreeNode LoadTree(DataView dataTree)
Метод РезультатыНа моем 1.8GHz процессоре, тест-приложению потребовалось чуть более, чем 2 секунды для построения дерева медленным способом. Используя "быстрый" метод, это заняло только около 0.004 секунды для построения того же дерева. Что составляет прирост скорости примерно в 500 раз! Замечание: конечно, тестовое дерево очень простое дерево. В реальных приложениях каждый узел дерева может содержать "полезную нагрузку" не только в виде текста. Это возможно немного замедлит процесс построения, но все равно это будет гораздо быстрее, чем обычное "медленное" дерево. Я наблюдал увеличение в скорости некоторых моих приложений аж в 400 раз. ЗаключениеПриложение может показывать плохие результаты когда:
Решение, предложенное в этой статье, избегает этого путем сведения к минимуму обращений к медленному методу (чтение записей из |DataView|). Общеизвестно, что из-за тесных связей между объектами родителя и потомка единственным выходом является умное использование той малой информации, которая известна об объектах. Автор: NielsHoldijk (англ. оригинал). Перевод выполнен cronOS для Realcoding.NET Рубрика: Windows Forms
HTML 5: пять вещей вызывающих особый интер....
HTML 5 — это грядущее обновление гипертекстового языка разметки, основного способа создания контента для размещения его во всемирной паутине. Разработка HTML остановилась в 1999 году, на версии HTML 4.01 и с тех пор web-содержимое изменилось так, что текущие спецификации HTML перестали соответствовать сегодняшним требованиям. HTML 5 нацелен на то, чтобы увеличить функциональную совместимость HTML и соответствовать растущим требованиям разнообразного и смешанного web-контента. HTML 5 так же нацелен на устранение недостатков четвертой версии. В этой статье мы взглянем на 5 новых интересных вещей в HTML 5.
Подробнее... |
Рубрика: Html
| Добавлено: 22.12.2008
asp.net: ListView с разных сторон.
Элемент управления ListView был представлен в .Net Framework 3.5 как замена устаревшему GridView. Новый элемент имеет более расширенный функционал, чем его предшественник, но в тоже время лишен некоторых внутренних механизмов, что впрочем целиком следствие из расширенной универсальности ListView. Среди отличий ListView и GridView можно назвать и гибкую настройку разметки, что позволяет выводить данные не только в табличном виде, но и вообще в любом каком пожелает программист. Благодаря шаблонам ItemTemplate, EditItemTemplate, InsertItemTeplate можно настроить внешний вид при любом из состояний ListView: редактировании или выборе элемента.
Подробнее... |
Рубрика: .NET компоненты
| Добавлено: 22.12.2008
Создание кросс-таб отчета в Stimulsoft Rep....
Компания Стимулсофт предоставляет для разработчиков мощный набор инструментов для создания отчетов для Microsoft Visual Studio .Net 2005 и 2008; эти инструменты доступны как для Windows Forms, так и для Web Forms. Это генератор отчетов Stimulsoft Reports.Net. Генератор отчетов Stimulsoft Reports.Net имеет ряд особенностей: простая работа с дизайнером отчетов, полная поддержка экспорта в PDF, Word, Excel и многие другие форматы. Crystal Report и Microsoft Reporting Service – очень хорошие программные продукты для повседневной работы, но, если Вам необходимо создать отчеты с поддержкой кросс-табов, drill down, Ajax, штрих-кодов и возможностью подключения одновременно более одного источника данных, то Stimulsoft Reports.Net поможет Вам сэкономить массу времени. Также, данный генератор отчетов позволяет пользователям создавать свои собственные отчеты любой сложности. И все эти особенности делают Stimulsoft Reports.Net хорошим выбором в сфере программных продуктов для Business Intelligence.
Подробнее... |
Рубрика: .NET компоненты
| Добавлено: 22.12.2008
Остальные статьи: |
Цитата дня (все,добавить):
|
Realcoding.NET
© 2003-2008 |
Контакты |
Реклама на сайте
|