汇编实现: C库常见函数

一丶汇编实现Strncpy拷贝函数

void __asmStrncpy(char *des,char *src,int len)
{
__asm {
mov edi,[ebp + 8]; //获取局部变量地址 des
mov esi,[ebp + 0xc]; //获取局部变量地址 src
mov ecx,len; //使用movs指令,需要给ecx长度
cld //设置DF = 0; 内存方向, 此时edi++ esi ++获取方式
rep movs byte ptr [edi],byte ptr[esi];//根据ecx的值,循环从esi里面获取字节输几局给edi
;rep movsb //直接省略了.默认操作 eis 跟 edi.以字节方式
;rep movsw //以word两个字节为单位拷贝 等价于 rep movs byte ptr[edi],byte ptr[esi]
;rep movsd //四个字节为单位. } }

总结:

movs指令的作用

主要使用了串操作指令movs指令 [esi] 拷贝->[edi] ecx计数 rep重复.

  1.跟ecx搭配, ecx控制循环次数

  2.跟cld搭配. cld设置DF位,这样拷贝的时候内存就是++拷贝

  3.movs的主要作用就是把 esi所指向的内存数据 拷贝到 edi所指向的内存中.

  4.movs 有很多重载, 例如 movsb movsw movsd 分别就是按照字节拷贝, 按照一个字拷贝 按照4个字拷贝.

二丶loads实现Strlen操作.

loads作用: 将 [esi]所指向内存拷贝到 eax中/ax al..

	int __asmStrlen(char *src)
{ __asm{
mov esi,[ebp + 8]; //获取src参数地址给esi
xor eax,eax;
xor ebx,ebx; //清空计数寄存器
Len:
Lods byte ptr[esi]; //将esi内存的字符串按照1字节给eax存储
test eax,eax; //判断最后的eax是否为0
jz Exit; //为0 就把计数的值给eax进行返回
inc ebx; //不为0,计数器++
jnz len; //并且跳转到上边继续执行.
Exit:
mov eax,ebx;
}
}

总结:

lods 主要就是[esi] 内存的值给eax进行存储. 其lodsb lodsd lodsw 分别就是按照一个字节 两个字节 4个字节赋值.

1.lods寄存器 操作的 esi 跟 eax寄存器

2.eax存放从esi里面获取的数据按照 lodsb lodsd losw等指令拷贝一个字节还是多个字节

3.loads 是通用的,后面只需要给定你拷贝的字节个数即可. 例如 lods byte ptr[esi] word ptr[esi]

三丶stos的作用

stos作用于 edi,和 eax. 把eax的值拷贝到edi所指向的内存中.

根据ecx的长度决定,配合rep指令.

相应的也有

stosb

stosw

stosd

__declspec(naked) int RetValue()
{
__asm
{
push ebp; ;保存栈低,老ebp
mov ebp,esp ;老ebp等于当前的栈顶,便于寻址
sub esp,0x20; ;开辟局部变量空间
lea edi,[esp]; ;取得栈顶地址,进行拷贝.首先获取一下,否则如果写在下方则要 ebp - xxx进行获取局部变量空间
pushad ;保存寄存器环境
mov ecx,0x20 ;赋值ecx 0x20个字节. rep循环20次.以byte 的形式
mov eax,0xcc; ;eax给cc,进行初始化
rep stos byte ptr[edi]; ;根据ecx个数,将局部eax的值赋值到edi中,给局部变量初始化为cc
popad ;恢复寄存器环境
mov esp,ebp ;恢复局部变量空间, 栈顶跟原栈顶一样.
pop ebp ;恢复栈低.
ret ;返回.
}
}

总结

总结来说. stos(stosb sw sd)就是把eax的值,拷贝到edi所指向的内存中,使用rep循环指令.拷贝大小.

1.获取局部变量空间.

2.给eax赋值你要初始化的值

3.给ecx赋值,计数的值

4.rep 配合stos将 eax值赋值给edi所指向的内存

汇编实现: C库常见函数,串操作指令作用的更多相关文章

  1. 汇编3栈帧,参数传递,串操作,混合汇编,x64,asm文件

    基础知识2 选择结构 通过判断 + 条件跳转指令来实现 循环结构 通过判断 + 条件跳转指令来实现(会有一个向上跳转的语句) 函数调用约定 C调用约定: 由外部平衡栈 标准调用约定 : 由函数内部平衡 ...

  2. DF标志和串移动指令(movsb/movsw)

    1.标志寄存器的第10位DF,方向标志位.在串处理指令中,控制每次操作后si,di的增减 DF=0,每次操作后,si.di添加 DF=1,每次操作后,si.di减小 我们能够用汇编语法描写叙述movs ...

  3. ARM指令集——条件执行、内存操作指令、跳转指令

    ARM 汇编指令条件执行 在ARM模式下,任何一条数据处理指令可以选择是否根据操作的结果来更新CPSR寄存器中的ALU状态标志位.在数据处理指令中使用S后缀来实现该功能. 不要在CMP,CMN,TST ...

  4. DF标志和串传送指令

    DF标志和串传送指令 flag的第10位是DF,方向标志位.在串处理指令中,控制si.di的递减. df = 0 每次操作后si.di递增 df = 1 每次操作后si.di递减 串传送指令 格式1: ...

  5. 计算机系统之汇编---IA32处理器数据格式及数据操作

    计算机系统之汇编---IA32处理器数据格式及数据操作 IA32数据格式: Intel用术语"字"表示16位数据类型,因此.称32位数为"双字",称64位数为& ...

  6. ARM汇编初探---汇编代码中都有哪几类指令---ARM伪指令介绍

    要学习一个东西首先要把概念搞清楚,以下仅仅是自己的一些关于汇编的理解. 可运行文件里的01码是机器码,机器码不等于汇编码,尽管机器码能够非常easy翻译成汇编码. 汇编码中包括非常多汇编指令.伪指令和 ...

  7. git操作指令,以及常规git代码操作

    安装git后操作指令如下:可以查阅git安装使用操作指南详情git安装使用操作图示详情.note 线上可参考指南:http://www.bootcss.com/p/git-guide/   所有操作在 ...

  8. 高级运维(六):源码安装Redis缓存服务、常用Redis数据库操作指令、配置Redis主从服务器

    一.源码安装Redis缓存服务 目标: 本案例要求先快速搭建好一台Redis服务器,并测试该缓存服务器: 1> 设置变量test,值为123 2> 查看变量test的值 3> 设置计 ...

  9. 第24篇-虚拟机对象操作指令之getfield

    getfield指令表示获取指定类的实例域,并将其值压入栈顶.其格式如下: getstatic indexbyte1 indexbyte2 无符号数indexbyte1和indexbyte2构建为(i ...

随机推荐

  1. Android 动画 (1) 基础

    背景 坑, 最近打算在recyclerview item上加一个带动画的button,结果button无法连续点击,还以为是动画是同步的,必须要结束之后才能开始另一个动画,后来去掉recylervie ...

  2. PyQt4转换ui为py文件需添加如下代码才可执行

    1)转换ui为py 命令行进入ui文件所在文件夹,输入pyuic4 ui_name.ui > py_name.py即可 或新建ui2py.bat文件,写入: @echo off @cd /d & ...

  3. 使用mongo获取文章

    先在命令行中输入mongo,进入mongo,然后 show dbs # 从结果中发现有cmb_demo_23_hacker use cmb_demo_23_hacker db.all_in_one.f ...

  4. DevOps详解

    最近我阅读了很多有关DevOps的文章,其中一些非常有趣,然而一些内容也很欠考虑.貌似很多人越来越坚定地在DevOps与chef.puppet或Docker容器的熟练运用方面划了等号.对此我有不同看法 ...

  5. 源码安装python +NGINX 的坎坷路 +uwsgi安装 部署django 的CRM项目

    一.Nginx安装(基于ubuntu17.10 版本) 首先我们是基于源码安装,主要有如下步骤 1.安装依赖包 1.安装gcc g++的依赖库 sudo apt-get install build-e ...

  6. CVE-2018-20129:DedeCMS V5.7 SP2前台文件上传漏洞

    一.漏洞摘要 漏洞名称: DedeCMS V5.7 SP2前台文件上传漏洞上报日期: 2018-12-11漏洞发现者: 陈灿华产品首页: http://www.dedecms.com/软件链接: ht ...

  7. wordpress安装插件和主题

    一.建立ftp服务器: 安装:sudo apt-get install vsftpd 配置:sudo nano /etc/vsftpd.conf 本地写入的注释去掉,可以写入的注释去掉 重启服务: s ...

  8. scala Weak Conformance

    Weak Conformance In some situations Scala uses a more general conformance relation. A type S weakly ...

  9. [安卓] 20、基于蓝牙BLE的广播包高频快速搜索

    前言: 之前介绍过很多蓝牙beacon.搜索.连接.通讯的文章.不过最近我发现:之前写的蓝牙广播包搜索的工程,搜索频率太慢,而且不能一直保持搜索状态.因此,这里探讨下高频蓝牙广播包扫描 -- 蓝牙BL ...

  10. 安卓开发笔记(十六):'Request(okhttp3.Request.Builder)' has private access in 'okhttp3.Request

    当出现了'Request(okhttp3.Request.Builder)' has private access in 'okhttp3.Request的错误的时候,实际上是我们在写代码的时候少打了 ...