业务逻辑:

逐行读取一个3.6MB的文件,

把每行的字符串切割成数组,

计算二维数组中的经纬度值与目标地点的经纬度的距离,

符合限定距离范围的结果存入map中,

将结果覆盖写入一个新的文件,

计算程序执行的时间。

php版:

<?php $stime=microtime(true);const BJ_LAT = 39.9041999;const BJ_LNG = 116.4073963;const DISTANCE = 100;$handle = fopen('air_route_data.txt','rb+');$result = [];while(!feof($handle)){    $lines = fgets($handle);    $airRoute = explode(' ',$lines);    $lat = (float)$airRoute[3];    $lng = (float)str_replace(array("", "", ""), "", $airRoute[4]);    $distance = getDistance($lat,$lng);    if ($distance <= DISTANCE){        $result[$airRoute[2]] = ['lat'=>$lat,'lng'=>$lng ];    }}fclose($handle);$jsonString = json_encode($result,JSON_UNESCAPED_UNICODE);file_put_contents('bjs_route_data.txt',$jsonString);//$handle2 = fopen('bjs_route_data.txt',"w+");//fwrite($handle2,$jsonString);//fclose($handle2);$etime=microtime(true);$total=$etime-$stime;   //计算差值//echo "当前页面执行时间为:{$total} 秒";$ms = $total*1000;echo "当前页面执行时间为:{$ms} 毫秒";function getDistance($lat1, $lng1, $lat2=39.9041999, $lng2=116.4073963){    $EARTH_RADIUS = 6378.137;    $radLat1 = rad($lat1);    $radLat2 = rad($lat2);    $a = $radLat1 - $radLat2;    $b = rad($lng1) - rad($lng2);    $s = 2 * asin(sqrt(pow(sin($a / 2), 2) + cos($radLat1) * cos($radLat2) * pow(sin($b / 2), 2)));    $s = $s * $EARTH_RADIUS;    $s = round($s * 100) / 100;    return $s;}function rad($d){    return $d * M_PI / 180.0;}

没有启动nginx,走php-fpm,直接从命令行执行的。

php执行时间:

测试N次,大约在116ms左右

go版:

package mainimport ("bufio""encoding/json""fmt""io""math""os""strconv""strings""time")//北京经纬度const BJ_LAT = 39.9041999const BJ_LNG = 116.4073963const DISTANCE = 100type Location struct {Lat float64 `json:"lat"`Lng float64 `json:"lng"`}func main() {t := time.Now()fi, err := os.Open("air_route_data.txt")if err != nil {fmt.Printf("Error: %s", err)return}defer fi.Close()result := make(map[string]*Location)//result := make(map[string]Location)br := bufio.NewReader(fi)for {data, _, c := br.ReadLine()if c == io.EOF {break} airRoute := strings.Fields(string(data))lat,_ := strconv.ParseFloat(airRoute[3],64)lng , _ := strconv.ParseFloat(airRoute[4],64) if lng < 0 || lat < 0 {continue}distance := GetDistance(lat,lng , BJ_LAT,BJ_LNG)if distance <= DISTANCE {//写数据temp := new(Location)temp.Lat = lattemp.Lng = lngresult[airRoute[2]] = temp//result[airRoute[2]] = Location{lat,lng}}}//写文件jsonString, _ := json.Marshal(result)f, _ := os.OpenFile("bjs_route_data.txt", os.O_TRUNC | os.O_WRONLY , 0666) //打开文件io.WriteString(f,string(jsonString))defer f.Close() elapsed := time.Since(t)fmt.Println("当前页面执行时间为:", elapsed)}// 返回单位,千米func GetDistance(lon1, lat1, lon2, lat2 float64) (distance float64) {//赤道半径(单位m)const EARTH_RADIUS = 6378.137rad_lat1 := rad(lat1)rad_lon1 := rad(lon1)rad_lat2 := rad(lat2)rad_lon2 := rad(lon2)if rad_lat1 < 0 {rad_lat1 = math.Pi/2 + math.Abs(rad_lat1)}if rad_lat1 > 0 {rad_lat1 = math.Pi/2 - math.Abs(rad_lat1)}if rad_lon1 < 0 {rad_lon1 = math.Pi*2 - math.Abs(rad_lon1)}if rad_lat2 < 0 {rad_lat2 = math.Pi/2 + math.Abs(rad_lat2)}if rad_lat2 > 0 {rad_lat2 = math.Pi/2 - math.Abs(rad_lat2)}if rad_lon2 < 0 {rad_lon2 = math.Pi*2 - math.Abs(rad_lon2)}x1 := EARTH_RADIUS * math.Cos(rad_lon1) * math.Sin(rad_lat1)y1 := EARTH_RADIUS * math.Sin(rad_lon1) * math.Sin(rad_lat1)z1 := EARTH_RADIUS * math.Cos(rad_lat1)x2 := EARTH_RADIUS * math.Cos(rad_lon2) * math.Sin(rad_lat2)y2 := EARTH_RADIUS * math.Sin(rad_lon2) * math.Sin(rad_lat2)z2 := EARTH_RADIUS * math.Cos(rad_lat2)d := math.Sqrt((x1-x2)*(x1-x2) + (y1-y2)*(y1-y2) + (z1-z2)*(z1-z2))theta := math.Acos((EARTH_RADIUS*EARTH_RADIUS + EARTH_RADIUS*EARTH_RADIUS - d*d) / (2 * EARTH_RADIUS * EARTH_RADIUS))distance = theta * EARTH_RADIUSreturn}//转化为弧度(rad)func rad(d float64) (r float64) {r = d * math.Pi / 180.0return}

