来源:冰河技术 在Java语言出现之前,敢说根本过J个功很多系统都是没项目中使用C和C++开发的。Java出现之后,使用由于其面向对象的敢说根本过J个功思想更加符合人们的思维习惯,Java也不用像C和C++那样需要程序员手动管理内存的没项目中分配和回收。说白了,使用就是敢说根本过J个功简单好用。由于Java的没项目中诸多优点,使其一跃霸榜编程语言前排很多年。使用 为了能够和使用C和C++写的敢说根本过J个功程序进行交互,Java提供了本地方法的没项目中特性,也就是使用我们常说的JNI技术,然而,敢说根本过J个功随着互联网的没项目中高速发展,分布式、使用微服务、大数据、云计算等技术和框架层出不穷,大多数支持多语言的框架基本上都是都过RPC或者Restful API进行调用。JNI这项Java中提供的高防服务器强大功能,却逐渐的被人遗忘了。 最近,冰河在分析500多TB的数据,从500多TB的数据中分析用户的行为习惯,以便为用户提供更好的产品体验和推荐更加适合用户的产品。然而,在实现算法的过程中,使用Java语言开发的算法从500多TB的数据中,单独分析某个用户某段时间的行为时,耗费了极大的时间开销。无论我如何优化算法,都不能达到预期的效果。很显然,这不符合性能要求。 一名小伙伴对我说:试试C语言嘛。对啊!我为啥不试试用C语言写算法啊,于是乎,使用C语言写了算法,站群服务器经过不断的优化和调整,算是初步达到了算法性能要求。但是向数据大屏展示数据的时候,后端还是要以微服务的形式部署,于是我想到了Java中的JNI技术 注:后面单独写一篇我是如何分析500多TB数据的。 先说说使用JNI时有哪些坑吧,以避免小伙伴们重复踩坑,这里,大家需要注意的是:在使用JNI技术调用dll动态链接库时,32位dll只能是32位JDK去调用,64位dll只能是64位JDK去调用。这个必须是这样的,如果发现无法调用或者提示版本错误,首先要检查下JDK的位数和dll的位数是否是云服务器对应的。 为了能够让小伙伴们顺利的按照文章开发出自己的JNI程序,这里,我就详细的说下如何开发一个JNI程序,主要分三个大的方面来说明如何使用JNI技术调用C和C++写的程序。 注意:本文中我使用的是jna Java类库实现JNI开发。 VS新建项目 输入项目名称 选择空项目,点击完成 创建完成后,将下面这段代码复制进去: ; ; ; ; ; ; ; { a + b; } { a*b; } { ; (a,b); } 这里要注意的是:java的String和cpp的String不一样的,其对应的是char,如果要用cpp的string不是乱码就是调用失败。 这里变成Release,点击配置管理器配置x64版本,这样生成的dll就是x64版本的,这点非常重要。 配置完成以后右击项目点击生成按钮。 这一顿操作下来,基本就能够正确的生成dll了,如果不能生成,极有可能是你的姿势不对,照着文章重新弄一遍,如果还是不行,你就加我微信(hacker_binghe)问我吧。 VS生成的dll文件在哪个位置呢?别急,我们继续。 右击项目 这里要注意的是在上级目录!不要想当然打开的项目位置然后直接就去x64去找了,根本没用!里面没有dll,是在上级目录,上级目录 的x64位置。 新建Maven项目后,在Maven的pom文件中引入如下依赖。 我个人就放在这个lib包下面,这样导入这个包的时候可以写绝对路径也可以写相对路径。 注意:这里定义的接口方法名称需要和dll中的方法名称一致。 com.binghe.jni; com.sun.jna.Library; com.sun.jna.Native; / binghe : 测试JNI程序 { { , ; ; ; ; } { )); )); )); } } 直接运行main方法,得到如下输出结果。为何使用JNI
如何使用JNI
开发dll动态链接库
使用VS开发dll
使用VS生成dll
开发Java程序
导入Maven依赖
指定dll位置
编写代码
运行Java程序