Обработка символьной информации, с помощью функций DOS |
1. Заголовок или название темы должно быть информативным
2. Все тексты программ должны помещаться в теги [CODE=asm] [/CODE]
3. Прежде чем задавать вопрос, см. "FAQ",если там не нашли ответа, воспользуйтесь ПОИСКОМ, возможно, такую задачу уже решали!
4. Не предлагайте свои решения на других языках, кроме Ассемблера. Исключение только с согласия модератора.
5. НЕ используйте форум для личного общения! Все, что не относиться к обсуждению темы - на PM!
6. Проверяйте программы перед тем, как выложить их на форум!!
Обработка символьной информации, с помощью функций DOS |
Rocket |
Сообщение
#1
|
Знаток Группа: Пользователи Сообщений: 306 Пол: Мужской Реальное имя: Евгений Репутация: 0 |
Вот задание: Ввести с клавиатуры две строки. Сравнить их. Вывести на экран какая из строк больше и насколько. Какие мысли есть по реализации данной программы? Как осуществить сравнение строк?
|
volvo |
Сообщение
#2
|
Гость |
Цитата А вот как организовать подпрограмму поиска одной введённой строки в другой строке? И ещё: вывод позиции, с которой подстрока содержится в строке... Вот тебе программа, которая это делает... В виде подпрограммы оформляй сам:MODEL small(процедуру writeDEC возьми из предыдущих постов, я не стал ее опять копировать...) |
Rocket |
Сообщение
#3
|
Знаток Группа: Пользователи Сообщений: 306 Пол: Мужской Реальное имя: Евгений Репутация: 0 |
Вот тебе программа, которая это делает... У меня возник ряд вопросов по реализации... 1) Использование "offset". Я так полагаю, что это полный аналог команды "lea" ? 2) inpStrDat что это за переменная, для чего она нужна? 3) mov di, offset inpStrDatчто делает конструкция такого вида? 4) Как определяется размер строки? т.е. mov cl, inpStrLenпочему в cl сразу помещается размер строки? 5) При переходе на метку beginCompare:, где мы должны проверять последующие за первой буквы, мы снова проверяем совпадение первых букв, так ли это? 6) Когда мы из стека вытаскиваем di, разве он сразу не указывает на позицию, с которой начинается подстрока в строке? Как вообще происходит тогда вычисление позиции? Сообщение отредактировано: volvo - |
volvo |
Сообщение
#4
|
Гость |
1) Использование "offset". Я так полагаю, что это полный аналог команды "lea" ? Правильно полагаешь... ; можно вот так получить смещение inpStrDatВ обоих случаях смещение этого массива от начала сегмента будет занесено в регистр DI... 2) inpStrDat что это за переменная, для чего она нужна? Как это "для чего"? А строку ты что, в воздухе хранить будешь? Вообще-то для нее надо место выделять. Вот я и выделил 200 байт.Вообще обрати внимание, для ввода строки используется функция 0AH прерывания 21H... А она требует для работы вот чего: Цитата(Абель) LABEL представляет собой директиву с атрибутом BYTE. Первый байт содержит максимальную длину вводимых данных. Так как это однобайтовое поле, то возможное максимальное значение его - FFh или 255. Второй байт необходим DOS для занесения в него действительного числа введенных символов. Третьим байтом начинается поле, которое будет содержать введенные символы. Вот так... А поскольку я не описывал LABEL (ленивый я, не люблю набирать лишние символы ), то в DX загружал смещение inpStr, то есть, первого из необходимых параметров...NAMEPAR LABEL BYTE ; Список параметров: Так как в списке параметров директива LABEL не занимает места, то NAMEPAR и MAXLEN указывают на один и тот же aдрес памяти. В трансляторе MASM для определения списка параметров в виде структуры может использоваться также директива STRUC. Однако, в связи с тем, что ссылки на имена, определенные внутри, требуют специальной адресации, воздержимся cейчас от рассмотрения данной темы до гл. 24 "Директивы ассемблера". Для запроса на ввод необходимо поместить в регистр AH номер функции - 10 (шест. 0Ah), загрузить адрес списка параметров (NAMEPAR в нашем примере) в регистр DX и выполнить INT 21H Я надеюсь, вопрос 4) Как определяется размер строки? т.е.
исчерпан? Я там, в цитате, выделил ответ на него...mov cl, inpStrLenпочему в cl сразу помещается размер строки? 5) При переходе на метку
Так, но почему тебя это пугает? Я же уменьшаю DI перед проверкой, то есть, DI указывает именно на первый, совпавший символ в строке...beginCompare:, где мы должны проверять последующие за первой буквы, мы снова проверяем совпадение первых букв, так ли это? 6) Когда мы из стека вытаскиваем di, разве он сразу не указывает на позицию, с которой начинается подстрока в строке? Как вообще происходит тогда вычисление позиции? Нет, он указывает на смещение относительно начала сегмента... А для того, чтобы вычислить позицию, надо из этого самого смещения, которое хранится в DI, вычесть смещение первого символа строки, которое я и заношу в DX... После вычитания в AX имеем позицию подстроки в строке... |
Текстовая версия | 17.05.2024 1:08 |