当前位置: 首页 > news >正文

编绎和优化,脚本代码小米加步枪赶超英法美

编程达人:冰冻牡蛎 测试,总结》》

今有空,继续看了一下竹笋大师几天前提出的“使用for循环查找10亿内可被7整除的数的个数”的题目(相关文件:群文件 10亿以内多少个数字可以整除7.7z )

1. 论输出的exe大小,purebasic最小;其它编译器输出的exe比它大, 甚至大很多——毫无疑问,大家知道我是说GO。工具/语言nelua(使用的是扩展版的lua语言)、shedskin(使用的是python的子集)、nim、freebasic、purebasic、rapideuphoria都是借助gcc;所以,“都是借助GCC,没有可比性”就是胡扯

2. 同是输出C之后、再调用gcc编译为exe,工具/语言nelua(使用的是扩展版的lua语言)、shedskin(使用的是python的子集)、nim、freebasic1.09、rapideuphoria产生的exe,与C版本的速度一致;但是purebasic速度慢得多(耗时是前排队友的17倍)。所以,“都是借助GCC,没有可比性”就是胡扯——还都是上班呢,马云那么多钱,我却是个穷屌丝

3.  对于freeebasic,1.09版本消耗的时间,是1.06版本的1/2

4.  对于purebasic,5.73和6.02版本消耗的时间大致一样

5. purebasic版本耗时,与freepascal版本接近;比freepascal版本略微慢一点

6. 对于脚本,官方lua版本速度,至少是官方python版本的2.8倍

7. 对于脚本,pypy版本速度,是luajit版本的1.2-3倍

8. purebasic/freepascal版本速度是luajit/pypy的3-5倍

9. 同为pascal系,PascalABC.NET版本速度,是freepascal版本的7.5倍以上

10. 同是.NET上的语言,可以输出.NET的exe,PascalABC.NET版本速度,是 IronPython版本的30倍~几百倍

11. 同是.NET、且可以输出.NET的exe的语言,PascalABC.NET版本只输出一个exe,可以直接发布到有.NET Framework的电脑上运行;但是IronPython版本输出的exe,依赖好几个DLL

12. 多数语言的耗时,是随着查找范围增大,而大致线性增加——这符合预期。但是,这里中出了3个叛徒
12.1 对于luajit,20亿的速度比10亿、30亿都多得多
12.2 官方python的速度,随数字增大,耗时多得可怕
12.3 对于Ironpython,随数字增大,耗时多得可怕,且不是简单线性

http://www.lryc.cn/news/145206.html

相关文章:

  • 数字电路-二进制学习
  • 运维Shell脚本小试牛刀(一)
  • screen命令,可以断开服务器连接,依旧能运行你的程序了
  • 【ArcGIS Pro二次开发】(63):批量更改字段别名
  • redis全套参数配置及降级解决方案
  • AMD即将上市大量中端显卡,为新显卡支付过高价格的日子可能结束
  • go学习一之go的初体验
  • 智能制造产业链数字化转型、数字化互联工厂建设方案PPT
  • 【安卓】拿注册码的两种方式
  • 【C++】—— 异常处理
  • cookie和session是什么,区别是什么?
  • linux的mmc子系统与块设备关联
  • 【Spring MVC】
  • 【ES】笔记-生成器函数与调用
  • 将Spring Boot与Redis集成
  • vue echarts
  • idea上利用JDBC连接MySQL数据库(8.1.0版)
  • 【100天精通python】Day47:python网络编程_Web编程基础
  • DockerCompose介绍与使用
  • Windows Qt 5.12.10下载与安装
  • RustDesk最新版本编译与打包
  • Gin 框架入门实战系列(一)
  • 【测试】pywinauto的简单使用(安装、常用对象、元素控件、鼠标操作、键盘操作)
  • Java基础十八(正则表达式 + 日期时间)
  • Linux C 多进程编程(面试考点)
  • c++一级
  • Code Lab - 34
  • 后端返回文件流,前端怎么导出、下载(8种方法可实现)
  • 什么是 ThreadLocal?
  • CANOCO5.0实现冗余分析(RDA)最详细步骤