当前位置:首页 > 每日看点 > 正文内容

Golang与Rust哪个语言会是今后的主流?

卡卷网11个月前 (01-31)每日看点171

rust就算了,一个计算圆周率的程序能比py还慢,注意,这个py是官方的cpython,两者代码几乎一模一样,Python也没有搞什么黑科技之类的,rust是默认的编译参数,我实在是想不出来你一个静态的,编译到汇编的,能比跑在虚拟机上的动态语言Python还慢

==========评论区要看代码,先把连接放一下吧

为什么Rust会比Python更慢? - 知乎

为什么Rust会比Python更慢?

use rand::Rng; use std::time::Instant; fn estimate_pi(n: u32) -> f64 { let mut num_points_in_circle = 0; let mut num_points_total = 0; let mut rng = rand::thread_rng(); for _ in 0..n { let x: f64 = rng.gen(); let y: f64 = rng.gen(); // let distance = x.powi(2) + y.powi(2); let distance = x * x + y * y; if distance <= 1.0 { num_points_in_circle += 1; } num_points_total += 1; } return 4.0 * (num_points_in_circle as f64) / (num_points_total as f64); } fn main() { const N: u32 = 1_0000_0000 / 2; let start_time = Instant::now(); let pi_estimate = estimate_pi(N); let elapsed_time = start_time.elapsed(); println!("N={}, estimated value of pi: {}", N, pi_estimate); println!("耗时:{:?}", elapsed_time); }


import random import time def estimate_pi(n): num_points_in_circle = 0 num_points_total = 0 rng = random.Random() for _ in range(n): x = rng.random() y = rng.random() distance = x**2 + y**2 if distance <=1.0: num_points_in_circle+=1 num_points_total +=1 return 4.0 * (num_points_in_circle/num_points_total) def main(): n = int(1_0000_0000 / 2) start_time = time.time() pi_estimate = estimate_pi(n) elapsed_time = time.time() - start_time print(f"n={n}, estimated value of pi: {pi_estimate}") print(f"耗时:{elapsed_time}") if __name__ == "__main__": main()

在来个go的

func main() { n := uint32(1_0000_0000 / 2) start_time := time.Now() pi_estimate := estimate_pi(n) elapsed_time := time.Since(start_time) fmt.Printf("n=%v, estimated value of pi: %v\n", n, pi_estimate) fmt.Printf("耗时:%v\n", elapsed_time) } func estimate_pi(n uint32) float64 { num_points_in_circle := 0 num_points_total := 0 rng := rand.New(rand.NewSource(time.Now().UnixMilli())) for range n { x := rng.Float64() y := rng.Float64() distance := x*x + y*y if distance <= 1.0 { num_points_in_circle += 1 } num_points_total += 1 } return 4.0 * (float64(num_points_in_circle) / float64(num_points_total)) }

运行了3次:

go耗时基本在600ms左右,运行命令go run main.go

rust耗时在78-80s左右,运行命令cargo run,加上--release,基本上会稳定在550ms左右

py耗时在35-40s左右,运行命令python main.py

为什么N要除以2,和原链接的不一样,因为rust实在太慢了

===把java和C#的也补充下

java耗时在1470-1500ms左右,java就用的idea运行的,默认配置

c#耗时在780-800ms左右, 运行命令dotnet run --configuration Release

public static void main(String[] args) { for (int i = 0; i < 3; i++) { final long n = 1_0000_0000 / 2; long start = System.currentTimeMillis(); double pi_estimate = estimate_pi(n); long end = System.currentTimeMillis(); System.out.println("n="+n+" estimated value of pi:"+pi_estimate); System.out.println("耗时"+(end-start)+"ms"); } } public static double estimate_pi(long n){ int num_points_in_circle = 0; int num_points_total = 0; Random rng = new Random(); for (long i = 0; i < n; i++) { double x = rng.nextDouble(); double y = rng.nextDouble(); double distance = x*x+y*y; if (distance<=1.0) { num_points_in_circle+=1; } num_points_total+=1; } return 4.0 * (double) num_points_in_circle / (double) num_points_total; }


using System.Diagnostics; static class Program { static void Main() { const long n = 1_0000_0000 / 2; var sw = new Stopwatch(); sw.Start(); for (int i = 0; i < 3; i++) { sw.Restart(); double pi_estimate = estimate_pi(n); sw.Stop(); System.Console.WriteLine($"n={n}, estimated value of pi: {pi_estimate}"); System.Console.WriteLine($"耗时:{sw.ElapsedMilliseconds}ms"); } } static double estimate_pi(long n) { int num_points_in_circle = 0; int num_points_total = 0; Random rng = new Random(); for (long i = 0; i < n; i++) { double x = rng.NextDouble(); double y = rng.NextDouble(); double distance = x * x + y * y; if (distance <= 1.0) { num_points_in_circle += 1; } num_points_total += 1; } return 4.0 * (double)num_points_in_circle / (double)num_points_total; } }

扫描二维码推送至手机访问。

版权声明:本文由卡卷网发布,如需转载请注明出处。

本文链接:https://www.kajuan.net/ttnews/2025/01/10371.html

分享给朋友:

相关文章

b站真的能自学PS吗?

b站真的能自学PS吗?

看你想达到哪一种程度了,如果你只是平常用PS扣图、调整照片大小、尺寸、简单调个色这样,自学真的挺简单的,B站很多免费的教程都可以教会你这些技巧。但是如果说你想成为专业的设计师或者是商业修图师,无师自通真的非常难,首先你会走很多弯路,不知道怎...

感觉手机配置都差不多,为什么有的手机能卖2k-3k,而有的手机却能卖到6k-8k?

感觉手机配置都差不多,为什么有的手机能卖2k-3k,而有的手机却能卖到6k-8k?

与所有的商品一样,手机的价格,也是由它的成本所决定的。虽然看起来3000元的手机和6000的手机配置差不多,甚至处理器都可能是同一个,但在很多大家容易忽略的地方,决定了两者价格的不同:例如手机的外观,塑料的机身,与素皮机身和玻璃机身就完全不...

在 Istio、Linkerd 和 Cilium 之间,哪种服务网格在性能上表现最佳?

在 Istio、Linkerd 和 Cilium 之间,哪种服务网格在性能上表现最佳?

在讨论服务网格之前,先理解一下为什么我们需要它。现代微服务架构意味着将应用拆分为多个小型、独立的服务,这些服务可以独立开发、部署和扩展。然而,服务之间的通信和管理成了巨大的挑战,例如如何保证安全的通信、负载均衡、监控与可观测性等。服务网格...

无人机真的是中国领先吗?

无人机真的是中国领先吗?

巧了这是。捡到了一台大疆。应该是别人飞丢的。在草丛中泡过水,轴承锈死,电池鼓涨已,经没有维修价值了。但作为玩电子的,免不了要把它解剖,研究一番。那么,我们看看它的国产化率能有多少吧。图片说话:解释一下吧。图一,高通 美国图二,MPS: 美国...

在 Kubernetes 中,Service 的实现原理是什么,它是如何实现服务发现的?

行,问的这个问题挺有意思,Kubernetes 里 Service 是怎么实现的,服务发现是怎么回事,咱就直说了。这事儿看起来挺玄乎,但掰开揉碎了讲,也就那么回事。你得把这事儿想得简单点,别一上来就被啥术语吓住了——其实全是些搬砖的套路。咱...

国内AI大模型已近80个,哪个最有前途?

国内AI大模型已近80个,哪个最有前途?

题主说错了,不是80个,是168个!虽然“最有前途”不好说,但是我可以帮题主排除一些错误方向:开源大模型一定比闭源的有前途吗?参数量大的模型一定就比小模型有前途吗?榜单排名高的大模型一定更有前途吗?2024年3月更新,243个大模型中有哪几...

发表评论

访客

看不清,换一张

◎欢迎参与讨论,请在这里发表您的看法和观点。