История счётных устройств насчитывает много веков. Приведем некоторые наиболее значимые события этой истории.
1642 г. Французский ученый Блез Паскаль приступил к созданию арифметической машины — механического устройства с шестернями, колёсами, зубчатыми рейками и т.п. Она умела "запоминать" числа и выполнять элементарные арифметические операции.
В 1694 г. немецкий математик и философ Готфрид Вильгельм Лейбниц, используя чертежи и рисунки Паскаля, улучшил машину Паскаля, добавив возможность перемножать числа. Вместо обычных шестеренок Лейбниц использовал пошаговый барабан.
1834 г. Английский ученый Чарльз Бэббидж составил проект "аналитической" машины, в которую входили: устройства ввода и вывода информации, запоминающее устройство для хранения чисел, устройство, способное выполнять арифметические операции, и устройство, управляющее последовательностью действий машины. Команды вводились с помощью перфокарт. Проект не был реализован.
1936 г. английский математик Алан Тьюринг и независимо от него Э. Пост выдвинули и разработали концепцию абстрактной вычислительной машины. Они доказали принципиальную возможность решения автоматами любой проблемы при условии возможности её алгоритмизации.
1938 г. Американский математик и инженер Клод Шеннон показал возможность применения аппарата математической логики для синтеза и анализа релейно-контактных переключательных схем.
1944 г. Под руководством американского математика Говарда Айкена создана автоматическая вычислительная машина "Марк—1" с программным управлением. Она была построена на электромеханических реле, а программа обработки данных вводилась с перфоленты.
1945 г. Джон фон Нейман в отчёте "Предварительный доклад о машине ЭНИАК" сформулировал основные принципы работы и компоненты современных компьютеров.
1948 г. Норберт Винер (Norbert Wiener) опубликовал книгу "Кибернетика", оказавшую влияние на все последующие исследования в области искусственного интеллекта.
1951 г. В Киеве построен первый в континентальной Европе компьютер МЭСМ (малая электронная счетная машина), имеющий 600 электронных ламп. Создатель Сергей Аалександрович Лебедев.
В 1974 г фирмой Intel (INTegrsted Electronics) создан микропроцессор i8080, который использовался в первом в мире персональном компьютере (ПК) «Альтаир».
В 1977 г. была основана фирма Apple Computer. Был запущен в серийное производство ПК Apple-II. В том же году началась продажа компьютеров фирм Commodore, Tandy и др.
В 1981 г. появился ПК фирмы IBM (International Business Machines), названный IBM PC (Personal Computer), который стал фактически стандартом этого класса машин.
Как уже было сказано выше, в основу построения подавляющего большинства современных компьютеров положены следующие общие принципы, сформулированные в 1945 г. американским ученым Джоном фон Нейманом.
1. Принцип программного управления. Из него следует, что программа состоит из набора команд, которые выполняются процессором автоматически друг за другом в определенной последовательности.
Выборка программы из памяти осуществляется с помощью счетчика команд. Этот регистр процессора последовательно увеличивает хранимый в нем адрес очередной команды на длину команды. А так как команды программы расположены в памяти друг за другом, то тем самым организуется выборка цепочки команд из последовательно расположенных ячеек памяти.
Если же нужно после выполнения команды перейти не к следующей, а к какой-то другой, используются команды условного или безусловного переходов, которые заносят в счетчик команд номер ячейки памяти, содержащей следующую команду. Выборка команд из памяти прекращается после достижения и выполнения команды “ стоп ”.
Таким образом, процессор исполняет программу автоматически, без вмешательства человека.
2. Принцип однородности памяти. Программы и данные хранятся в одной и той же памяти. Поэтому компьютер не различает, что хранится в данной ячейке памяти — число, текст или команда. Над командами можно выполнять такие же действия, как и над данными. Это открывает целый ряд возможностей. Например, программа в процессе своего выполнения также может подвергаться переработке, что позволяет задавать в самой программе правила получения некоторых ее частей (так в программе организуется выполнение циклов и подпрограмм). Более того, команды одной программы могут быть получены как результаты исполнения другой программы. На этом принципе основаны методы трансляции — перевода текста программы с языка программирования высокого уровня на язык конкретной машины.
3. Принцип адресности. Структурно основная память состоит из перенумерованных ячеек; процессору в произвольный момент времени доступна любая ячейка. Отсюда следует возможность давать имена областям памяти, так, чтобы к запомненным в них значениям можно было впоследствии обращаться или менять их в процессе выполнения программ с использованием присвоенных имен.