很多windows底层API函数是存在于动态链接库的,通过调用DLL来实现调用函数的目的。
底层api都在系统目录下的dll里面,c++就是通过调用这些动态库来调用底层API的。
下面是通过显式链接调用DLL中的Max函数的例子。
#include
#include
void main(void)
{
typedef int(*pMax)(int a,int b)
typedef int(*pMin)(int a,int b)
HINSTANCE hDLL
PMax Max
HDLL=LoadLibrary("MyDll.dll")//加载动态链接库MyDll.dll文件;
Max=(pMax)GetProcAddress(hDLL,"Max")
A=Max(5,8)
Printf("比较的结果为%d\n",a)
FreeLibrary(hDLL)//卸载MyDll.dll文件;
}
在上例中使用类型定义关键字typedef,定义指向和DLL中相同的函数原型指针,然后通过LoadLibray()将DLL加载到当前的应用程序中并返回当前DLL文件的句柄,然后通过GetProcAddress()函数获取导入到应用程序中的函数指针,函数调用完毕后,使用FreeLibrary()卸载DLL文件。在编译程序之前,首先要将DLL文件拷贝到工程所在的目录或Windows系统目录下。
*** 作方法如下:编译后安装该生成的apk即可使用该程序调用底层硬件驱动。大概整个过程就这样,上层app调用框架层的java接口,java接口通过jni调用硬件抽象层即可。
欢迎分享,转载请注明来源:内存溢出
评论列表(0条)