i am sure this must have been asked before in different ways - as isEmptyOrNull is so common yet people implement it differently. but i have below curious query in terms of best available approach which is good for memory and performance both.
1) Below does not account for all spaces like in case of empty XML tag
return inputString==null || inputString.length()==0;
2) Below one takes care but trim can eat some performance + memory
return inputString==null || inputString.trim().length()==0;
3) Combining one and two can save some performance + memory (As Chris suggested in comments)
return inputString==null || inputString.trim().length()==0 || inputString.trim().length()==0;
4) Converted to pattern matcher (invoked only when string is non zero length)
private static final Pattern p = Pattern.compile("\\s+");
return inputString==null || inputString.length()==0 || p.matcher(inputString).matches();
5) Using libraries like -
Apache Commons (StringUtils.isBlank/isEmpty
)
or Spring (StringUtils.isEmpty
)
or Guava (Strings.isNullOrEmpty
)
or any other option?
isEmpty
is "new" in java 6 and implementations that are older or want to stay java 5 compatible will have to use length check. – Cabanreturn inputString==null || inputString.length()==0 || inputString.trim().length()==0;
(combining 1 and 2) then trim is only invoked on non-zero-length string. You might add 3 to it too., – Evenson