Форум программистов, компьютерный форум, киберфорум
С++ для начинающих
Войти
Регистрация
Восстановить пароль
 
Рейтинг 4.67/6: Рейтинг темы: голосов - 6, средняя оценка - 4.67
4 / 4 / 1
Регистрация: 17.09.2013
Сообщений: 179
1

Ассемблерная Вставка

17.03.2014, 13:30. Показов 1215. Ответов 2
Метки нет (Все метки)

Добрый день. начал изучать ассемблер(начал со вставок, на этом основание пишу здесь).
Должен был написать программу, где на Си++ задается массив, а ассемблерная часть программы вычисляет разницу наибольшего элемента и первого.
все компилит, но программу виснет после ввода переменных - т.е. на ассемблерной вставке.
Пожалуйста, подскажите где ошибка, вторую неделю сижу =(


C++
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
// asmb1.cpp: определяет точку входа для консольного приложения.
//
 
#include "stdafx.h"
#include <iostream>            
using namespace std;
 
int _tmain(int argc, _TCHAR* argv[])
{
    int mass[10];
    int i,raz;
    int Max;
    cout << "Enter value of mass[i]"<<endl;
    for (i = 0; i < 10; i++) {
        cin >> mass[i];
    }
    int pervii;
    _asm{
            mov cx, 0;
            lea EBX, mass;  регистр ебх получает в себя  указатель на первый элемент массива
                mov pervii, EBX; первый элемент.
                mov EDX, DWORD PTR[EBX]; дублируем
                Mov ECX, 0; регистр, содержащий индексы
                Mov Max, EBX; Сначала первый элемент максимальный.
        a2:
            mov Max, EDX;
        a1:
         mov EBX, DWORD PTR[EBX];
         add ECX, 4;                        сравнивается первый элемент и элемент n
         mov EDX, DWORD PTR[EBX][ECX]; переход на следующий элемент массива
            cmp ECX,EBX; если Есх больше, ты прыгаем на А2. Т.е. элемент N+1 наибольший
             JGE a2;
         add cx, 1;
         cmp cx, 9
             jl a1;
         Mov EBX, pervii;
         Mov Eax, Max;
         Sub Eax, EBX;
         Mov raz, Eax;
    }
 
    cout << raz;
    return 0;
}
Добавлено через 5 минут
нашел 1 ошибку, теперь не виснет, но выводит рандомное число

C++
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
#include "stdafx.h"
#include <iostream>            
using namespace std;
 
int _tmain(int argc, _TCHAR* argv[])
{
    int mass[10];
    int i,raz;
    int Max;
    cout << "Enter value of mass[i]"<<endl;
    for (i = 0; i < 10; i++) {
        cin >> mass[i];
    }
    int pervii;
    _asm{
            mov cx, 0;
            lea EBX, mass;  регистр ебх получает в себя  указатель на первый элемент массива
                mov pervii, EBX; первый элемент.
                mov EDX, DWORD PTR[EBX]; дублируем
                Mov ECX, 0; регистр, содержащий индексы
                Mov Max, EBX; Сначала первый элемент максимальный.
        a2:
            mov Max, EDX;
        a1:
         add ECX, 4;                        сравнивается первый элемент и элемент n
         mov EDX, DWORD PTR[EBX][ECX]; переход на следующий элемент массива
            cmp ECX,EBX; если Есх больше, ты прыгаем на А2. Т.е. элемент N+1 наибольший
             JGE a2;
         add cx, 1;
         cmp cx, 9
             jl a1;
         Mov EBX, pervii;
         Mov Eax, Max;
         Sub Eax, EBX;
         Mov raz, Eax;
    }
 
    cout << raz;
    return 0;
}
__________________
Помощь в написании контрольных, курсовых и дипломных работ здесь
0
Programming
Эксперт
94731 / 64177 / 26122
Регистрация: 12.04.2006
Сообщений: 116,782
17.03.2014, 13:30
Ответы с готовыми решениями:

Ассемблерная Вставка
Помогите, пожалуйста! Задано массив из 4 байт. Рассматривая его, как массив из 32 бит посчитать...

Ассемблерная вставка
Доброго времени суток, пытаюсь пытаюсь узнать поддерживает ли мой процессор тепловые сенсоры код не...

Ассемблерная вставка в c++
Как данный код написать между вставками __asm {} в c++??? Поскольку dw, db и тд не поддерживаются в...

Ассемблерная вставка в с++
С помощью логических операций реализуйте запись битов в данной ячейки памяти, размером в 2 байта, в...

2
1773 / 751 / 153
Регистрация: 03.06.2009
Сообщений: 5,482
17.03.2014, 16:03 2
C++
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
__asm{
lea ebx,mass
mov ecx,0
mov edx,[ebx]  ;max
m1:
cmp [ebx+ecx*4],edx
jng m2
mov edx,[ebx+ecx*4]
m2:
inc ecx
cmp ecx,10
jl m1
sub edx,[ebx]
mov raz,edx
    }
Старался попроще и сохранить схожесть с оригиналом. Не проверял.
1
4 / 4 / 1
Регистрация: 17.09.2013
Сообщений: 179
17.03.2014, 16:12  [ТС] 3
alexcoder, работает, спасибо!
0
IT_Exp
Эксперт
87844 / 49110 / 22898
Регистрация: 17.06.2006
Сообщений: 92,604
17.03.2014, 16:12

Ассемблерная вставка на С++
Добрый день, уважаемые. Столкнулся с большой проблемой когда понадобилось для увеличения скорости...

Ассемблерная вставка в С++
Когда в b у нас число больше 127 программа работает неправильно помогите исправить .. очень нужно...

Ассемблерная вставка
#include &lt;iostream&gt; #include &lt;cstdlib&gt; using namespace std; int main() { int x, y; cout &lt;&lt;...

Ассемблерная вставка
Нужно заменить в русской строке похожие буквы латиницей. Ввод и вывод - на С++, всё остальное - на...


Искать еще темы с ответами

Или воспользуйтесь поиском по форуму:
3
Ответ Создать тему
Опции темы

КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2021, vBulletin Solutions, Inc.