第十九章 调用Callout Library函数 - 将 $ZF(-5) 与多个库和许多函数调用一起使用
作者:mmseoamin日期:2024-02-06

文章目录

  • 第十九章 调用Callout Library函数 - 将 $ZF(-5) 与多个库和许多函数调用一起使用
  • 将 `$ZF(-5)` 与多个库和许多函数调用一起使用

    第十九章 调用Callout Library函数 - 将 $ZF(-5) 与多个库和许多函数调用一起使用

    将 $ZF(-5) 与多个库和许多函数调用一起使用

    Method GraphSomeData(loopsize As %Integer=100000) As %Status
     {
       // load libraries and get system-defined ID values
       set InputLibID = $ZF(-4,1,"c:\intersystems\iris\bin\inputlibrary.dll")
       set OutputLibID = $ZF(-4,1,"c:\intersystems\iris\bin\outputlibrary.dll")
       set fnGetData = $ZF(-4,3,InputLibID,"GetData")
       set fnAnalyzeData = $ZF(-4,3,OutputLibID,"AnalyzeData")
       set fnPlotPoint = $ZF(-4,3,OutputLibID,"PlotPoint")
       set fnWriteData = $ZF(-4,3,OutputLibID,"WriteData")
       // call functions from each library until we have 100000 good data items
       set count = 0
       do {
          set datapoint = $ZF(-5,InputLibID,fnGetData)
          set normalized = $ZF(-5,OutputLibID,fnAnalyzeData,datapoint)
          if (normalized'="") { set flatdata($INCREMENT(count)) = normalized }
       } while (count
          set list = $ZF(-5,OutputLibID,fnPlotPoint,flatdata(point))
          set x = $PIECE(list,",",1)
          set y = $PIECE(list,",",2)
          set sc = $ZF(-5,OutputLibID,fnWriteData,flatdata(point),x,y,"outputfile.dat")
       }
       set status = $ZF(-4,2,OutputLibID)   //unload "outputlibrary.dll"
       quit 0
     }
    
    • 对 $ZF(-4,1) 的调用将标注库 inputlibrary.dll 和 outputlibrary.dll 加载到虚拟内存中,并为其返回系统定义的库 ID。

    • 对 $ZF(-4,3) 的调用使用库 ID 和函数名称来获取库函数的 ID。返回的函数 ID 实际上是 ZFEntry 表序列号(请参阅上一章中的“创建 ZFEntry 表”)。

    • 第一个循环使用 $ZF(-5) 调用每个库中的函数:

      • inputlibrary.dll中的 GetData() 函数从某个未指定的源读取原始数据。
      • outputlibrary.dll 中的AnalyzeData() 函数可以对原始数据进行标准化,也可以拒绝它并返回一个空字符串。
      • 每个标准化数据点都存储在 flatdata(count) 中(其中第一次调用 ObjectScript 函数 $INCRMENT 创建 count 并将其初始化为 1)。

        默认情况下,循环获取 100000 个项目。由于两个库都已加载并保留在内存中,因此在两个不同库之间切换没有处理开销。

        • 第一个循环结束后,不再需要库 inputlibrary.dll,因此调用 $ZF(-4,2) 来卸载它。库outputlibrary.dll将保留在内存中。
        • 第二个循环处理数组 flatdata 中的每个项目并将其写入文件中某个未指定的位置:
          • 库函数 PlotPoint() 读取该项目并返回一个以逗号分隔的字符串,其中包含将绘制该项目的坐标(有关库函数如何返回多个输出参数的说明,请参阅“链接简介”)。
          • $PIECE 函数用于从字符串中提取坐标值 x 和 y。
          • 库函数 WriteData() 将项目和坐标存储在文件 outputfile.dat 中,其他应用程序将使用该文件来打印图形。
          • 第二个循环完成后,再次调用 $ZF(-4,2) 来卸载库outputlibrary.dll。

            以下部分介绍 $ZF(-6) 接口,它将库加载到与 $ZF(-5) 接口相同的虚拟内存空间中。