Форум программистов, компьютерный форум, киберфорум
С++ для начинающих
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.57/7: Рейтинг темы: голосов - 7, средняя оценка - 4.57
2 / 2 / 0
Регистрация: 17.05.2012
Сообщений: 40

Сделать из assembler кода ассемблерную вставку в C++

12.01.2015, 12:21. Показов 1671. Ответов 4
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
У меня есть код в ассемблере, мне надо его сделать ассемблерной вставкой, чтоб он работал
вот код
Assembler
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
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
include \masm32\include\masm32rt.inc
include \masm32\include\msvcrt.inc ;для сrt_printf\crt_scanf
include \masm32\macros\macros.asm
includelib \masm32\lib\masm32.lib
includelib \masm32\lib\msvcrt.lib ;для сrt_printf\crt_scanf
 
    .data
      msg1 db 'Enter string 1:',0Dh, 0Ah,0
      msg2 db 'Symbol:',0Dh, 0Ah,0
      msg3 db 'Modified string:',0Dh,0Ah,0
      new db 0Dh,0Ah,0
      tpts db '%s',0
 
      str1 db 255 dup(?)
      str2 db 255 dup(?)
      str3 db 255 dup(?)
 
    .code
start:
 
    cls
    invoke crt_printf,ADDR msg1
    invoke StdIn, addr str1,255 ;вводим, вводим, вводим
    
    invoke crt_printf,ADDR msg2
    invoke StdIn, addr str2,255
 
    mov eax, offset str1 ;в регистры адрес строк
    mov ebx, offset str2
    mov edi, offset str3
    xor edx,edx
    mov dl, byte ptr [ebx] ;получаем искомый символ
 
    call work
 
    invoke crt_printf,ADDR msg3 ;выводим результат
    invoke crt_printf,ADDR str3
    invoke crt_printf,ADDR new
    inkey
    exit
 
work proc
 
    push ebx ;запоминаем регистры
    push ecx
    push esi
    push ebp
 
    xor ebx,ebx
    xor ecx,ecx
    xor esi,esi
    xor ebp,ebp
 
    @@1:    ;цикл по строке
        mov bl, byte ptr [eax + esi] ;получили символ из строки
        inc esi ;увеличили позицию
        cmp bl,0 ;дошли до кнца?
        je @@4
 
        cmp bl,dl
        je @@2 ;если дошли до заданного символа
        
        mov byte ptr [edi],bl ;иначе в выходную строку добавляем текущий символ
        inc edi ;увеличиваем счетчик
 
        jmp @@1
 
    @@2:
        mov bl, byte ptr [eax + esi] ;получили символ
        inc esi ;увеличили счетчик
        cmp bl,0 ;сравнили с концом
        je @@3
        
        mov byte ptr [edi],bl ;положили на выход текущий символ
        inc edi ;увеличили счетчик
 
        jmp @@2
 
    @@3:
        mov byte ptr [edi],dl ;положили искомый символ
        inc edi ;увеличили счетчик
    @@4:
        mov byte ptr [edi],0 ;указали конец строки
 
    @@end:
    pop ebp ;восстановили регистры
    pop esi
    pop ecx
    pop ebx
    ret ;возвращаемся
work endp
 
