使用斐波那契(Fibonacci)数列来测试各大语言的性能

笔者使用最多的语言是C++,目前项目中在使用Go,也使用过不少其它语言,像Erlang,Python,Lua,C#等等。最近看到C#夺冠,首次荣获 TIOBE 年度编程语言,同时也看到网上有不少Java与C#之争的文章,于是就想要来做一个性能比较。

这里参与性能比较的是以下几门语言:Go、C#、Java、Python、Erlang。这些语言或语言标准库本身都提供了大数计算的支持,不需要自己实现大数计算或者找额外的库来实现大数计算。

笔者选取计算斐波那契(Fibonacci)数列来做性能比较,可能会有局限性,仅作参考。斐波那契数列是指这样一个数列:1,1,2,3,5,8,13,21,34,55,89……这个数列从第3项开始 ,每一项都等于前两项之和。为了达到一定计算量,但又不会费时太久,笔者以计算100万次斐波那契(Fibonacci)数列的耗时来作为依据。

一、测试环境

项目参数
CPU11th Gen Intel® Core™ i7-11700 @ 2.50GHz
内存32G
硬盘WD NVMe SSD
操作系统Windows 10 22H2

二、各语言源码

1、Go源码

GO版本为1.12.5

package mainimport ("fmt""math/big"
)func main() {a := big.NewInt(1)b := big.NewInt(1)sum := big.NewInt(0)for i := 0; i < 1000000; i++ {sum = sum.Add(a, b)b.Set(a)a.Set(sum)}fmt.Println(sum)
}

2、C#源码

C#选择的是.net 8.0.101

using System.Numerics;BigInteger a = new BigInteger(1);
BigInteger b = new BigInteger(1);
BigInteger sum = new BigInteger(0);
for (int i = 0; i < 1000000; i++)
{sum = a + b;b = a;a = sum;
}Console.WriteLine(sum);

3、Java源码

Java版本是21.0.1

import java.math.BigInteger;public class t {public static void main(String[] args) {BigInteger a = BigInteger.valueOf(1);BigInteger b = BigInteger.valueOf(1);for (int i = 0; i < 1000000; i++) {BigInteger sum = a.add(b);b = a;a = sum;}System.out.println(a.toString());}
}

4、Python源码

python版本是3.11.7

import syssys.set_int_max_str_digits(1000000)
a = 1
b = 1
sum = 0
for i in range(0, 1000000):sum = a + bb = aa = sumprint(sum)

5、Erlang源码

erlang版本是:otp_win64_26.2.1

-module(app).-export([main/1]).fibonacci(A, B, 1) ->A+B;
fibonacci(A, B, N) ->fibonacci(A+B, A, N-1).main(_) ->V = fibonacci(1,1, 1000000),io:format("~w", [V]),ok.

二、使用VSCode Code Runner测试

由于有些语言有缓存,所以都以多次执行结果较少耗时的为准:

1. Go

go run main.go

在这里插入图片描述

2. C#

dotnet run

在这里插入图片描述

3. Java

javac t.java && java t

在这里插入图片描述

4. Python

set PYTHONIOENCODING=utf-8 && python.exe -u main.py

在这里插入图片描述

5. Erlang

escript app.erl

在这里插入图片描述

三、使用命令行测试

1. go

time go run main.go

在这里插入图片描述
使用go build main.go编译成exe后再运行time ./main

在这里插入图片描述

2. C#

time dotnet run
在这里插入图片描述

直接执行生成的exe:

在这里插入图片描述

3. Java

time java t

在这里插入图片描述

4. Python

time python main.py

在这里插入图片描述

5. Erlang

先编译erlc app.erl,再执行time erl -noshell -s app main 0 -s init stop

在这里插入图片描述

四、结果统计

语言Code Runner结果Code Runner 执行的命令命令行编译运行结果命令行编译运行的命令命令行直接运行结果命令行直接运行的命令
Go3.548秒go run main.go3.539秒time go run main.go3.068秒time ./main
C#10.295秒dotnet run10.075秒time dotnet run9.255秒time ./ConsoleApp
Java10.654秒javac t.java && java t//9.814秒time java t
Python5.939秒set PYTHONIOENCODING=utf-8 && python.exe -u main.py5.943秒time python main.py//
Erlang13.353秒escript app.erl//12.836秒time erl -noshell -s app main 0 -s init stop

从结果可以看出,Go作为后起的名门之秀,在此项测试中是遥遥领先;C#在没有使用.net 8的AOT特性的情况下,依旧是略胜Java一筹,相信如果使用了AOT,可能会更快,但是其编译速度相比JAVA有点拖后腿;Erlang作为老牌并发编程语言,虽然近几年不断发展,但是在执行效率上还是有待提高;让人大跌眼镜的是Python,在传统认知中Python是应该比C#和JAVA慢的,但是出人意料的是比他们俩都快不少。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.hqwc.cn/news/410447.html

