Delphi D10.X 在安卓APP开发中使用Jar包的注意事项

Mangena ·
更新时间:2024-11-14
· 610 次阅读

写完上一篇博客《对于《关于使用Delphi XE10 进行android开发的一些总结》的补充》考虑了一下,应该把一些在开发安卓APP时使用到JAR包的注意事项也再讲一下。
请注意:这里是一些注意事项,或说“在开发过程中可能遇到的坑”,不是具体的怎么做JAR的调用开发。

需要准备的一些工具

工欲善其事必先利其器,以下这些工具对你开发会起到帮助作用的。当然,不用工具也是可以的,只要你愿意,什么事会做不到呢。这里只讲需要什么,不讲具体使用方法,怎么使用,可以自己学习一下。

JNI桥接文件生成工具

生成Jni桥接文件的工具,当然如果你够强大,不用工具自己也是可以写桥接文件的,工具只是辅助而已。(工具有Java2OP,Java2pas,老猫的JarOrClass2Pas,还有一个是我自己使用没发布的工具)

APK逆向工具

apk逆向工具,直白的说就是将apk反编译成java源码(classes.dex转化成jar文件),例如dex2jar。为啥?为了可能学习DEMO里的使用方法。你可能没有JAVA源码,怎么办,就反编译后看了。

JAVA反编译工具

JAVA反编译工具,就是反编译Jar:例如jd-gui.exe,两个目的:

可以查看JAR里接口真实的调用方式。为什么要看?因为你可能在开发文档里看到写的某接口需要2个参数(或参数是某某类型),但是怎么调用怎么错,你就开始怀疑人生怀疑Delphi有问题了。某些朋友可能会问,Jni那个桥接文件是工具生成的,与JAR里的应该一样,也就可以不用看JAR里的情况了。确实如此,绝大多数情况下是这样的,也需要注意上述几个工具在某些时候对同一个JAR生成桥接文件的内容会出现差异。 当你没有JAVA版DEMO源码时,可以反编译他的DEMO程序,从而查看他的DEMO里怎么使用JAR里的接口,前面讲的一条你可以不需要去查看,但DEMO里的使用方式你一定会要看的。 JAVA的APK开发工具

这个不是必要的,有的话可能会好一些。当你有JAVA版本源码的时候,查看起来会更方便一些。

monitor安卓调试器

安卓调试器,可以查看APP运行时的一些日志、异常等等,不是必须使用的,有会比没有好。

需要准备的知识 Delphi开发安卓的知识

首先你得会使用DELPHI开发安卓程序,其次得在这个前提下知道怎么加入JAR包,怎么发布。

JAVA基础知识

这里包括一些简单的JAVA开发APP的基础知识,也包括能理解(能猜都行)JAVA源码的知识,不然有时候可能都看不懂文档里的内容,更看不懂JAVA代码了。一些简单的可以通过某些案例去模仿,再复杂的可能就模仿不了的。

深入的JAVA知识

知道怎么写JAVA代码,并可以生成自己的JAR包。这点使用到的不多,但也是可能遇到的,因为JAR包是为JAVA准备的,不会考虑到其他语言的使用。我遇到过的可能在5%左右,你可能需要去修改JAR包(不推荐),也可能需要写一段JAVA代码来过渡(这都是真实发生过的)。

填坑

以下就是可能遇到的坑,及解决(避免有坑)方法之一(因为可能会有其他更好的解决)。

准备好资料

做开发前,一定向第三方(JAR提供方)索要JAR对应的开发文档及开发好的DEMO,最好有源码。某些供应商不给源码的,也可能是给不出源码。如果没有这些东西,那你做好骂人的准备。
其次,在拿到这些资料后,要检查正确性,例如:对应的版本是否正确,资料是否完整。怎么检查?一是看对应日期,看文档资料里的对应版本号说明(某些做得不好的文档可能不会有),二是要检查提供的DEMO是否能正常运行,安装到手机(PDA)上试功能;三是要检查APP里包含的JAR包与单独给你的JAR是不是同样的版本,解压APK,对比APK里JAR与给你的JAR的大小、日期。
一定不要相信提供商给你的东西是匹配的,因为,他可能只是一个售后或售前人员,不懂技术,他拿到手的资料可能都是错的。也可能是提供商的技术人员懒,更新了程序没更新文档,更新了APK没更新JAR;也可能是提供商管理不规范,自己的资料都乱七八糟。反正原因众多,我也不去猜。

其次是快速验证

这个方法你可以不用,也可以使用,我自己经常这样处理。先不要直接应用到你的系统中,特别是已有的系统。
生成JNI桥接文件后,新建一个程序,加入桥接文件,先处理掉可能出现的错误,保证桥接文件的正确。(空项目+JNI的PAS可以编译通过,不作任何调用)。多说一句,JNI不需要把所有的JAR都做桥接的,可以只做主要的JAR,更精简的只做需要的类就行了,其他的就算有错误,删除就好(前提需要你了解桥接文件结构)。
然后忽略那些业务逻辑,直接测试调用JAR里的接口,这里就可能会使用到前面说的那些工具与知识了。这里用得最多的就是各种对应数据类型的转换,这些都只是技术问题,不是坑。
坑就在上一步得到的资料上,资料错误、资料不全,不能指导你完成开发、或错误的指导你开发,解决办法就是以正确的DEMO代码为主,看Demo里的JAVA代码,再结合文档资料参考对应。再后面是查看JAR包里的代码,检查桥接文件的正确性。
开发过程中,90%以上的坑是来自于这些资料,其中包括有资料的错误,也包括有你阅读的理解错误。解决办法就是多看、多想、多比较,要有较为全面的技术知识。
10%以内是桥接文件有问题(包括需要修改JAR包或增加JAVA代码过渡调用的),这样的问题其实不太多,主要是生成的时候需要处理一下,能编译通过后的基本也不会有太多的问题。
还有一个,也是最最小的几率是delphi自身的BUG(或说考虑不全面)。例如:通常delphi里做JAVA类的实例化时使用init方法,如果在JAVA类里又有一个名为init的方法,那肯定会出错的(这是一个真实的案例,最后我是修改delphi的代码来解决的)。当然,还会有其他BUG,我到目前至少修改过2处以上。
所以,有问题后,首先排除不是自己不会使用的情况外,先就不要怀疑是DELPHI的问题。更不要把自己的问题说成是DELPHI的问题,当然DELPHI没能够按照你的思维、没能按照你的想法去做,那是他大错特错,你应该果断的鄙视他,抛弃他。我就不挽留你了。

完成接口开发

上面的都做好后,你应该新建一个正式的项目(或是在已有的项目中),再根据delphi的规范去封装(某些功能最好能先封装好,系统里再直接调用),完成自己系统的开发。

总结

Delphi调用JAR包,最主要的工作不是花在了写代码上,而是完成这几行代码的过程中。
Delphi调用JAR包,需要的知识面可能较为广泛,也较为深入,具体需要多广多深入,是由你要使用的JAR包及提供的相应资料来确定。
Delphi调用JAR包,多想、多看、多检查、多试验,多学习。

终极解决办法

这可能是最简单的解决办法,那就是花钱找我帮你解决。这是解决办法之一,也可能是一个广告(可能对你有用的信息,有时候也不应该称为大众理解的广告)。

欢迎光顾本人小店:(https://shop63778938.taobao.com/) 小店也提供delphi方面其他技术支持、定制开发。

现在就进店看看

以上信息对您有用的话请点赞收藏,就下面这行


作者:tanqth



安卓app开发 jar包 delphi d1 jar app

需要 登录 后方可回复, 如果你还没有账号请 注册新账号