| « Поставить закладку » « Сделать стартовой » | |||
|
|||
|
Статьи:: Оптимизация кода :: Оптимизация для pentium процессора :: Соображения о других микропроцессорах
Соображения о других микропроцессорах
Большинство оптимизаций, описанных в этом документе может иметь очень маленькую, а может и вообще отрицательную, эффективность на других, не-Intel микропроцессорах, но о некоторых проблемах лучше быть осведомленным. Использование полного регистра, после записи в его часть вызовет серьезные задержки на 80486 и небольшие задержки на PentiumPro. Например: MOV AL,[EBX] / MOV ECX,EAX На PentiumPro может быть анулированно обнулением полного регистра перед записью: XOR EAX,EAX / MOV AL,[EBX] / MOV ECX,EAX или используя MOVZX EAX,BYTE PTR [EBX] При планировании кода с плавающей точкой на Pentium, обычно используется много инструкций FXCH. Это замедлит исполнение кода на ранних микропроцессорах, но не на PentiuPro, поздних Intel и не-Intel процессорах. Как упомянуто во введении, Intel заявил о создании новых версий процессора Pentium с набором MMX инструкций, предназначеных для векторных операций. Эти инструкции будут очень полезны для параллельных расчетов большого числа целочисленных операций. Чип PentiumPro во многих отношениях быстрее, чем Pentium, но с другой стороны кое в чем медленнее. Знание сильных и слабых стороны PentiumPro позволит вам делать ваш код максимально быстрым для обоих процессоров. Наиболее важное преимущество PentiumPro то, что он делает большую часть оптимизаций для вас: переупорядочивание инструкций и разложение сложных инструкций на более простые. Но отлично оптимизированный код - различается у обоих процессоров. Оба процессора имеют одинаковое число модулей исполнения, так что производительность их примерно равна. PentiumPro имеет раздельные модули для чтения и записи в память, таким образом он может делать три операции чтения одновременно, но не может делать два чтения и запись, или две операции записи и одну чтения одновременно, тогда как Pentium может. PentiumPro лучше, чем Pentium в следующих случаях: - порядок выполнения - один промах кеша не задерживает последующие инструкции - разбиение сложных инструкций на меньшие микро-операции - автоматическое анулирование регистра, для анулирования не необходимых задержек - лучший механизм предсказания переходов, чем на Pentium без MMX - многие неспариваемые или слабо оптимизированные на Pentium инструкции выполняются лучше на PentiumPro, т.н. целочисленное умножение, MOVZX, CQD, битовое сканирование, битовый тест, сдвиги CL и загрузка чисел с плавающей точкой - числа с плавающей точкой и целые числа операции могут обрабатываться одновременно - чтение и запись в память не занимает ALU - инструкции косвенно обращающиеся к памяти не вызывают остановку AGI - новые инструкции перемещения данных могут использоваться вместо инструкций условных переходов - новая инструкция FCOMI устраняет потребность в медленной FNSTSW AX - более высокая частота PentiumPro уступает Pentium в следующем: - непредсказанные переходы очень медленные (10-15 тактов!) - низкая производительность 16 битного кода и сегментной модели - медленно декодируются префиксы (кроме 0FH) - большие потери при смешивании 8, 16 и 32 битных регистров - FADD, FSUB, FMUL, FCHS медленнее - не возможны два чтения или записи в память - некоторые комбинации инструкций не могут исполняться параллельно, например push + push, push + условный переход Таким образом, PentiumPro может быть действительно медленнее Pentium, хорошо оптимизированный код, с большим количеством непредсказанных переходов и большим количеством операций с плавающей точкой может действительно работать с весьма разной скоростью. Большинство недостатков каждого процессора могут быть обойдены тщательным оптимизированием и использованием режима адресации FLAT. Но проблема с непредсказанными условными переходами не может анулироваться, за исключением случаев, где вы сможете заменить их инструкциями условного перемещения. Использование преимуществ MMX и PentiumPro процессоров создаст значительные трудности, если вы захотите, что бы ваш код был совместим с более ранними микропроцессорами. Решением может быть написание нескольких версий кода, оптимизированного под каждый из процессоров. Ваша программа должна автоматически определять тип используемого процессора и выбирать соответствующую версию кода. Такой сложный способ целесообразно применять только в критических частях вашей программы. Рубрика: Оптимизация для pentium процессора
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 |
Контакты |
Реклама на сайте
|