|
0 / 0 / 0
Регистрация: 22.02.2013
Сообщений: 13
|
|
Компиляторы по АХО04.04.2013, 10:49. Показов 3329. Ответов 30
Метки нет (Все метки)
Доброго времени суток, коллеги.
Помнится в далеком 2006 году, я писал кросс-компилятор для какой-то микроЭВМ, на тот момент я реализовал только класс синтаксического анализатора. Программа считывала текстовый файл в котором находились команды и операнды, команды были взяты из документации. Собственно, программа считывала файл, проверяла его на ошибки и на этом все. Мне всегда была интересна тема разработки компиляторов и низкоуровнего программирования, но времени на подробное изучение теории написания компиляторов не было, ибо работа. Сейчас я заново читаю эту замечательную книгу и у меня возник вопрос: Как происходит компиляция кода в машинный? Я так понимаю, что между моим компилятором и машинным кодом должен стоять ассемблер? Ну например я написал ЯП, компилятор перевел этот код в код ассемблера, что дальше?
0
|
|
| 04.04.2013, 10:49 | |
|
Ответы с готовыми решениями:
30
Алгоритм Ахо-Корасик Алгоритм Ахо-Корасика Реализовать алгоритм Ахо-Корасика |
|
|
|||
| 04.04.2013, 10:53 | |||
|
Или, как уже писал выше, сразу генерить машинный код.
1
|
|||
|
0 / 0 / 0
Регистрация: 22.02.2013
Сообщений: 13
|
|
| 04.04.2013, 10:59 [ТС] | |
|
Kastaneda, Пардон, конечно, за мою некомпетентность, но каким образом я могу сгенерировать сразу машинный код, без ассемблера?
0
|
|
|
4226 / 1796 / 211
Регистрация: 24.11.2009
Сообщений: 27,562
|
|
| 04.04.2013, 11:02 | |
|
А какая разница, что генерить? Мнемоники соответствуют опкодам и наоборот.
0
|
|
|
73 / 73 / 18
Регистрация: 29.11.2011
Сообщений: 356
|
|
| 04.04.2013, 11:04 | |
|
Ну если ваш компилятор успешно генерирует ассемблерный код, то что мешает скомпилировать ассемблерный код, ну я не знаю, ну что-ли, компилятором ассемблера, например.
0
|
|
|
4226 / 1796 / 211
Регистрация: 24.11.2009
Сообщений: 27,562
|
||
| 04.04.2013, 11:05 | ||
|
Если же охота иметь две стадии, то код можно передать на сборку в сторонний ассемблер, либо генерить дважды с исходника: сначала ассемблерный код, потом опкоды.
Добавлено через 51 секунду
0
|
||
|
73 / 73 / 18
Регистрация: 29.11.2011
Сообщений: 356
|
|
| 04.04.2013, 11:07 | |
|
Компилятор, этот как язык, только другое. Попробуй скомпилировать код на с++ - сиплюсплюсом. Ассемблер - это язык
0
|
|
|
|
||||
| 04.04.2013, 11:09 | ||||
Исходя из этого можно создать машинный код. По сложности это почти тоже самое, что генерить ассемблерный листинг. Добавлено через 50 секунд
0
|
||||
|
73 / 73 / 18
Регистрация: 29.11.2011
Сообщений: 356
|
|
| 04.04.2013, 11:11 | |
|
Ладно, 1:0, но я отыграюсь
0
|
|
|
4226 / 1796 / 211
Регистрация: 24.11.2009
Сообщений: 27,562
|
||
| 04.04.2013, 11:11 | ||
|
0
|
||
|
0 / 0 / 0
Регистрация: 22.02.2013
Сообщений: 13
|
||
| 04.04.2013, 11:14 [ТС] | ||
|
Praktolock,
Kastaneda, Пожалуйста, опишите процесс более подробно. Например, если компилятор правильно сгенериррвал машинный код, что дальше?
0
|
||
|
73 / 73 / 18
Регистрация: 29.11.2011
Сообщений: 356
|
|
| 04.04.2013, 11:15 | |
|
Попробуй употребить где-нибудь словосочетание "пишу на ассемблере" вместо "пишу на языке ассемблера". Я буду рядом
0
|
|
|
0 / 0 / 0
Регистрация: 22.02.2013
Сообщений: 13
|
|
| 04.04.2013, 11:18 [ТС] | |
|
Kastaneda, если можно, дайте ссылки на литературу, где это расписано. У Ахо про это ничего нет.
0
|
|
|
4226 / 1796 / 211
Регистрация: 24.11.2009
Сообщений: 27,562
|
|
| 04.04.2013, 11:22 | |
|
0
|
|
|
|
|||
| 04.04.2013, 11:25 | |||
0
|
|||
|
73 / 73 / 18
Регистрация: 29.11.2011
Сообщений: 356
|
||
| 04.04.2013, 11:36 | ||
|
0
|
||
|
73 / 73 / 18
Регистрация: 29.11.2011
Сообщений: 356
|
|
| 04.04.2013, 11:42 | |
|
Это меняет счёт - 1:1. Впрочем, это неизменит того, что тема не имеет отношения ни к c++ ни, не дай боже, к начинающим.
Добавлено через 1 минуту И вообще, я так и не понял с какого языка ТС желает компилировать, и во что(под какую платформу).
0
|
|
|
0 / 0 / 0
Регистрация: 22.02.2013
Сообщений: 13
|
||
| 04.04.2013, 11:45 [ТС] | ||
|
Kastaneda, а можете описать процесс компановки и линкования бинарника? Ведь я могу для примера создать бинарный файл с машинными кодами которые бы выводили пресловутый хелло ворлд в досбоксе.
Добавлено через 1 минуту Praktolock,
0
|
||
| 04.04.2013, 11:45 | |
|
Помогаю со студенческими работами здесь
20
Реализация алгоритма Ахо-Корасика Подсчет времени выполнения алгоритма Ахо-Корасика (поиск подстроки в строке) Алгоритм Ахо-Карасика: для каждого слова определить, сколько раз оно встречается как подстрока во всех остальных словах Компиляторы Компиляторы Искать еще темы с ответами Или воспользуйтесь поиском по форуму: |
|
Новые блоги и статьи
|
||||
|
PhpStorm 2025.3: WSL Terminal всегда стартует в ~
and_y87 14.12.2025
PhpStorm 2025. 3: WSL Terminal всегда стартует в ~ (home), игнорируя директорию проекта
Симптом:
После обновления до PhpStorm 2025. 3 встроенный терминал WSL открывается в домашней директории. . .
|
Access
VikBal 11.12.2025
Помогите пожалуйста !! Как объединить 2 одинаковые БД Access с разными данными.
|
Новый ноутбук
volvo 07.12.2025
Всем привет.
По скидке в "черную пятницу" взял себе новый ноутбук Lenovo ThinkBook 16 G7 на Амазоне:
Ryzen 5 7533HS
64 Gb DDR5
1Tb NVMe
16" Full HD Display
Win11 Pro
|
Музыка, написанная Искусственным Интеллектом
volvo 04.12.2025
Всем привет. Некоторое время назад меня заинтересовало, что уже умеет ИИ в плане написания музыки для песен, и, собственно, исполнения этих самых песен. Стихов у нас много, уже вышли 4 книги, еще 3. . .
|
От async/await к виртуальным потокам в Python
IndentationError 23.11.2025
Армин Ронахер поставил под сомнение async/ await. Создатель Flask заявляет: цветные функции - провал, виртуальные потоки - решение. Не threading-динозавры, а новое поколение лёгких потоков. Откат?. . .
|
|
Поиск "дружественных имён" СОМ портов
Argus19 22.11.2025
Поиск "дружественных имён" СОМ портов
На странице:
https:/ / norseev. ru/ 2018/ 01/ 04/ comportlist_windows/
нашёл схожую тему. Там приведён код на С++, который показывает только имена СОМ портов, типа,. . .
|
Сколько Государство потратило денег на меня, обеспечивая инсулином.
Programma_Boinc 20.11.2025
Сколько Государство потратило денег на меня, обеспечивая инсулином.
Вот решила сделать интересный приблизительный подсчет, сколько государство потратило на меня денег на покупку инсулинов.
. . .
|
Ломающие изменения в C#.NStar Alpha
Etyuhibosecyu 20.11.2025
Уже можно не только тестировать, но и пользоваться C#. NStar - писать оконные приложения, содержащие надписи, кнопки, текстовые поля и даже изображения, например, моя игра "Три в ряд" написана на этом. . .
|
Мысли в слух
kumehtar 18.11.2025
Кстати, совсем недавно имел разговор на тему медитаций с людьми. И обнаружил, что они вообще не понимают что такое медитация и зачем она нужна. Самые базовые вещи. Для них это - когда просто люди. . .
|
Создание Single Page Application на фреймах
krapotkin 16.11.2025
Статья исключительно для начинающих. Подходы оригинальностью не блещут.
В век Веб все очень привыкли к дизайну Single-Page-Application .
Быстренько разберем подход "на фреймах".
Мы делаем одну. . .
|