汇编实现的从小到大的冒泡排序

主函数由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语言混合 实现的从小到大的冒泡排序的更多相关文章

  1. 从linux0.11中起动部分代码看汇编调用c语言函数

    上一篇分析了c语言的函数调用栈情况,知道了c语言的函数调用机制后,我们来看一下,linux0.11中起动部分的代码是如何从汇编跳入c语言函数的.在LINUX 0.11中的head.s文件中会看到如下一 ...

  2. 5种语言混合编程:C++、JS、python、Lisp、汇编

    /* 混合C++.JS.python.Lisp.汇编 1种语言,5种语法 */ main { //C++ vector<int> v; v.push(2); putsl(v.size()) ...

  3. 九、ARM 汇编与 C 的混合编程

    9.1 ARM 汇编与 C 的混合编程 9.1.1 内嵌汇编 __asm __asm("指令")例如关闭/打开总中断开关 CPSR __asm //使用 C 中变量名代替寄存器 { ...

  4. [汇编与C语言关系]2. main函数与启动例程

    为什么汇编程序的入口是_start,而C程序的入口是main函数呢?以下就来解释这个问题 在<x86汇编程序基础(AT&T语法)>一文中我们汇编和链接的步骤是: $ as hell ...

  5. 【转载】ANSYS的APDL与C语言混合编程(实例)

    原文地址:http://www.cnblogs.com/lyq105/archive/2010/05/04/1727557.html 本文讨论的不是利用C语言为ANSYS写扩展(或者说是用户子程序), ...

  6. keil or c51 汇编调用c语言函数 容易忽视的问题

    最近,在用keil 写一个小程序时,想实践一下从汇编调用 C语言函数,我们都知道C语言调用汇编函数讨论得较多,但反过来,从汇编中调用C语言的函数未见深入分析:在开始的时候,还是忽视了一个问题,就是对现 ...

  7. C语言中递归什么时候能够省略return引发的思考:通过内联汇编解读C语言函数return的本质

    事情的经过是这种,博主在用C写一个简单的业务时使用递归,因为粗心而忘了写return.结果发现返回的结果依旧是正确的.经过半小时的反汇编调试.证明了我的猜想,如今在博客里分享.也是对C语言编译原理的一 ...

  8. Java语言与C语言混合编程(2)--在Java中调用C语言本地库

    在上一篇文章中介绍了Java语言中的native关键字,以及Java语言调用C语言的编译生成本地动态链接库(DLL)实现加法运算的小例子,本文通过一个更加详细的例子,深入讲解Java语言调用C语言的函 ...

  9. Java语言与C语言混合编程(1)--Java native 关键字

    一. 什么是 native Method 简单地讲,一个 native Method 就是一个java调用非java代码的接口.一个 native Method 是这样一个java的方法:该方法的实现 ...

随机推荐

  1. 使用log4javascript记录日志

    1.定义log4js服务类,用于初始化log4javascript相关参数 log4jsService.js //启用javascript 日志功能 var logger = log4javascri ...

  2. 机器学习&&数据挖掘之一:决策树基础认识

    决策树入门篇 前言:分类是数据挖掘中的主要分析手段,其任务就是对数据集进行学习并构造一个拥有预测功能的分类模型,用于预测未知样本的类标号,把类标号未知的样本按照某一规则映射到预先给定的类标号中. 分类 ...

  3. 【BZOJ】【1048】【HAOI2007】分割矩阵

    DP/记忆化搜索 暴力枚举分割方案?……大概是指数级的?大约是20!的方案= =? 但是我们看到a.b.n的范围都很小……所以不同的状态数只是$10^5$级别的,可以记忆化搜索求解 比较水的一道题…… ...

  4. 【BZOJ】【1041】【HAOI2008】圆周上的点

    数学 orz hzwer 完全不会做…… 很纠结啊,如果将来再遇到这种题,还是很难下手啊…… 引用题解: [分析]: 样例图示: 首先,最暴力的算法显而易见:枚举x轴上的每个点,带入圆的方程,检查是否 ...

  5. NENU_CS_segment_tree

    单点更新 http://acm.hdu.edu.cn/showproblem.php?pid=1166 题意:单点更新加减,区间查询求和. #include<cstdio> #define ...

  6. 阿里云centos配置ftp和svn全过程

    1.下载xshell 2.登录centos 3.安装vsftpd [root@xxx]# yum install vsftpd //安装vsftpd [root@xxx]# chkconfig vsf ...

  7. INSERT IGNORE 与INSERT INTO的区别

      INSERT IGNORE 与INSERT INTO的区别就是INSERT IGNORE会忽略数据库中已经存在 的数据,如果数据库没有数据,就插入新的数据,如果有数据的话就跳过这条数据.这样就可以 ...

  8. 使用CSS3实现超炫的Loading(加载)动画效果

    SpinKit 是一套网页动画效果,包含8种基于 CSS3 实现的很炫的加载动画.借助 CSS3 Animation 的强大功能来创建平滑,易于定制的动画.SpinKit 的目标不是提供一个每个浏览器 ...

  9. jQuery一些常用特效方法使用实例

    1. jQuery fadeIn() 用于淡入已隐藏的元素. 语法: $(selector).fadeIn(speed,callback); 实例: $("button").cli ...

  10. IE浏览器上传文件时本地路径变成”C:\fakepath\”的问题【转】

    转自:http://www.iefans.net/ie-shangchuan-bendi-lujing-fakepath/ 在使用<input id="file_upl" t ...