x64汇编第四讲,c / C++中调用x64汇编

一丶简介

1.说明

在x86下,我们的C/C++调用汇编可以直接 __asm进行内联.

或者也可以直接静态链接

具体详情可以参考以前博客:

https://www.cnblogs.com/iBinary/p/7555503.html

其实在我们x64下跟x32调用一样.只不过不支持内联汇编了.还是支持你编译成obj的方式进行调用.你声明一下就可以使用了.

现在我们用新的方法.直接编写一个 x64ASM文件即可.

二丶C/C++调用 asm64.asm函数.

1.配置asm参与生成

首先我们创建一个C/C++空项目.使用VS创建.这个应该很简单.不在截图了.

然后创建一个.c 或者.cpp文件.里面先按照征程写法,编写你的程序.

如下:



可以正常执行

然后我们添加一个.asm文件的后缀名. 这个文件跟添加.cpp文件一样.自己更改为.asm即可.

如下:

最重要的一步

你有这个文件,但是不能参加到项目的生成中来.所以你需要改一下 这个文件的属性.让其可以参与项目生成,且编译的时候编译成汇编格式.

如下:

从项目中生成 选择否代表你这个文件要参与生成.

第二个就是选择工具,选择自定义即可.因为我设置过了.所以左侧有自定义

生成工具

设置命令行编译.以及输出

如下:

命令行: ** ml64 /Fo $(IntDir)%(fileName).obj /c %(fileName).asm **

输出: **$(IntDir)%(fileName).obj **

此时我们asm就可以参与生成了.

2.给Asm文件添加函数代码

此时文件可以生成了.你就可以编写x64代码了.如下



.data

.const

.code

addNumber proc

	mov rax,rcx
add rax,rdx
ret
addNumber endp
end

3.C/C++调用asm的函数

上面我们写了 asm函数.我们C/C++调用的时候声明一下即可使用

如上面代码我们操作了 rcx,rdx 说明我们的参数有两个.

如下:

如果你的工程比较大.那么你可以为你的64asm汇编文件添加一个头文件

头文件中进行函数声明. 以 C方式导出.

你的CPP文件中包含这个头文件即可.

x64汇编第四讲,c / C++中调用x64汇编的更多相关文章

  1. 32位汇编第四讲,干货分享,汇编注入的实现,以及快速定位调用API的数量(OD查看)

    32位汇编第四讲,干货分享,汇编注入的实现,以及快速定位调用API的数量(OD查看) 昨天,大家可能都看了代码了,不知道昨天有没有在汇编代码的基础上,实现注入计算器. 如果没有,今天则会讲解,不过建议 ...

  2. [转]C# 互操作性入门系列(四):在C# 中调用COM组件

    传送门 C#互操作系列文章: C# 互操作性入门系列(一):C#中互操作性介绍 C# 互操作性入门系列(二):使用平台调用调用Win32 函数 C# 互操作性入门系列(三):平台调用中的数据封送处理 ...

  3. 第四讲 :hibernate中的session

    hibernate中的session中可以进行增删改差,通过工具类可以得到相关的工具类. 方法概要:  Transaction beginTransaction()开始一个工作单元,得到关联的事务对象 ...

  4. 算法第四版 在Eclipse中调用Algs4库

    首先下载Eclipse,我选择的是Eclipse IDE for Java Developers64位版本,下载下来之后解压缩到喜欢的位置然后双击Eclipse.exe启动 然后开始新建项目,File ...

  5. 算法第四版 在Linux 中调用Algs4库

    一: 搭建Java 环境   : 确认版本: 1.8及以上 [username:~/] javac -version javac 1.8.0_111 [username:~/] java -versi ...

  6. arm汇编学习(四)

    一.android jni实现1.静态实现jni:先由Java得到本地方法的声明,然后再通过JNI实现该声明方法.2.动态实现jni:先通过JNI重载JNI_OnLoad()实现本地方法,然后直接在J ...

  7. 逆向知识第十四讲,(C语言完结)结构体在汇编中的表现形式

    逆向知识第十四讲,(C语言完结)结构体在汇编中的表现形式 一丶了解什么是结构体,以及计算结构体成员的对其值以及总大小(类也是这样算) 结构体的特性 1.结构体(struct)是由一系列具有相同类型或不 ...

  8. PC逆向之代码还原技术,第四讲汇编中减法的代码还原

    目录 PC逆向之代码还原技术,第四讲汇编中减法的代码还原 一丶汇编简介 二丶高级代码对应汇编观看. 1.代码还原解析: 三丶根据高级代码IDA反汇编的完整代码 四丶知识总结 PC逆向之代码还原技术,第 ...

  9. C++反汇编第四讲,反汇编中识别继承关系,父类,子类,成员对象

    C++反汇编第四讲,反汇编中识别继承关系,父类,子类,成员对象 讲解目录: 1.各类在内存中的表现形式   备注: 主要复习开发知识,和反汇编没有关系,但是是理解反汇编的前提.     2.子类继承父 ...

随机推荐

  1. django中navie时间和aware时间详解

    navie时间和aware时间: 什么是navie时间?什么是aware时间? navie时间:不知道自己的时间表示的是哪个时区的.也就是不知道自己几斤几两.比较幼稚. aware时间:知道自己的时间 ...

  2. React生命周期中应该做什么事

    React生命周期函数 装载组件触发 0.construct(props) 用来 props--->state 初始化state,并且把props转化为state 1.componentWill ...

  3. SQL Server 2017 下载及安装详细教程

    SQL Servicer 2017 下载及安装 1)下载安装SQLServer 2)安装SQLServer management Studio. 一.     下载及安装SQLServer 下载链接( ...

  4. C# 静态方法中获取类的名称

    静态方法中用: string className = System.Reflection.MethodBase.GetCurrentMethod().ReflectedType.FullName; 非 ...

  5. 【转载】C#如何往DataTable中新增一个数据列

    在C#中的Datatable数据变量的操作过程中,有时候我们需要往现有的DataTable中新增一个自定义数据列,该列在原有的DataTable变量中并不存在,属于用户手工自定义新增的数据列,在往Da ...

  6. Django:RestFramework之-------分页

    9.分页操作 分页,看第n页,每页显示n条数据 分页,在n个位置,向后查看n条数据. 加密分页,上一页和下一页 1.基于PageNumberPagination分页 1.路由: url(r'^(?P& ...

  7. Springboot+Mybatis的逆向工程

    Mybatis逆向工程,自动生成 entity类和常用的增删改查方法. 1.pom.xml引入类 <!-- 通用mapper 用于mabatis封装的基础增删改查的功能--><dep ...

  8. 解决vant-weapp组件库的example的导入问题

    最近在学习小程序,看到了vant-weapp这个组件库,我比较喜欢边看示例边来敲代码.刚好这个组件库下载下来有 example的文件夹.废话不多说,现在来看看怎么在开发工具里面导入吧! 步骤: 1.下 ...

  9. 【Maven】Maven中排除依赖、归类依赖、优化依赖

    参考博文:Maven中排除依赖.归类依赖.优化依赖

  10. CentOS6.7搭建部署FTP服务 (详解主配置文件)

    FTP传输 三种解析: username -->UID  :/etc/passwd    将用户名转换成UID的库. hostname--->        IP   :DNS服务,/et ...