在软件团队开发项目中,要提高开发效率和质量,代码必然要进行封装和重用。在使用DolphinDB的脚本进行开发时,可使用module和use方法,来声明和使用可重用模块。服务器
在DolphinDB中,模块是指只包含函数定义的代码包。它具备如下特色:app
默认状况下,全部的模块定义在[home]/modules目录下,[home]由系统配置参数home决定,能够经过 getHomeDir() 函数获取。好比DolphinDB节点的home目录为:ide
/root/DolphinDB/server
那么咱们须要在该目录下建立modules子目录来保存模块文件,最终模块目录为:函数
/home/root/DolphinDB/server/modules
2.2 建立模块文件spa
在modules目录下建立以.dos为后缀的模块文件,好比FileLog.dos。模块文件的第一行必须是模块声明语句。模块声明语句的语法以下:调试
module moduleName
moduleName必须与模块文件的名称一致,好比在FileLog.dos中声明模块:日志
module FileLog
声明模块后,咱们能够开始编写模块代码。例如,FileLog.dos的内容以下:orm
module FileLog //向指定日志文件写入日志 def appendLog(filePath, logText){ f = file(filePath,"a+") f.writeLine(string(now()) + " : " + logText) f.close() }
在模块文件中,仅容许封装函数定义,其余非函数定义代码将被忽略。server
在DolphinDB中,使用use关键字来导入一个模块。注意,use关键字导入的模块是会话隔离的,仅对当前会话有效。导入模块后,咱们能够经过如下两种方式来使用模块内的自定义函数:blog
(1)直接使用模块中的函数:
use FileLog appendLog("mylog.txt", "test my log")
(2)经过完整路径来调用模块中的函数:
use FileLog FileLog::appendLog("mylog.txt", "test my log")
DolphinDB引入了命名空间的概念,支持对模块进行分类和规划。
若是咱们须要对模块进行分类,能够经过多级路径为规划模块的命名空间。例如,现有两个模块FileLog和DateUtil,它们的存放路径分别为modules/system/log/FileLog.dos和modules/system/temperal/DateUtil.dos,那么这两个模块相应的声明语句以下:
module system::log::FileLog
module system::temperal::DateUtil
4.2 调用命名空间模块
咱们能够在use关键字后加完整路径来导入命名空间下的模块。例如,导入FileLog模块:
use system::log::FileLog //全路径调用 system::log::FileLog::appendLog("mylog.txt", "test my log") //直接调用已导入模块中的函数 appendLog("mylog.txt", "test my log")
当工做机和DolphinDB服务器不是同一台机器时,咱们在工做机上编辑的模块代码,不能直接在远程服务器的DolphinDB上经过use导入,须要先将模块文件上传到[home]/modules的对应目录,才能经过use调用模块。
DolphinDB GUI从0.99.2版本开始提供了远程同步模块的功能,具体用法以下图所示:
此操做会将Modules目录下的全部文件和子目录同步到GUI链接的DolphinDB节点的[home]/modules目录下,同步完成后,就能够在Server上直接执行use代码导入模块。
不一样模块能够定义相同名字的函数。若是使用全路径调用函数,DolphinDB能够经过模块命名空间来区分函数名。若是直接调用函数:
Modules [Module1] and [Module2] contain function [functionName]. Please use module name to qualify the function.
//定义模块 module sys def myfunc(){ return 3 } //自定义函数 login("admin","123456") def myfunc(){ return 1 } addFunctionView(myfunc) //调用 use sys sys::myfunc() //调用模块的函数 myfunc() //调用模块的函数 ::myfunc() //调用自定义函数
在开发阶段调试模块代码时,开发人员须要反复修改模块代码并刷新定义,此时能够从新打开模块文件并全选执行模块代码便可,这种方法仅对当前会话有效。
6.3 模块间互相调用
模块之间能够单向引用,好比模块a 引用 b , b 引用 c。模块之间不支持交叉引用,好比模块a 引用 b, 模块b又引用a。