测试:
耗时:0.015秒,消费时光包含:过程cat读出文本
经由过程管道将数据传入Golang
go处理数据,将结不雅返回到屏幕
经由过程比较测试,计算出各个流程占用的时光。下面提到的title.txt文件,包含100万行文本,每行文本是大年夜b2b平台取的商品标题
1: 整体流程耗时#timecat title.txt | ./test > /dev/null
耗时:14.819秒,消费时光包含:过程cat读出文本
经由过程管道将数据传入Golang
Golang处理数据,将结不雅返回到屏幕
2:计算分词函数耗时。筹划:去除分词函数的调取,即:注释掉落Golang源代码中的调取分词那行的代码timecat title.txt | ./test > /dev/null
耗时:1.817秒时光,消费时光包含:过程cat读出文本
经由过程管道将数据传入Golang
Golang处理数据,将结不雅返回到屏幕
分词耗时 = (第一步耗时) - (以上敕令所耗时)
分词耗时 : 14.819 - 1.817 = 13.002秒
3:测试cat过程与Golang过程之间通信所占时光timecat title.txt > /dev/null
好吧,也许你已经发明,我是标题档,这里重点要讲的并不只是PHP与Golang若何通信。而是在介绍一种办法: 经由过程双向管道让随便率性说话通信。(所有说话都邑实现管道相干内容)
管道通信耗时:(第二步耗时) - (第三步耗时)
管道通信耗时: 1.817 - 0.015 = 1.802秒
4:PHP与Golang通信的时光消费
编写简单的php文件:<?php
$descriptorspec = array(
0 => array("pipe","r"),
1 => array("pipe","w")
);
$handle = proc_open(
'/webroot/go/src/test/test',
$descriptorspec,
$pipes
);
$fp = fopen("title.txt","rb");
while (!feof($fp)) {
fwrite($pipes['0'], trim(fgets($fp))."\n");
echo fgets($pipes[1]);
}
fclose($pipes['0']);
fclose($pipes['1']);
proc_close($handle);
流程与膳绫擎根本一致,读出title.txt内容,经由过程双向管道传入Golang过程分词后,再返回给php (比膳绫擎的测试多一步:数据再经由过程管道返回)timephp popen.php > /dev/null
耗时:24.037秒,消费时光包含:过程PHP读出文本
经由过程管道将数据传入Golang
推荐阅读
5 月 27 日,由机械之心主办的为期两天的GMIS 2017 大年夜会在北京拉开帷幕。据悉,浩瀚来自瑞士、美国、加拿大年夜以及国内的浩瀚人工智能学术大年夜咖、业界大年夜牛都邑表态GMIS的舞台>>>详细阅读
地址:http://www.17bianji.com/lsqh/35483.html