草庐IT

try_integer

全部标签

java - 在 Java 中从 MongoDB 读取 Integer 字段时出现长类型转换错误

我正在从Rails应用程序写入的Java访问MongoDB实例。我正在检索应存储在Long中的整数值,因为它们可以超过32位。此代码将编译:this.profile_uid=(Long)this.profile.get("uid");但是,我遇到类型转换运行时错误:Exceptioninthread"main"java.lang.ClassCastException:java.lang.Integercannotbecasttojava.lang.Long这大概是因为该字段由Mongo作为Integer返回,但我知道某些ID可以作为Longs出现,并且出于各种原因我无法更改写入DB的类

java - JAXB Marshall Map<Integer, ArrayList<String>>

我有一个对象我想编码。@XmlRootElementpublicclassBoxItem{@XmlElementMap>intgerStringArrMap;BoxItem(){intgerStringArrMap=newHashMap>();for(inti=0;istringArrayList=newArrayList();for(intj=0;j现在假设我们有一个boxItem=newBoxItem()如果我调用jaxbMarshaller.marshal(boxItem,System.out);,每个条目的值为空。012如何将ArrayList中的元素编码到一个Map值中?

java - 如何从 Set<Integer> 创建 IntStream?

我目前这样做:Setintegers=...//sourcedfromelsewhereincodeIntStreamintStream=integers.stream().mapToInt(value->value);必须将值映射到值以转换Stream似乎是多余的至IntStream.有没有办法在没有冗余的情况下做到这一点mapToInt(...)部分? 最佳答案 不,你必须使用.mapToInt(value->value)或者(对我来说更好看).mapToInt(Integer::intValue).作为Stream是通用类,它

java - 为 Set<Integer> 的类似 BitSet 的实现有效地计算 hashCode

我想知道如何有效地计算hashCode对于BitSet类似Set的实现.BitSet#hashCode显然计算速度很快,相当愚蠢(*)并且与Set#hashCode()不兼容.快速兼容的实现可能是这样的inthashCode(){intresult=0;for(inti=0;i如果有一个有效的实现intweightedBitCount(longword){//naiveimplementationintresult=0;for(inti=0;i如果大多数位未设置,可以通过测试word==0来改进简单的实现或使用Long.highestOneBit或类似的东西,但这些技巧在其他情况下没有

java - 为什么在 Java 的 try-with-resources 构造中 catch 之前调用资源的 close() 方法?

我偶然发现,是这样的。请参阅下面的示例:publicclassAutoClosableTest{publicstaticvoidmain(String[]args)throwsException{try(MyClosableinstance=newMyClosable()){if(true){System.out.println("try");thrownewException("Foo");}}catch(Exceptione){System.out.println("Catched");}finally{System.out.println("Finally");}}publics

java - 有没有更简洁的方法来使用 try-with-resource 和 PreparedStatement?

这是Main.java:packagefoo.sandbox.db;importjava.sql.Connection;importjava.sql.PreparedStatement;importjava.sql.ResultSet;importjava.sql.SQLException;publicclassMain{publicstaticvoidmain(String[]args){finalStringSQL="select*fromNVPAIRwherename=?";try(Connectionconnection=DatabaseManager.getConnectio

Java - List<Integer> 排序、比较器和溢出

我有以下代码按降序对列表进行排序Listlist=Arrays.asList(Integer.MAX_VALUE,-1);list.sort((x,y)->y-x);System.out.println(list)结果是[-1,2147483647]现在,我知道我不应该写y-x,因为它会导致溢出问题。但问题是为什么输出是这样的?我相信输出会是[2147483647,-1]因为-1-Integer.MAX_VALUE是-2147483648,仍然是一个负整数,广告该操作似乎不受溢出问题的影响。我做错了什么? 最佳答案 正如您在Orac

java - 如何将字符串转换为 float 并避免在 java 中使用 try/catch?

在某些情况下,我需要将字符串转换为float或其他一些数字数据类型,但有可能得到一些不可转换的值,例如“-”或“/”,我无法验证所有值事先删除它们。我想避免在这件事上使用try/catch,有没有其他方法可以在java中进行正确的转换?类似于C#TryParse的东西? 最佳答案 我能想到的最简单的事情是java.util.Scanner。然而,这种方法需要为每个字符串创建一个新的Scanner实例。Stringdata=...;Scannern=newScanner(data);if(n.hasNextInt()){//check

java - 我们能否在发生异常的try block 中获取LineNumber和ColumnNumber

我有以下代码,可以打印发生错误的全类名、类名、方法名。此外,我能够打印行号,但打印的行号是初始化变量“LineNumber”的行。如何在发生错误的tryblock中打印准确的LineNumber和ColumnNumber?try{SQLQuery}catch(Exceptione){StringfullClassName=Thread.currentThread().getStackTrace()[1].getClassName();StringclassName=fullClassName.substring(fullClassName.lastIndexOf(".")+1);Str

java - Java 1.6 中的 Try-with-resources 等价物

我有以下代码:publicclassMain{publicstaticvoidmain(String[]args)throwsSQLException{try(Connectionconn=DBUtil.getConnection(DBType.HSQLDB);Statementstmt=conn.createStatement(ResultSet.TYPE_SCROLL_INSENSITIVE,ResultSet.CONCUR_READ_ONLY);ResultSetrs=stmt.executeQuery("SELECT*FROMtours");){DBUtil.getConnec