rust为什么跑得比js慢
问题描述
实现一个计算斐波那契数列的递归函数, rust代码和js代码在我的电脑上耗时都是11秒, js甚至比rust快一点
问题出现的环境背景
本人刚接触rust,听说它的性能可以和C++媲美,所以就想比较一下到底比js快多少,可是程序跑出来的结果和想象中的不太一样,顺带一提,在我同事的电脑上用C++跑耗时7秒,当传入参数为50时,他那边C++耗时73秒,我这边rust耗时132秒,差别太大了
相关代码
rust代码:
extern crate stopwatch;
use stopwatch::{Stopwatch};
fn fid(num: u64) -> u64 {
match num {
0 => 0,
1 => 1,
_ => fid(num - 1) + fid(num - 2)
}
}
fn main(){
let sw = Stopwatch::start_new();
let num = fid(45);
println!("{}",num);
println!("耗时: {}ms", sw.elapsed_ms());
}
js代码:
function fid(n) {
if (n == 0) return 0;
if (n == 1) return 1;
return fid(n-1) + fid(n-2)
}
fib(45)
你期待的结果是什么?实际看到的错误信息又是什么?
按理来说rust的速度应该比js快很多才对吧?希望大佬们能指点一下我是不是rust代码哪里用错了,或者是有什么地方可以优化的,谢谢.
如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。
绑定邮箱获取回复消息
由于您还没有绑定你的真实邮箱,如果其他用户或者作者回复了您的评论,将不能在第一时间通知您!
发布评论
评论(5)
机器surface go
rust-release 15秒
rust-debug 27秒
chrome 29秒
相同的实现,rust比js慢是不存在的。但是递归本来就慢,因为要申请很多栈内存,而且很可能溢出。如果是要对比rust和js递归效率,其实js比rust更快(递归次数多的时候),因为js有尾调优化,rust暂时还不支持,但是你这个js实现不是尾调递归,所以也不可能比rust快。如果你的js实现是:
你会发现它能秒算出,而且不会溢出,因为尾调优化了。不然你算一个很大的数,可能就卡死或直接崩了。如果你再用rust实现一个非递归的实现肯定要比js快,但是也快不了多少,因为这个计算本来就很简单,如果是大量的计算,差距就明显了。
我机器上
js : 37.905s
rust : 7.6654385s
改一下
rust : 6.6643812s
我机器上rust编译release测试9秒,js29秒
你是不是debug模式编译测得,那自然慢