汇编与C语言混合 实现的从小到大的冒泡排序
汇编实现的从小到大的冒泡排序
主函数由C语言实现,sort函数用汇编语言写
#include <stdio.h>
int buffer[256]; //数据缓冲区
int bufferlen=0; //数据缓冲区数据个数
extern sort(int *buffer,int bufferlen); //汇编函数sort接口
//********从键盘录入数据********
int InputDataFromKeyBoard(int *pBuffer)
{
int nCnt=0;
int x;
printf("数据输入开始:\n");
while(1)
{
scanf("%d",&x); //键盘输入整型数==〉x
pBuffer[nCnt++]=x; //x存入缓冲区
if((x==(int)-1)||(nCnt>=256)) //输入数据为-1 结束输入
{
nCnt--;
break;
}
}
printf("数据输入结束!\n");
return nCnt;
}
//********向控制台输出buffer数据********
void OutputConsole()
{
int i;
printf("输出Buffer数据:\n"); // 向控制台输出数据
for(i=0;i<bufferlen;i++)
{ printf("%4d",buffer[i]); }
printf("\n");
}
//********主函数********
int main()
{
bufferlen=InputDataFromKeyBoard((int *)buffer); //从键盘录入数据
OutputConsole(); //将输入数据输出到控制台
sort((int *)buffer,bufferlen); //对输入数据排序
OutputConsole(); //输出排序数据
return 0;
}
汇编函数如下:
EXPORT sort ;导出函数sort
AREA Exp103,CODE,READONLY
CODE32
sort ;函数名
;入口参数
; R0<==buffer数据缓冲区首地址
; R1<==bufferlen 数据缓冲区数据个数
SUBS R1,R1,#1 ;第一层循环 次数R1
MOV R5,R1 ;R5等于要排序的数据数-1
L0 MOV R2,#0
MOV R3,R1 ;第二层循环 次数R3
CMP R1,R5 ;R1是不是等于总数-1.如果是就说明这是第一次,R0不必移位
ADDNE R0,R0,#4 ;除了第一次外都要使R0移位,NE是不等于的意思
L1 LDR R6,[R0,R2] ;R6<=[R0+R2]
ADD R4,R2,#4
LDR R7,[R0,R4] ;R7<=[R0+R2+1]
CMP R6,R7
BLT L2
STR R7,[R0,R2] ;R6<R7交换
STR R6,[R0,R4]
L2 ADD R2,R2,#4
SUBS R3,R3,#1 ;二层循环控制
BNE L1
SUBS R1,R1,#1 ;一层循环控制
BNE L0
EXIT MOV PC,LR ;函数返回
END
运行实例
数据输入开始:4 2 6 8 7 -1
数据输入结束!
输出Buffer数据:
4 2 6 8 7
输出Buffer数据:
2 4 6 7 8
汇编与C语言混合 实现的从小到大的冒泡排序的更多相关文章
- 从linux0.11中起动部分代码看汇编调用c语言函数
上一篇分析了c语言的函数调用栈情况,知道了c语言的函数调用机制后,我们来看一下,linux0.11中起动部分的代码是如何从汇编跳入c语言函数的.在LINUX 0.11中的head.s文件中会看到如下一 ...
- 5种语言混合编程:C++、JS、python、Lisp、汇编
/* 混合C++.JS.python.Lisp.汇编 1种语言,5种语法 */ main { //C++ vector<int> v; v.push(2); putsl(v.size()) ...
- 九、ARM 汇编与 C 的混合编程
9.1 ARM 汇编与 C 的混合编程 9.1.1 内嵌汇编 __asm __asm("指令")例如关闭/打开总中断开关 CPSR __asm //使用 C 中变量名代替寄存器 { ...
- [汇编与C语言关系]2. main函数与启动例程
为什么汇编程序的入口是_start,而C程序的入口是main函数呢?以下就来解释这个问题 在<x86汇编程序基础(AT&T语法)>一文中我们汇编和链接的步骤是: $ as hell ...
- 【转载】ANSYS的APDL与C语言混合编程(实例)
原文地址:http://www.cnblogs.com/lyq105/archive/2010/05/04/1727557.html 本文讨论的不是利用C语言为ANSYS写扩展(或者说是用户子程序), ...
- keil or c51 汇编调用c语言函数 容易忽视的问题
最近,在用keil 写一个小程序时,想实践一下从汇编调用 C语言函数,我们都知道C语言调用汇编函数讨论得较多,但反过来,从汇编中调用C语言的函数未见深入分析:在开始的时候,还是忽视了一个问题,就是对现 ...
- C语言中递归什么时候能够省略return引发的思考:通过内联汇编解读C语言函数return的本质
事情的经过是这种,博主在用C写一个简单的业务时使用递归,因为粗心而忘了写return.结果发现返回的结果依旧是正确的.经过半小时的反汇编调试.证明了我的猜想,如今在博客里分享.也是对C语言编译原理的一 ...
- Java语言与C语言混合编程(2)--在Java中调用C语言本地库
在上一篇文章中介绍了Java语言中的native关键字,以及Java语言调用C语言的编译生成本地动态链接库(DLL)实现加法运算的小例子,本文通过一个更加详细的例子,深入讲解Java语言调用C语言的函 ...
- Java语言与C语言混合编程(1)--Java native 关键字
一. 什么是 native Method 简单地讲,一个 native Method 就是一个java调用非java代码的接口.一个 native Method 是这样一个java的方法:该方法的实现 ...
随机推荐
- 使用log4javascript记录日志
1.定义log4js服务类,用于初始化log4javascript相关参数 log4jsService.js //启用javascript 日志功能 var logger = log4javascri ...
- 机器学习&&数据挖掘之一:决策树基础认识
决策树入门篇 前言:分类是数据挖掘中的主要分析手段,其任务就是对数据集进行学习并构造一个拥有预测功能的分类模型,用于预测未知样本的类标号,把类标号未知的样本按照某一规则映射到预先给定的类标号中. 分类 ...
- 【BZOJ】【1048】【HAOI2007】分割矩阵
DP/记忆化搜索 暴力枚举分割方案?……大概是指数级的?大约是20!的方案= =? 但是我们看到a.b.n的范围都很小……所以不同的状态数只是$10^5$级别的,可以记忆化搜索求解 比较水的一道题…… ...
- 【BZOJ】【1041】【HAOI2008】圆周上的点
数学 orz hzwer 完全不会做…… 很纠结啊,如果将来再遇到这种题,还是很难下手啊…… 引用题解: [分析]: 样例图示: 首先,最暴力的算法显而易见:枚举x轴上的每个点,带入圆的方程,检查是否 ...
- NENU_CS_segment_tree
单点更新 http://acm.hdu.edu.cn/showproblem.php?pid=1166 题意:单点更新加减,区间查询求和. #include<cstdio> #define ...
- 阿里云centos配置ftp和svn全过程
1.下载xshell 2.登录centos 3.安装vsftpd [root@xxx]# yum install vsftpd //安装vsftpd [root@xxx]# chkconfig vsf ...
- INSERT IGNORE 与INSERT INTO的区别
INSERT IGNORE 与INSERT INTO的区别就是INSERT IGNORE会忽略数据库中已经存在 的数据,如果数据库没有数据,就插入新的数据,如果有数据的话就跳过这条数据.这样就可以 ...
- 使用CSS3实现超炫的Loading(加载)动画效果
SpinKit 是一套网页动画效果,包含8种基于 CSS3 实现的很炫的加载动画.借助 CSS3 Animation 的强大功能来创建平滑,易于定制的动画.SpinKit 的目标不是提供一个每个浏览器 ...
- jQuery一些常用特效方法使用实例
1. jQuery fadeIn() 用于淡入已隐藏的元素. 语法: $(selector).fadeIn(speed,callback); 实例: $("button").cli ...
- IE浏览器上传文件时本地路径变成”C:\fakepath\”的问题【转】
转自:http://www.iefans.net/ie-shangchuan-bendi-lujing-fakepath/ 在使用<input id="file_upl" t ...