end start
я попробовал сам это сделать но у меня явно какие-то косяки,
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
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
#include "stdafx.h"
#include <iostream>
#include <string.h>
using namespace std;
const int length = 32;
char *buf = new char[length];
char *str1 = new char[32];
char *str2 = new char[32];
char *str3 = new char[32];
int main();
{
cout<< "stroka";
cin>>str1;
cout<< "simvol";
cin>>str2;
    _asm 
    {   
        mov eax, offset str1 ;в регистры адрес строк
    mov ebx, offset str2
    mov edi, offset str3
    xor edx,edx
    mov dl, byte ptr [ebx] ;получаем искомый символ
    
    push ebx ;запоминаем регистры
    push ecx
    push esi
    push ebp
 
    xor ebx,ebx
    xor ecx,ecx
    xor esi,esi
    xor ebp,ebp
 
    1:    ;цикл по строке
        mov bl, byte ptr [eax + esi] ;получили символ из строки
        inc esi ;увеличили позицию
        cmp bl,0 ;дошли до кнца?
        je 4
 
        cmp bl,dl
        je 2 ;если дошли до заданного символа
        
        mov byte ptr [edi],bl ;иначе в выходную строку добавляем текущий символ
        inc edi ;увеличиваем счетчик
 
        jmp 1
 
    2:
        mov bl, byte ptr [eax + esi] ;получили символ
        inc esi ;увеличили счетчик
        cmp bl,0 ;сравнили с концом
        je 3
        
        mov byte ptr [edi],bl ;положили на выход текущий символ
        inc edi ;увеличили счетчик
 
        jmp 2
 
    3:
        mov byte ptr [edi],dl ;положили искомый символ
        inc edi ;увеличили счетчик
    4:
        mov byte ptr [edi],0 ;указали конец строки
 
    end:
    pop ebp ;восстановили регистры
    pop esi
    pop ecx
    pop ebx
    ret ;возвращаемся
 
 
    }
         system("pause");
     return 0;
}
надеюсь кто-нибудь поможет сделать как надо.

ну и людям которым нравиться издеваться возрадуются ибо тут такой простор для этого))

Добавлено через 35 минут
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
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
// laba1.cpp: определяет точку входа для консольного приложения.
//
#include "stdafx.h"
#include <iostream>
#include <string.h>
using namespace std;
const int length = 32;
char *buf = new char[length];
char *str1 = new char[32];
char *str2 = new char[32];
char *str3 = new char[32];
void main()
{
cout<< "stroka";
cin>>str1;
cout<< "simvol";
cin>>str2;
    _asm 
    {   
        mov eax, offset str1 ;в регистры адрес строк
    mov ebx, offset str2
    mov edi, offset str3
    xor edx,edx
    mov dl, byte ptr [ebx] ;получаем искомый символ
    
    push ebx ;запоминаем регистры
    push ecx
    push esi
    push ebp
 
    xor ebx,ebx
    xor ecx,ecx
    xor esi,esi
    xor ebp,ebp
 
    l1:    //цикл по строке
        mov bl, byte ptr [eax + esi] //получили символ из строки
        inc esi //увеличили позицию
        cmp bl,0 //дошли до кнца?
        je l4
 
        cmp bl,dl
        je l2 //если дошли до заданного символа
        
        mov byte ptr [edi],bl //иначе в выходную строку добавляем текущий символ
        inc edi //увеличиваем счетчик
 
        jmp l1
 
    l2:
        mov bl, byte ptr [eax + esi] //получили символ
        inc esi //увеличили счетчик
        cmp bl,0 //сравнили с концом
        je l3
        
        mov byte ptr [edi],bl //положили на выход текущий символ
        inc edi //увеличили счетчик
 
        jmp l2
 
    l3:
        mov byte ptr [edi],dl //положили искомый символ
        inc edi //увеличили счетчик
    l4:
        mov byte ptr [edi],0 //указали конец строки
 
   end:
    pop ebp //восстановили регистры
    pop esi
    pop ecx
    pop ebx
    ret //возвращаемся
 
end start
    } cout<<str3;
         system("pause");
    }
чутка подредактировал, но все равно какие -то ошибки
warning C4731: main: регистр указателя фрейма "ebp" изменен встроенным кодом на языке ассемблера
что делать фиг знает
0
Programming
Эксперт
39485 / 9562 / 3019
Регистрация: 12.04.2006
Сообщений: 41,671
Блог
12.01.2015, 12:21
Ответы с готовыми решениями:

Как сделать ассемблерную вставку?
Нужно сложить два числа. Не могу понять ошибки вроде примеры смотрел вставки делаются именно так #include &lt;iostream&gt; #include...

