编写MR代码中,JAVA注意事项
在编写一个job的过程中,发现代码中抛出 java.lang.UnsupportedOperationException 异常。
编写相似逻辑的测试代码:
1 String[] userid = {"uid_123","uid_124","uid_125"};
2
3 List<String> userList = Arrays.asList(userid);
4
5 userList.add("uid_126"); // Throws exception here.
异常分析:
java.lang.UnsupportedOperationException是指请求的方法不被支持的异常。
查阅Arrays.asList方法,从Arrays.asList()返回的List的不支持add()和remove()方法,这是由于从Arrays.asList()返回的是返回java.util.Arrays$ArrayList,而不是ArrayList。Arrays$ArrayList和ArrayList都是继承AbstractList,add() 和remove()等方法在AbstractList中默认throw UnsupportedOperationException而不做任何操作。ArrayList重写这些方法对List进行操作,而Arrays$ArrayList却没有重写add()和 remove()等方法,所以对从Arrays.asList()转化过来的List进行add()和remove()会出现UnsupportedOperationException异常。
解决方案:
String[] userid = {"uid_123","uid_124","uid_125"};
List<String> userList = Arrays.asList(userid);
List newList = new ArrayList(Arrays.asList(userid)); //将内容复制一份,新建为ArrayList,newList可调用add()与remove()等方法。
userList.add("uid_126");