没有go build或者go install, 直接使用go run执行。

go执行时间:

测试N次,大约在45ms以上

结论:

试验过程中,尽量严谨。去除了nginx,两者没有借助web服务器启动,都是直接执行。

结果是相同的for循环10w+以上的代码逻辑,go的执行效率要比php快一倍以上。

php的一个数组解决一切数据格式问题,变量使用无需定义,数据类型和格式无需严谨,随用随定义等等特点,再加上php的web生态,已有的轮子特别多,这些决定了php做网站开发的速度是非常快的。

缺点是历史上的php4、php5遗留下的不严谨,很多开源代码框架cms有漏洞、效率、可维护等的问题。这些问题在未来的8,应该能更好的解决或者弥补。

但是,php语言本身的定位决定了执行速度的瓶颈。毕竟执行效率比go要慢。

8能达到go速度吗 php_相同逻辑的php与golang代码效率对比,最好语言落谁家…相关推荐

  1. python 速度 memmap_从20秒到0.5秒:一个使用Rust语言来优化Python性能的案例

    <从20秒到0.5秒:一个使用Rust语言来优化Python性能的案例>要点: 本文介绍了从20秒到0.5秒:一个使用Rust语言来优化Python性能的案例,希望对您有用.如果有疑问,可 ...

  2. js中怎么使用php代码高亮,PHP_如何实现正则表达式的JavaScript的代码高亮,今天想改一下JS的高亮的配色 - phpStudy...

    如何实现正则表达式的JavaScript的代码高亮 今天想改一下JS的高亮的配色,憋了一下午憋出了这个这个正则表达式. 下面这老长老长了的玩意儿是个正则表达式,看到了别吓坏了. /(\/\/.*|\/ ...

  3. Android显存到内存拷贝耗时,memcpy速度太慢?掌握这个技术让内存拷贝效率成倍提升...

    封面出自:板栗懒得很 memcpy是C/C++的一个标准函数,原型void *memcpy(void *dest, const void *src, size_t n),用于从源src所指的内存地址的 ...

  4. php单引号和双引号速度,PHP单引号、双引号用法比较和效率分析

    网上有关php单双引号的分析有很多, 在这里我简单的归纳一下. 1.定义字符串及字符串转义 var $str = 'abc1234'; var $str = "abc1234"; ...

  5. 【速度收藏】16条有趣的Python一行代码实现

    1. 引言 自从我接触了Python中一些一行代码实现后,我就被它的简单性.出色的可读性和可理解性所吸引. 在下面我将给大家展示一些看似复杂的任务,均可以使用一行Python代码就可以搞定. 希望大家 ...

  6. 语音编码 c语言,语音编解码算法G.723.1在DSP - 嵌入式新闻 - 电子发烧友网

    1 引言 G.723.1是删组织于1996年推出的一种低码率的语音编码算法标准,也是目前该组织颁布的语音压缩标准中码率最低的一种标准.G.723.1主要用于对语音及其它多媒体声音信号的压缩,目前在一些 ...

  7. 百度APP视频播放中的解码优化

    全文3514字,预计阅读时间26分钟 一.背景 在全民视频的时代,百度APP中视频播放是十分重要的业务.随着 5G 的到来,视频播放已经不满足以前的标清/高清,超清乃至于 4K 已经是旧时王谢堂前燕飞 ...

  8. 快70倍!新一代JS构建工具:ESBuild SWC浅析

    首先, ESBuild & swc是什么? ESBuild[1]是基于Go语言开发的JavaScript Bundler, 由Figma前CTO Evan Wallace开发, 并且也被Vit ...

  9. Get技能 | 嵌入式软件测试的10条秘诀

    在嵌入式软件开发过程中,花在测试和花在编码的时间比通常在3:1左右(实际上可能更多).这个比例会随着工程师编程.测试水平的提高而不断下降,但无论如何,软件测试都是嵌入式软件开发中至关重要的部分. 多年 ...

最新文章

  1. Python - json和simplejson比较(转)
  2. 本学期的选修课:动感单车
  3. 改变UITableView选中行高亮的颜色
  4. 路由器笔记 CCNA
  5. jQuery倒计时(仿团购)
  6. 算法训练+乘法表c语言,[蓝桥杯][算法提高VIP]输出九九乘法表 (C语言代码)
  7. python离散变量_python – 当涉及离散变量时,pymc3与pymc2的困难
  8. css颜色渐变 移动,CSS颜色渐变
  9. c语言 随机漫步,随机漫步理论
  10. 解决键盘老是不消失实现delegate委托实例化过程
  11. 分布式系统的概念、特点及常见方案
  12. Android代码中设置横屏
  13. linux压缩到最小命令,Linux 压缩打包命令详细教程
  14. c语言第一章复习思维导图
  15. 一筐梨子amp;一筐水果——协变性(covariant)
  16. linux下的时间 date 和 hwclock命令
  17. Android程序员春招三面蚂蚁金服,7年老Android一次坑爹的面试经历,先睹为快
  18. 基于Java毕业设计疫情下的进出口食品安全信息管理系统源码+系统+mysql+lw文档+部署软件
  19. 如何搜索和阅读一篇论文及鉴别论文好坏
  20. Functional Commitment Schemes: From Polynomial Commitments to Pairing-Based Accumulators学习笔记

热门文章

  1. php类实例化js,php中如何实例化一个类_后端开发
  2. opencv java水平投影_使用OpenCv中Mat进行水平投影与垂直投影并实现字符切分
  3. java join yield_Java多线程中join、yield、sleep方法详解
  4. 计算机原理第六章简答题,2012年4月考前串讲计算机组成原理第六章(2)
  5. java ee 导入项目_最代码网站java项目下载后遇到项目打开,导入,运行的问题QA汇总...
  6. java程序员编程过程中的基本问题
  7. 阿里DRUID数据源
  8. yarn========================(类似于node)
  9. 【转】C#3.0入门系列(九)-之GroupBy操作
  10. ICCV2021 还在用大量数据暴力train模型?主动学习,教你选出数据集中最有价值的样本...