Как сделать ассемблерную вставку в с++ ?
void encode_symbol (short int symbol ) { long range=0; asm{ mov ax,high //---------------находим range-------------- ...

Как сделать ассемблерную вставку на с++?
Вроде бы ничего нет сложного, код очень простой, и много где есть, но не идет код У меня c++ BorlandC 3.0, ассемблер MASM использую. Взял...

4
267 / 170 / 40
Регистрация: 25.08.2014
Сообщений: 1,087
Записей в блоге: 1
12.01.2015, 12:52
Так это warning, а не ошибка. скомпилировался и нормально.
0
 Аватар для Kastaneda
5232 / 3205 / 362
Регистрация: 12.12.2009
Сообщений: 8,143
Записей в блоге: 2
12.01.2015, 15:42
Цитата Сообщение от Enno Посмотреть сообщение
скомпилировался и нормально.
и пускай он стек-фреймы косячит

Хотя код посмотрел, там ebp сохраняется/восстанавливается, в данном случае действительно нормально. Но лучше отказаться от использования ebp и scratch регистры тоже лучше сохранить/восстановить, неизвестно как компилятор их использует.
1
2 / 2 / 0
Регистрация: 17.05.2012
Сообщений: 40
13.01.2015, 11:06  [ТС]
Всем спасибо тему можно закрывать.
0
7804 / 6568 / 2988
Регистрация: 14.04.2014
Сообщений: 28,705
13.01.2015, 16:23
А зачем там ret? Это же не функция уже.
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
inter-admin
Эксперт
29715 / 6470 / 2152
Регистрация: 06.03.2009
Сообщений: 28,500
Блог
13.01.2015, 16:23
Помогаю со студенческими работами здесь

Как сделать ассемблерную вставку
Доброе время суток: подскажите хотя бы теоретично как сделать ассемблерную вставку в код паскаля? например есть программа : ...

Переписать используя ассемблерную вставку
Есть подпрограмма написанная на С++: void sion(char *&amp;str){ int len = 0; for(;str; len++); for(int j = len - 1; j &gt;= 0; j--){...

Не могу запустить ассемблерную вставку на c++
Вставка находит скалярное произведение двух векторов, помогите запустить __asm { movaps xmm0, xmmword ptr // 0 | A.z |...

Системные вызов через ассемблерную вставку
Добрый день. Ребята помогите вызов функции getpid() return : -14 почему -14 ? #include &lt;stdio.h&gt; #include...

Нужно переделать С++ функцию на ассемблерную вставку
Вот у меня имеется функция,осуществляющая реверс строки на С++ void reverse(const char *s) { if (s &amp;&amp; *s) { int l; ...


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

Или воспользуйтесь поиском по форуму:
5
Ответ Создать тему
Новые блоги и статьи
моя боль
iceja 24.01.2026
Выложила интерполяцию кубическими сплайнами www. iceja. net REST сервисы временно не работают, только через Web. Написала за 56 рабочих часов этот сайт с нуля. При помощи perplexity. ai PRO , при. . .
Модель сукцессии микоризы
anaschu 24.01.2026
Решили писать научную статью с неким РОманом
http://iceja.net/ математические сервисы
iceja 20.01.2026
Обновила свой сайт http:/ / iceja. net/ , приделала Fast Fourier Transform экстраполяцию сигналов. Однако предсказывает далеко не каждый сигнал (см ограничения http:/ / iceja. net/ fourier/ docs ). Также. . .
http://iceja.net/ сервер решения полиномов
iceja 18.01.2026
Выкатила http:/ / iceja. net/ сервер решения полиномов (находит действительные корни полиномов методом Штурма). На сайте документация по API, но скажу прямо VPS слабенький и 200 000 полиномов. . .
Расчёт переходных процессов в цепи постоянного тока
igorrr37 16.01.2026
/ * Дана цепь(не выше 3-го порядка) постоянного тока с элементами R, L, C, k(ключ), U, E, J. Программа находит переходные токи и напряжения на элементах схемы классическим методом(1 и 2 з-ны. . .
Восстановить юзерскрипты Greasemonkey из бэкапа браузера
damix 15.01.2026
Если восстановить из бэкапа профиль Firefox после переустановки винды, то список юзерскриптов в Greasemonkey будет пустым. Но восстановить их можно так. Для этого понадобится консольная утилита. . .
Сукцессия микоризы: основная теория в виде двух уравнений.
anaschu 11.01.2026
https:/ / rutube. ru/ video/ 7a537f578d808e67a3c6fd818a44a5c4/
WordPad для Windows 11
Jel 10.01.2026
WordPad для Windows 11 — это приложение, которое восстанавливает классический текстовый редактор WordPad в операционной системе Windows 11. После того как Microsoft исключила WordPad из. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru