aardio 文档

aardio 范例:aardio.CallJson

//aardio.CallJson
import golang;
var go = golang();//创建 Go 编译器( 仅调用编译的 DLL 不需要此扩展库 )

//Go 与 aardio 一样,源码与字符串默认为 UTF-8 编码
go.main = /**********
package main

import "C" 
import "aardio" //源文件: ~\lib\golang\.res\aardio\aardio.go

//export TestCallBack 
func TestCallBack(fnCallback uintptr) int{

    var s = "字符串"

    /*
    回调 aardio 用 raw.jsonCall 创建的函数指针。
    支持可变参数(使用 JSON 自动转换参数),aardio 函数返回 null 或 int 类型整数值 。
    aardio.CallJson() 返回类型为 (int,error)。

    注意:aardio 与 Go 导出函数所在的默认 goroutine 之间的互调属于同一线程(这里不用考虑多线程)。
    */
    var r,_ = aardio.CallJson(fnCallback,s,123,map[string]int{"id": 1, "id2": 2} )

    return r
}

func main() {} 
**********/

//上面的 go.main 会自动保存到文件,然后编译 Go 源码生成同名 DLL 文件
go.buildShared("/.go/CallJson.go");

//------------------下面调用 DLL-----------------------

import console.int;

//加载 Go 编译的 DLL,注意要指定 cdecl 调用约定
var goDll = raw.loadDll("/.go/CallJson.dll",,"cdecl");

import  raw.jsonCall;

//创建回调函数指针, 在 Go 中必须用 aardio.CallJson 调用。
var callback = raw.jsonCall(
    function(a,b,c){ 
        console.log("回调参数:",a,b) 
        console.dumpJson(c);
        return 123;
    } );

var ret  = goDll.TestCallBack( callback )
console.log(ret);

Markdown 格式