zoukankan      html  css  js  c++  java
  • 编写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"); 
  • 相关阅读:
    开源数据采集组件比较: scribe、chukwa、kafka、flume
    主流开源SQL(on Hadoop)总结
    Hive over HBase和Hive over HDFS性能比较分析
    开源Astro(SparkSQL On HBase)
    ML: 降维算法-LE
    ML: 降维算法-LLE
    Blender使用基础
    Cycles渲染研究测试效果图
    vs2008所有DTE.ExecuteCommand命令
    come on,逆战
  • 原文地址:https://www.cnblogs.com/marc01in/p/4250206.html
Copyright © 2011-2022 走看看