// 把 AccountToTable 引用传递给 导出函数 (接口)
// 主関数でテストする
main ((() {の関数について
var p = $.NewPositionManager (新ポジションマネージャー)
p.OpenShort ((MA701, 1); MA701, 1); MA701, 1; MA701, 1; MA701, 1; MA701, 1; MA701, 1); MA701, 1; MA701, 1; MA701, 1; MA701, 1;
p.OpenShort ((MA705, 1); MA705, 1); MA705, 1; MA705, 1; MA705, 1; MA705, 1; MA705, 1); MA705, 1; MA705, 1;
ログ (p.GetPosition (MA701,PD_SHORT));
ログ ((p.GetAccount ((());
ログ ((p.Account (());
スリープ ((60000 * 10);
p.CoverAll (すべてカバー)
ログプロフィット (p.Profit)
ログ (($.IsTrading ((MA701)));
// 多種間では,取引列を使用して非ブロックされた取引タスクを完了します
ワルQ = $.NewTaskQueue (新タスクキュー)
q.pushTask ((exchange, MA701, buy, 3, function ((task, ret) { // 最後の参数 function ((task, ret) {...} は,呼び出し関数として送信されたタスクオブジェクトtaskとして使用される匿名関数である.
Log ((task.desc,ret) // 呼び出し関数では,このタスクの記述と,タスクが完了した値が返されます.これらは既定であり,すぐに実行されません.
if (ret) { と表示される
q.pushTask ((exchange, MA701, closebuy, 1, 123, function ((task, ret) { // は,最初の押し入りのキューのタスクの呼び戻し関数で,押し入りのタスクをタスクキューにマッチするタスクを実行するために使用される.
// 最初のタスクトランザクションが完了すると,呼び戻し関数のマッチング操作を起動します.
Log (q,task.desc,ret,task.arg) は,他の言語で表示されている.
(笑)
{cH00ffff}
(笑)
変数について説明します
//空き時に poll を呼び出し,未完成のタスクを完了します
q.poll (英語)
スリープ ((1000)
{cH00ffff}
{cH00ffff}
- #### 通篇看完,我想你们应该对这个模块有了一定的了解。
这个模块代码分两种 模式:
- 1、单品种的交易模式
这个只能用于一个品种的商品期货合约的买卖处理,整体流程是线性的。
- 2、多品种模拟并发交易模式:
这个就可以用来做多品种的策略,比如多品种的海龟交易法。(多品种的好处就是分散资金,一定程度上控制风险。)
这个模式的设计思路就是遇到任何错误都不等待重试,马上返回对应的错误码,这样多个任务执行时,虽然程序执行流程还是线性的。但是都已很快的速度执行,不独占过多时间,类似CPU并发机制。并且各个任务都有自身的变量寄存数据结构,在错误返回后再次执行的时候会继续任务的执行直到完成,模拟出并发执行的效果。适合用于多品种策略系统使用(各品种交易在时间序列上的互相影响降至较低程度)。
并且使用了回调函数,在任务完成时可以自动触发一些设计好的代码。
这种思路很值得学习。
下一篇,我们会用这些JS代码创造出一个真正的策略。
#### 先写到这,欢迎读者给我留言!提出建议和意见,如果感觉好玩可以分享给更多热爱程序热爱交易的朋友
https://www.fmz.com/bbs-topic/737
### 程序员 littleDream 原创