Форум программистов, компьютерный форум CyberForum.ru

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

Восстановить пароль Регистрация
 
Newchap
4 / 4 / 1
Регистрация: 17.09.2013
Сообщений: 179
17.03.2014, 13:30     Ассемблерная Вставка #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
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;
}
Similar
Эксперт
41792 / 34177 / 6122
Регистрация: 12.04.2006
Сообщений: 57,940
17.03.2014, 13:30     Ассемблерная Вставка
Посмотрите здесь:

Ассемблерная вставка в с++ C++
Ассемблерная вставка C++
Ассемблерная вставка в c++ C++
Ассемблерная вставка в С++ C++
Ассемблерная вставка C++
C++ Ассемблерная вставка на С++
Не компилируется ассемблерная вставка C++
C++ Ассемблерная вставка на С++

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

Или воспользуйтесь поиском по форуму:
После регистрации реклама в сообщениях будет скрыта и будут доступны все возможности форума.
alexcoder
1438 / 652 / 86
Регистрация: 03.06.2009
Сообщений: 3,295
Завершенные тесты: 1
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
    }
Старался попроще и сохранить схожесть с оригиналом. Не проверял.
Newchap
4 / 4 / 1
Регистрация: 17.09.2013
Сообщений: 179
17.03.2014, 16:12  [ТС]     Ассемблерная Вставка #3
alexcoder, работает, спасибо!
Yandex
Объявления
17.03.2014, 16:12     Ассемблерная Вставка
Ответ Создать тему
Опции темы

Текущее время: 16:56. Часовой пояс GMT +3.
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2016, vBulletin Solutions, Inc.
Рейтинг@Mail.ru