我有这种方法。 问题是,当这个条件满足即使在调用catch块时也正在执行代码
if (bagList==null||bagList.size()<1 && UngarList==null||UngarList.size()<1)
它进入catch块这里
catch (Exception e) {
this.errorText = e.getMessage().toString();
info.setErrorText(this.errorText.toString());
response.setinfo(info);
}
但它毕竟是execuing下一行是
final boolean toProceedorNot = validate(bagList.toArray(new Bag[bagList.size()]))
什么如果这是符合要求
if (bagList==null||bagList.size()<1 && UngarList==null||UngarList.size()<1)
**then directly return the response;**
这是我的方法
public Response getData(Request request) {
Info info = new Info();
Response response = new Response();
String xmlrequest = request.getxmlMessage();
HashMap listMap = new HashMap();
List<Ungar> UngarList = new ArrayList<Ungar>();
List<Bag> bagList = new ArrayList<Bag>();
UniverseStaxParser xmlparser = new UniverseStaxParser();
try {
listMap = (HashMap) xmlparser.parseData(xmlrequest);
UngarList = (List<Ungar>) listMap.get("UngarItems");
bagList = (List<Bag>) listMap.get("bagItems");
if (bagList==null||bagList.size()<1 && UngarList==null||UngarList.size()<1)
throw new Exception("No Valid Data is passed as Input ");
} catch (Exception e) {
this.errorText = e.getMessage().toString();
info.setErrorText(this.errorText.toString());
response.setinfo(info);
}
final boolean toProceedorNot = validate(bagList.toArray(new Bag[bagList.size()]));
try {
if (!toProceedorNot) {
info.setErrorText(errorText);
response.setinfo(info);
} else {
// some logic here goes
}
} catch (Exception e) {
errorText = e.getMessage().toString();
info.setErrorText(errorText);
response.setinfo(info);
}
return response;
}
调用一个空对象的方法会抛出空指针异常。这是一个常见的错误。 – Jasonw
非常感谢大家,我修改了代码,将它保存在一个try块中,现在它的工作。 – Revathi