如若内容造成侵权/违法违规/事实不符,请联系编程知识网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

Vue实战:两种方式创建Vue项目

文章目录 一、实战概述二、实战步骤&#xff08;一&#xff09;安装Vue CLI脚手架1、从Node.js官网下载LTS版本2、安装Node.js到指定目录3、配置Node.js环境变量4、查看node版本5、查看npm版本6、安装Vue Cli脚手架7、查看Vue Cli版本 &#xff08;二&#xff09;命令行方式构建…

三、Sharding-JDBC系列03:自定义分片算法

目录 一、概述 1.1、分片算法 精确分片算法 范围分片算法 复合分片算法 Hint分片算法 1.2、分片策略 标准分片策略 复合分片策略 行表达式分片策略 Hint分片策略 不分片策略 二、自定义分片算法 - 复合分片算法 (1)、创建数据库和表 (2)、自定义分库算法 (3)、…

阿里云国外云服务器地域、收费标准及活动报价2024新版

阿里云国外服务器优惠活动「全球云服务器精选特惠」&#xff0c;国外服务器租用价格24元一个月起&#xff0c;免备案适合搭建网站&#xff0c;部署独立站等业务场景&#xff0c;阿里云服务器网aliyunfuwuqi.com分享阿里云国外服务器优惠活动&#xff1a; 全球云服务器精选特惠…

Centos7安装K8S

Centos7安装K8S 安装过程中没有出现的错误可以往下 根据以前一些博主写的博客&#xff0c;在小阳翻了不下几十篇博客之后&#xff0c;我果断是放弃了&#xff0c;于是找到了官网地址&#xff0c;然后也有坑 1. 关闭防火墙 systemctl stop firewalld systemctl disable firew…

33、病隙随笔——浅聊脑机接口BCI

上周得了支原体和甲流&#xff0c;吃了特效药&#xff0c;现在好的七七八八了&#xff0c;目前不少小伙伴问我怎样入门BCI领域。脑机接口是一个很大的概念&#xff0c;有很多的方向&#xff0c;但是我个人认为&#xff0c;脑机接口入门需要的必备知识有&#xff1a; 1.python数…

JVM实战(14)——Young GC调优

作者简介&#xff1a;大家好&#xff0c;我是smart哥&#xff0c;前中兴通讯、美团架构师&#xff0c;现某互联网公司CTO 联系qq&#xff1a;184480602&#xff0c;加我进群&#xff0c;大家一起学习&#xff0c;一起进步&#xff0c;一起对抗互联网寒冬 学习必须往深处挖&…

Redis-redis.conf配置文件中的RDB与AOF持久化方式的详解与区别

RDB&#xff08;Redis Database&#xff09; RDB是Redis的默认持久化方式&#xff0c;它将内存中的数据以二进制格式写入磁盘&#xff0c;形成一个快照。RDB持久化有以下几个重要的配置选项&#xff1a; save&#xff1a;指定了保存RDB的策略&#xff0c;默认的配置是每900秒&…

【STM32】STM32学习笔记-USART串口收发HEX和文本数据包(29)

00. 目录 文章目录 00. 目录01. 串口简介02. 串口收发HEX数据包接线图03. 串口收发HEX数据包示例104. 串口收发HEX数据包示例205. 串口收发文本数据包接线图06. 串口收发文本数据包示例07. 程序示例下载08. 附录 01. 串口简介 串口通讯(Serial Communication)是一种设备间非常…

Oracle-java下载、开源/商业许可证(收费、免费说明)、版本发布日志

Oracle-java下载、开源/商业许可证&#xff08;收费、免费说明&#xff09;、版本发布日志 下载开源/商业许可证&#xff08;收费、免费说明&#xff09;java8版本发布日志以上是一般情况&#xff0c;具体的以官网发布信息为准例如&#xff1a; JDK17某些特定版本是免费的&…

OceanBase集群部署

我认为学习一个中间件比较好的方式是&#xff0c;先了解它的架构和运行原理&#xff0c;然后动手部署一遍&#xff0c;加深对它的了解&#xff0c;再使用它&#xff0c;最后进行总结和分享 本篇介绍OceanBase部署前提配置和集群部署 1.使用开源免费的社区版&#xff0c;企业版…

评论转换输出 - 华为OD统一考试

OD统一考试 分值: 200分 题解: Java / Python / C++ 题目描述 在一个博客网站上,每篇博客都有评论。每一条评论都是一个非空英文字母字符串。 评论具有树状结构,除了根评论外,每个评论都有一个父评论。当评论保存时,使用以下格式: 首先是评论的内容; 然后是回复当前…

【计算机网络】内容整理

概述 分组交换 分组交换则采用存储转发&#xff08;整个包必须到达路由器&#xff0c;然后才能在下一个链路上传输)技术。 在发送端&#xff0c;先把较长的报文划分成较短的、固定长度的数据段。 电路交换 在端系统间通信会话期间&#xff0c;预留了端系统间沿路径通信所需…