java - matlab - 如何从返回 long 的 Java 方法中获取 int64?

标签 java matlab type-conversion

根据Matlab documentation ,当一个Java方法返回一个long时,它在Matlab中赋值之前被转换为一个double

精度已丢失。我对 Java 方法返回的 long 的低位感兴趣。 double 不能表示它们,但 Matlab 的 int64 可以。 (考虑到这两种类型都有 64 位,这一点很清楚,而 double 使用其中的一些来表示指数。)

如果我可以控制 Java 代码,我可以返回一个包含一个元素的数组,其中包含 long — 在这种情况下,Matlab 将它们保存为 int64,但是就我而言,我正在调用一个库函数。

目前,我能看到的最好方法是用 Java 编写一个包装器,它将调用该方法并在数组中返回答案。但是这种方法存在可移植性问题。有没有更好的办法?

最佳答案

如果您的 Java 方法返回的 long 结果在 [-9,007,199,254,740,992 到 9,007,199,254,740,992] 范围内,那么您根本不需要在代码中执行任何操作。您可以将结果转换回 Matlab 的 int64,而不会损失任何精度。该范围内的所有整数都可以表示为 double 数字而不会损失精度,因为该值可以存储在 double 的 64 位表示提供的 53 位有效二进制数字中 值。

您可以在我的书 Code Quality: The Open Source Perspective 的第 8 章(浮点运算)中找到更多详细信息或任何其他涵盖浮点运算的教科书。

下面的程序演示了 double 表示精确表示范围末尾的 1 亿个整数的准确性。

#include <stdio.h>

int
main(int argc, char *argv[])
{
    int i;
    volatile long long n1, n2;
    volatile long long p1, p2;
    volatile double d;

    /* Include one number outside the range, to show that the test works. */
    n1 = -9007199254740993ll;
    p1 =  9007199254740993ll;
    for (i = 0; i < 100000000; i++) {
        d = p1;
        p2 = d;
        if (p1 != p2)
            printf("%lld != %lld\n", p1, p2);

        d = n1;
        n2 = d;
        if (n1 != n2)
            printf("%lld != %lld\n", n1, n2);
        p1--;
        n1++;
    }
    return 0;
}

关于java - matlab - 如何从返回 long 的 Java 方法中获取 int64?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/16313772/

相关文章:

java - Amazon SQS 调用 lambda 函数

java - 如果没有可用的互联网连接,我的应用程序会出现 ANR

matlab - 在 MATLAB 中获取所有可能的聚类

matlab - 如果不增加值则为空赋值(Matlab)

java - 如何从 hibernate 中的新工作方法返回值

java - 在Java中根据种子创建一个随机整数数组

matlab - 如何在 matlab 时间序列对象中表示秒的小数部分?

java - 三元运算符转换整数

android - 保存位图的 RGB

java - 为单个 Spring Controller 指定消息转换器