我一直发现这里和谷歌上的人都有从long到int的麻烦,而不是相反。然而,我确信我不是唯一一个在从int型转向Long型之前遇到这种情况的人。

我找到的唯一其他答案是“一开始就把它设置为长”,这并没有解决这个问题。

我最初尝试了类型转换,但我得到了一个“不能从int类型转换为Long类型”

for (int i = 0; i < myArrayList.size(); ++i ) {
    content = new Content();
    content.setDescription(myArrayList.get(i));
    content.setSequence((Long) i);
    session.save(content);
}

正如你可以想象的,我有点困惑,我被困在使用int,因为一些内容是作为一个数组列表进来的,而我存储这个信息的实体需要序列号作为一个长。


当前回答

我在这方面遇到了很大的麻烦。我只是想:

thisBill.IntervalCount = jPaidCountSpinner.getValue();

其中IntervalCount是Long, JSpinner被设置为返回Long。最后我不得不写出这个函数:

    public static final Long getLong(Object obj) throws IllegalArgumentException {
    Long rv;

    if((obj.getClass() == Integer.class) || (obj.getClass() == Long.class) || (obj.getClass() == Double.class)) {
        rv = Long.parseLong(obj.toString());
    }
    else if((obj.getClass() == int.class) || (obj.getClass() == long.class) || (obj.getClass() == double.class)) {
        rv = (Long) obj;
    }
    else if(obj.getClass() == String.class) {
        rv = Long.parseLong(obj.toString());
    }
    else {
        throw new IllegalArgumentException("getLong: type " + obj.getClass() + " = \"" + obj.toString() + "\" unaccounted for");
    }

    return rv;
}

这似乎很管用。再多简单的铸造,上面的解决方案都不适合我。非常令人沮丧。

其他回答

如果你已经有int类型为Integer,你可以这样做:

Integer y = 1;
long x = y.longValue();

如何

int myInt = 88;

//不编译

Long myLong = myInt;

//编译,并保留int的非null精神。最好的演员阵容根本就是没有演员阵容。当然,您的用例可能需要长值和可能的NULL值。但如果int或其他长类型是您唯一的输入,并且您的方法可以修改,我建议使用这种方法。

long myLong = myInt;

//编译,是最有效的方法,并且清楚地表明源值永远不会为NULL。

Long myLong = (long) myInt;

只要只有long . valueof (long)方法,在使用long . valueof (intValue)的情况下,将隐式地从int转换为long。

更明确的做法是

Integer.valueOf(intValue).longValue()

我在这方面遇到了很大的麻烦。我只是想:

thisBill.IntervalCount = jPaidCountSpinner.getValue();

其中IntervalCount是Long, JSpinner被设置为返回Long。最后我不得不写出这个函数:

    public static final Long getLong(Object obj) throws IllegalArgumentException {
    Long rv;

    if((obj.getClass() == Integer.class) || (obj.getClass() == Long.class) || (obj.getClass() == Double.class)) {
        rv = Long.parseLong(obj.toString());
    }
    else if((obj.getClass() == int.class) || (obj.getClass() == long.class) || (obj.getClass() == double.class)) {
        rv = (Long) obj;
    }
    else if(obj.getClass() == String.class) {
        rv = Long.parseLong(obj.toString());
    }
    else {
        throw new IllegalArgumentException("getLong: type " + obj.getClass() + " = \"" + obj.toString() + "\" unaccounted for");
    }

    return rv;
}

这似乎很管用。再多简单的铸造,上面的解决方案都不适合我。非常令人沮丧。

我有一个小玩具,它也处理非泛型接口。 我可以接受它抛出一个ClassCastException如果饲料错误(OK和快乐)

public class TypeUtil {
    public static long castToLong(Object o) {
        Number n = (Number) o;
        return n.longValue();
    }
}