[英]Java short primitive type issue
我正在构建一个需要使用post方法与服务器连接并获取结果的应用程序。 我需要获取服务器响应的特定部分,并将其转换为不同类型的原语(从String
到short
, int
, byte
等)。
所以基本上我需要获取一部分响应代码并将其转换为short,而不是看看是否有带有该值的enum
元素,但是问题是响应返回值001
,然后将其转换为short并传递给它我getByValue(int)
的方法enum
,它说我有是001没有元素如果我打印的short
值,我得到1
。
这是我正在使用的代码示例:
httppost.setEntity(new UrlEncodedFormEntity(postParameters));
HttpResponse response = httpclient.execute(httppost);
Log.v("Response ","Status line : "+ response.getStatusLine().toString());
String responseBody = EntityUtils.toString(response.getEntity()); //response
Log.v("Response ","Response : "+ responseBody);
int objectIdentificator = Integer.parseInt(responseBody.substring(0,32));
Log.v("Response ","Object Identificator (LONGINT) : "+ responseBody.substring(0,32));
Log.v("Response ","Object Identificator (LONGINT) : "+ objectIdentificator);
String type = responseBody.substring(32,35);
Log.v("Response ","TYPE (UNSIGNED BYTE) : "+ type);
short pType = Short.parseShort(type); // short
Log.v("Response ","TYPE (UNSIGNED BYTE) : "+ pType);
String operation = responseBody.substring(35,38); //
short operationType = Short.parseShort(operation);
Log.v("Response ","OPERATION (UNSIGNED BYTE) : "+ operation);
Log.v("Response ","OPERATION (UNSIGNED BYTE) : "+ operationType);
String objectId = responseBody.substring(38, 70);
Log.v("Response ","UID (CHAR, length 32) : "+ objectId);
int id = Integer.parseInt(responseBody.substring(70, 102));
Log.v("Response ","ID (LONGINT) : "+ responseBody.substring(70, 102));
Log.v("Response ","ID (LONGINT) : "+ id);
String size = responseBody.substring(102,134);
Log.v("Response ","Data Size (LONGINT) : "+ size);
String hash = responseBody.substring(134,166);
Log.v("Response ","Data Hash (CHAR, length 32 : "+ hash);
String dType = responseBody.substring(166,169);
Log.v("Response ","Data Type (UNSIGNED BYTE) : "+ dType);
short dataType = Short.parseShort(dType);
Log.v("Response ","Data Type (UNSIGNED BYTE) : "+ dataType);
String data = responseBody.substring(169, responseBody.length());
Log.v("Response ","Data (CHAR, any length, in BASE64) : "+ data);
byte[] first = Base64.decode(data);
String string = new String(first, "UTF-8");
Log.v("Response ","BASE 64 : "+ string);
RPCPacket packet = new RPCPacket( objectIdentificator,
RPCPacketType.getPacketTypeByValue(pType),
RPCOperationType.getByValue(Integer.parseInt(operation)),
objectId,
id,
Integer.parseInt(size),
hash,
RPCPacketDataType.getByValue(dataType),
first
);
Log.v("PacketType", "RPCPacketType : "+packet.packetTypeToStr(RPCPacketType.getPacketTypeByValue(pType)));
和packetTypeToStr代码:
public String packetTypeToStr(RPCPacketType type){
String str=null;
switch(type){
case ST_OBJECT_TYPE_INFO_START:
str = "ST_OBJECT_TYPE_INFO_START";
break;
case ST_OBJECT_TYPE_INFO_ERROR:
str = "ST_OBJECT_TYPE_INFO_ERROR";
break;
case ST_OBJECT_TYPE_COLLECTION:
str = "ST_OBJECT_TYPE_COLLECTION";
break;
case ST_OBJECT_TYPE_CATEGORY:
str = "ST_OBJECT_TYPE_CATEGORY";
break;
case ST_OBJECT_TYPE_CARD:
str = "ST_OBJECT_TYPE_CARD";
break;
case ST_OBJECT_TYPE_MESSAGE:
str = "ST_OBJECT_TYPE_MESSAGE";
break;
case ST_OBJECT_TYPE_GENRE:
str = "ST_OBJECT_TYPE_GENRE";
break;
case ST_OBJECT_TYPE_TAG:
str = "ST_OBJECT_TYPE_TAG";
break;
case ST_OBJECT_TYPE_USER:
str = "ST_OBJECT_TYPE_USER";
break;
case ST_OBJECT_TYPE_MEDIA_COLLECTION:
str = "ST_OBJECT_TYPE_MEDIA_COLLECTION";
break;
case ST_OBJECT_TYPE_MEDIA_CATEGORY:
str = "ST_OBJECT_TYPE_MEDIA_CATEGORY";
break;
case ST_OBJECT_TYPE_MEDIA_CARD:
str = "ST_OBJECT_TYPE_MEDIA_CARD";
break;
case ST_OBJECT_TYPE_MEDIA_TAG:
str = "ST_OBJECT_TYPE_MEDIA_TAG";
break;
case ST_OBJECT_TYPE_INFO_END:
str = "ST_OBJECT_TYPE_INFO_END";
break;
case ST_OBJECT_TYPE_CARDSTATS_CATEGORY:
str = "ST_OBJECT_TYPE_CARDSTATS_CATEGORY";
break;
case ST_OBJECT_TYPE_CONTENT:
str = "ST_OBJECT_TYPE_CONTENT";
break;
case ST_OBJECT_TYPE_MEDIA_COLLECTION_BUTTON:
str = "ST_OBJECT_TYPE_MEDIA_COLLECTION_BUTTON";
break;
default:
str ="UNKNOWN "+type;
break;
}
return str;
}
和例外:
09-08 09:53:08.744: WARN/System.err(2509): java.lang.IllegalArgumentException: no datatype with 001 exists
09-08 09:53:08.754: WARN/System.err(2509): at com.stampii.stampii.comm.rpc.RPCCommucatorDefines$RPCOperationType.getByValue(RPCCommucatorDefines.java:34)
09-08 09:53:08.754: WARN/System.err(2509): at com.stampii.stampii.user.UserLogin$2.onClick(UserLogin.java:122)
09-08 09:53:08.754: WARN/System.err(2509): at android.view.View.performClick(View.java:2408)
09-08 09:53:08.754: WARN/System.err(2509): at android.view.View$PerformClick.run(View.java:8817)
09-08 09:53:08.754: WARN/System.err(2509): at android.os.Handler.handleCallback(Handler.java:587)
09-08 09:53:08.754: WARN/System.err(2509): at android.os.Handler.dispatchMessage(Handler.java:92)
09-08 09:53:08.754: WARN/System.err(2509): at android.os.Looper.loop(Looper.java:144)
09-08 09:53:08.754: WARN/System.err(2509): at android.app.ActivityThread.main(ActivityThread.java:4937)
09-08 09:53:08.754: WARN/System.err(2509): at java.lang.reflect.Method.invokeNative(Native Method)
09-08 09:53:08.754: WARN/System.err(2509): at java.lang.reflect.Method.invoke(Method.java:521)
09-08 09:53:08.754: WARN/System.err(2509): at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:868)
09-08 09:53:08.764: WARN/System.err(2509): at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:626)
09-08 09:53:08.764: WARN/System.err(2509): at dalvik.system.NativeStart.main(Native Method)
RPCOperationType代码:
public enum RPCOperationType {
O_CREATE(1),
O_UPDATE(2),
O_DELETE(3);
private int value;
private intvalue1;
private RPCOperationType(int i){
this.value=i;
}
public int getNumericType(){
return value;
}
public static RPCOperationType getByValue(int i) {
for(RPCOperationType dt : RPCOperationType.values()) {
if(dt.value1 == i) {
return dt;
}
}
throw new IllegalArgumentException("no datatype with " + i + " exists");
}
}
因此,有什么建议可以在不更改枚举中的ID的情况下解决该问题? 提前致谢!
您显示给我们的代码不会引发异常。 堆栈跟踪说明发生异常的位置:
at com.stampii.stampii.comm.rpc.RPCCommucatorDefines$RPCOperationType.getByValue(RPCCommucatorDefines.java:34)
因此,在第34行的RPCCommucatorDefines.java
对RPCOperationType.getByValue()
的调用将引发此异常。 您肯定要传递给它一个字符串,而不是一个BTW整数,因为像在异常错误消息中那样,没有办法将一个短变量打印为001
。
堆栈走线的前两行是最重要的一条。 第一个告诉您出了什么问题,第二行告诉您在哪里引发了异常。
如果您需要用零填充数字,则必须使用Formatter 。
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.