记录一次rust浮点数计算没有java速度快的例子

不同的电脑执行如下代码可能会有不同的结果。但是我在同一台机器上的结果,java会比rust快5倍。

java代码:

java 复制代码
public class Test {
    private static final int MAX = 10000000;
    public static void main(String[] args) {
        test(1, 3.141592653589793, 2.718281828459045, "Addition");
        test(2, 3.141592653589793, 2.718281828459045, "Subtraction");
        test(3, 3.141592653589793, 2.718281828459045, "Multiplication");
        test(4, 3.141592653589793, 2.718281828459045, "Division");
    }
    public static void test(int step, double a, double b, String msg) {
        long startTime = System.currentTimeMillis();
        double sum = 0;
        switch (step) {
            case 1 -> {
                for (int i = 0; i < MAX; i++) {
                    sum += a + b;
                }
            }
            case 2 -> {
                for (int i = 0; i < MAX; i++) {
                    sum += a - b;
                }
            }
            case 3 -> {
                for (int i = 0; i < MAX; i++) {
                    sum += a * b;
                }
            }
            case 4 -> {
                for (int i = 0; i < MAX; i++) {
                    sum += a / b;
                }
            }
        }
        long endTime = System.currentTimeMillis();
        System.out.println(msg + " Time taken: " + (endTime - startTime) + "ms result: " + sum);
    }
}

java代码的运行结果

bash 复制代码
Addition Time taken: 15ms result: 5.8598744811975874E7
Subtraction Time taken: 14ms result: 4233108.251312001
Multiplication Time taken: 17ms result: 8.539734223664734E7
Division Time taken: 15ms result: 1.155727349739092E7
rust 复制代码
fn main() {
    _test1(1, 3.141592653589793, 2.718281828459045, "Addition");
    _test1(2, 3.141592653589793, 2.718281828459045, "Subtraction");
    _test1(3, 3.141592653589793, 2.718281828459045, "Multiplication");
    _test1(4, 3.141592653589793, 2.718281828459045, "Division");
}
const MAX: usize = 10000000;
fn _test1(step: u8, a: f64, b: f64, msg: &str) {
    let start = std::time::Instant::now();
    let mut sum = 0.0;
    match step {
        1 => {
            for _ in 0..MAX {
                sum += a + b;
            }
        }
        2 => {
            for _ in 0..MAX {
                sum += a - b;
            }
        }
        3 => {
            for _ in 0..MAX {
                sum += a * b;
            }
        }
        4 => {
            for _ in 0..MAX {
                sum += a / b;
            }
        }
        _ => {
            println!("Invalid step");
        }
    }
    println!("{} Time take: {:?}ms result: {}", msg, start.elapsed().as_millis(), sum);
}
bash 复制代码
Addition Time take: 82ms result: 58598744.811975874
Subtraction Time take: 75ms result: 4233108.251312001
Multiplication Time take: 73ms result: 85397342.23664734
Division Time take: 70ms result: 11557273.49739092
相关推荐
清心歌7 分钟前
HashMap实现原理及扩容机制
java
一只大袋鼠7 分钟前
数据库连接池从入门到精通(下):Druid 连接池使用与工具类封装
java·数据库·连接池
禹中一只鱼10 分钟前
【IDEA 出现 `IDE error occurred`】
java·ide·spring boot·intellij-idea
西凉的悲伤10 分钟前
Guava类库——Lists.partition() 高效分批处理列表数据
java·guava
weixin_4080996711 分钟前
【保姆级教程】按键精灵调用 OCR 文字识别 API(从0到1完整实战 + 可运行脚本)
java·前端·人工智能·后端·ocr·api·按键精灵
brahmsjiang12 分钟前
Java类加载机制解析:从JVM启动到双亲委派,再到Android的特殊实现
android·java·jvm
yaaakaaang14 分钟前
十一、享元模式
java·享元模式
卓怡学长16 分钟前
基于 SpringBoot 的生活信息分享平台,从 0 到 1 完整实现(附源码 + 数据库)
java·数据库·spring boot·tomcat·maven
ID_1800790547317 分钟前
Python解析小红书(XHS)笔记评论 API,json数据返回参考
java·服务器·数据库
努力努力再努力wz18 分钟前
【C++高阶系列】告别内查找局限:基于磁盘 I/O 视角的 B 树深度剖析与 C++ 泛型实现!(附B树实现源码)
java·linux·开发语言·数据结构·c++·b树·算法