汇编语言-019(汇编程序与c\c++相互调用)
生活随笔
收集整理的這篇文章主要介紹了
汇编语言-019(汇编程序与c\c++相互调用)
小編覺得挺不錯的,現在分享給大家,幫大家做個參考.
1:在C++程序中使用__asm塊插入匯編代碼程序(不能用LENGTHOF與SIZEOF運算符,而是LENGTH和SIZE)
struct Package {long originZip; //4long destinationzip;//4float shippingPrice; //4 };int main(int argcount,char* args[]) {char myChar;bool myBool;short myShort;int myInt;long myLong;float myFloat;double myDouble;Package myPackage;long double myLongDouble;long myLongArray[10];__asm{mov eax, myPackage.destinationzip; mov eax, LENGTH myInt; //1mov eax, LENGTH myLongArray; / 10mov eax, TYPE myChar; //1mov eax, TYPE myBool; //1mov eax, TYPE myShort; //2mov eax, TYPE myInt; //4mov eax, TYPE myLong; //4mov eax, TYPE myFloat;//4mov eax, TYPE myDouble;//8mov eax, TYPE myPackage;//12mov eax, TYPE myLongDouble; //8mov eax, TYPE myLongArray;//4mov eax, SIZE myLong;//4mov eax, SIZE myPackage;//12mov eax, SIZE myLongArray;//40}return 0;}2:使用c++程序調用匯編模塊,在一個數組中順序查找一個元素
IndexOf.asm
.586 .model flat,CIndexOf PROTO,srchVal:DWORD,arrayPtr:PTR DWORD,count:DWORD.code ;對32位整數數組執行線性搜索 ;尋找指定的數值,如果發現匹配數值 ;用EAX返回索引位置,否則返回-1 IndexOf PROC USES ecx esi edi,srchVal:DWORD,arrayPtr:PTR DWORD,count:DWORDNOT_FOUND = -1mov eax,srchVal ;搜索數值mov ecx,count ;數組大小mov esi,arrayPtr;數組指針mov edi,0 ;索引L1:cmp [esi+edi*4],eaxje foundinc ediloop L1notFound:mov eax,NOT_FOUNDjmp exit found:mov eax,ediexit:ret IndexOf ENDPENDindexOf.h
extern "C" long IndexOf(long n, long array[], unsigned count);main.cpp
#include <iostream> #include <time.h> #include "indexof.h" using namespace std;int main() {//偽隨機數數填充數組const unsigned ARRAY_SIZE = 100000;const unsigned LOOP_SIZE = 100000;char* boolstr[] = { "false", "true" };long array[ARRAY_SIZE];for (unsigned i = 0; i < ARRAY_SIZE; i++){array[i] = rand();}long searchVal;time_t startTime, endTime;cout << "Enter an integer value to find: ";cin >> searchVal;cout << "Please wait...\n";//測試匯編函數time(&startTime);int count = 0;for (unsigned n = 0; n < LOOP_SIZE; n++)count = IndexOf(searchVal, array, ARRAY_SIZE);bool found = count != -1;time(&endTime);cout << "Elapsed ASM time:" << long(endTime - startTime)<< "seconds . Found = " << boolstr[found] << endl;return 0;}3: 在c++程序中調用匯編過程,匯編過程又調用C++函數, 實現提示用戶輸入整數,通過移位方式將其與2的冪相乘
ASM.asm
include Irvine32.inc;外部c++函數 askForInteger PROTO C showInt PROTO C,value:SDWORD,outWidth:DWORD newLine PROTO COUT_WIDTH = 8 ENDING_POWER = 10.data intVal DWORD ?.code ;設置文本顏色,并清除控制臺窗口 ;調用Irvine32庫函數 SetTextOutColor PROC C,color:DWORDmov eax,colorcall SetTextColorcall Clrscrret SetTextOutColor ENDP;輸入一個整數n并顯示范圍為N*2的1次方到N*2的10次方的乘法表 DisplayTable PROC CINVOKE askForInteger ;調用C++函數mov intVal,eax ;保存整數mov ecx,ENDING_POWER ;循環計數器 L1:push ecx ;保存計數器shl intVal,1 ;乘以2INVOKE showInt,intVal,OUT_WIDTH;等于INVOKE,;push OUT_WIDTH;push intVal;call showInt;add esp,8 C規范主調方一定要恢復棧call Crlfpop ecxloop L1ret DisplayTable ENDP ENDmain.cpp
#include <iostream> #include <iomanip> using namespace std;extern "C" {//外部ASM過程void DisplayTable();void SetTextOutColor(unsigned color);//局部C++函數int askForInteger();void showInt(int value,int width); }int main() {SetTextOutColor(0x1E); //藍底黃字DisplayTable();return 0; }//提示用戶輸入一個整數 int askForInteger() {int n;cout<<"Enter an integer between 1 and 90,000:";cin>>n;return n; }//按特定寬度顯示一個有符號整數 void showInt(int value,int width) {cout<< setw(width)<<value; }4: 在匯編程序中調用C標準庫函數printf、scanf(必須從C或C++啟動程序中調用匯編語言代碼)
ASM.asm
.386 .model flat,stdcall .stack 2000printf PROTO C ,format:PTR BYTE,args:VARARG scanf PROTO C , format:PTR BYTE,args:VARARGTAB =9 .data strSingle BYTE "%lf",0 strDouble BYTE "%lf",0formatTwo BYTE "%lf",TAB,"%lf",0dh,0ah,0 Single REAL8 ? Double REAL8 ?.code asmMain PROC CINVOKE scanf,ADDR strSingle,ADDR SingleINVOKE scanf,ADDR strDouble,ADDR Double;傳遞給printf的浮點參數應聲明為REAL8,如果是REAL4,這需要相當的編程技巧INVOKE printf,ADDR formatTwo,Single,Doubleret asmMain ENDP ENDmain.cpp
#include <iostream> using namespace std; extern "C" void asmMain();int main() {asmMain();return 0; }5:匯編過程實現一個數組與一個整數相乘,c++程序傳遞數組進行運算
ASM.asm
.586 .model flat,C.code arrayAdd PROC , array:PTR DWORD,count:DWORD,mulNum:DWORDmov esi, arraymov ecx,count L1:mov eax,[esi]mul mulNummov [esi],eaxadd esi,4loop L1ret arrayAdd ENDP ENDmain.cpp
#include <iostream> using namespace std;extern "C" void arrayAdd(int* array,int count,int mulNum); int array[] = {1,2,3,4,5,6,7,8}; int main() {arrayAdd(array,8,10);for(int i=0;i<8;i++){cout<<array[i];cout<<endl;}return 0; }6: 編寫匯編子程序,接收數組偏移量和數組大小,子程序返回數組中最長的遞增序列中整數值的個數
ASM.asm
.586 .model flat,C.code GetIncrementalList PROC USES ecx edi ebx esi,array:PTR SDWORD,count:DWORDmov eax,1mov edi,1mov ecx,countdec ecxmov esi,array L0:mov ebx,[esi]cmp ebx,[esi+4]jge L1inc edijmp L2 L1:cmp edi,eaxjbe L2mov eax,edimov edi,1 L2:add esi,4loop L0ret GetIncrementalList ENDP ENDmain.cpp
#include <iostream> using namespace std;extern "C" int GetIncrementalList(int* array,int count);int array[] ={-5,10,20,14,17,26,42,22,19,-5}; int main() {int n =GetIncrementalList(array,10);return 0; }7:編寫匯編子程序,接收三個同樣大小的數組,將第二個數組與第三個數組加到第一個數組中
ASM.asm
.586 .model flat,C.code arraysAdd PROC ,array1:PTR DWORD,array2:PTR DWORD,array3 :PTR DWORD,count: DWORDmov ebx,array1mov esi,array2mov edi,array3mov ecx,count L1: mov eax,[esi]add eax,DWORD PTR[edi]mov [ebx],eaxadd esi,4add edi,4add ebx,4loop L1ret arraysAdd ENDP ENDmain.cpp
#include <iostream> using namespace std;extern "C" void arraysAdd(int* array1,int* array2,int* array3,int count); int array1[10]; int array2[10]={1,2,3,4,5,6,7,8,9,10}; int array3[10]={1,2,3,4,5,6,7,8,9,10}; int main() {arraysAdd(array1,array2,array3,10);for(int i =0;i<10;i++){cout<<array1[i]<<endl;}return 0; }8:編寫匯編過程實現判斷是一個數是否是一個質數,是返回1否則返回0,C++將數組每個元素進行判斷
isPrimeNumber.asm
.586 .model flat,C.code isPrimeNumber PROC USES ebx ecx edx, number:DWORDmov ebx,2cmp ebx,numberje L2mov ecx,numberjmp Start L0:mov eax,ecxmov edx,0div ebxcmp edx,0je L1inc ebx Start:cmp ebx,ecxjb L0 L2:mov eax,1jmp quit L1:mov eax,0 quit:ret isPrimeNumber ENDP ENDmain.cpp
#include <iostream> using namespace std;extern "C" int isPrimeNumber(int number);int array[] = {2,3,4,5,6,7,8,9,10,11,12,13,500,967,968}; int main() {for (int i = 0; i < 15; i++){int result = isPrimeNumber(array[i]);if(result)cout<<array[i]<<"is a prime number."<<endl;elsecout<<array[i]<<"is not a prime number."<<endl;}return 0; }9:編寫匯編過程從一個數組的尾部開始順序查找一個元素,返回其索引否則返回-1
myLastIndexOf.asm
.586 .model flat,C.code ;對32位整數數組執行線性搜索 ;尋找指定的數值,如果發現匹配數值 ;用EAX返回索引位置,否則返回-1 myLastIndexOf PROC USES ecx esi edi,srchVal:DWORD,arrayPtr:PTR DWORD,count:DWORDNOT_FOUND = -1mov eax,srchVal ;搜索數值mov ecx,count ;數組大小mov esi,arrayPtr;數組指針lea edi,[ecx - 1] ;索引L1:cmp [esi+edi*4],eaxje founddec ediloop L1notFound:mov eax,NOT_FOUNDjmp exit found:mov eax,ediexit:ret myLastIndexOf ENDPENDmyLastIndexOf.h
extern "C" long myLastIndexOf(long n, long array[], unsigned count);main.cpp
#include <iostream> #include "myLastIndexOf.h" using namespace std;long array[10] ={1,2,3,4,5,6,7,8,9,10};int main() {int index = myLastIndexOf(3, array, 10);cout<<index;return 0;}總結
以上是生活随笔為你收集整理的汇编语言-019(汇编程序与c\c++相互调用)的全部內容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: 许昌治疗少精弱精最好的医院推荐
- 下一篇: 医院住院多少钱一天啊?