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

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

Войти
Регистрация
Восстановить пароль
Другие темы раздела
C++ Найти сумму ряда с заданной точностью http://www.cyberforum.ru/cpp-beginners/thread1121655.html
Найти сумму ряда с точностью Е=10-4, общий член которого An= (n!)/(n^n) правильно ли я написал программу ? #include <conio.h> #include <iostream> #include<math.h> using namespace std; ...
C++ Какова польза лямбда выражений Вот набросал пример который показывает что лямбда выражения медленней простых циклов и больше кода, в чем тогда их польза ? /* * main.cpp * * Created on: 31 янв. 2014 г. * Author:... http://www.cyberforum.ru/cpp-beginners/thread1121644.html
C++ Ввести несколько кирпичей, определить обьем и определить самый большой
1)Определить N первых членов рекуррентной последовательностиhttp://rghost.ru/53121622.view 2)Ввести N троек чисел a1,b1,c1; a2,b2, c2 an,bn,cn.... обозначающих длины рёбер кирпичей....
Перевод числа из двоичной системы в десятичную C++
Помогите написать программу для перевода из 2 в 10. Если число делится на 3, то вывести и результат деления
C++ Помогите написать две небольшие программы по блок схемам http://www.cyberforum.ru/cpp-beginners/thread1121602.html
Помогите написать две небольшие программы по блок схемам для уравнения X^3+3X^2+6X-1=0 1.Метод простой итерации 2.Метод Хорд
C++ В матрице, записанной в файл, четные элементы разделить на 4, а к нечетным прибавить 10 Вот условие задачи: В матрице A(6,6) четные элементы разделить на 4, а к нечетным прибавить 10. Вывести полученную матрицу. код: #include <iostream> #include <cstdio> #include <cmath> using... подробнее

Показать сообщение отдельно
Newchap
4 / 4 / 1
Регистрация: 17.09.2013
Сообщений: 179

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

17.03.2014, 13:30. Просмотров 519. Ответов 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
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
 
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2017, vBulletin Solutions, Inc.
Рейтинг@Mail.ru