zoukankan      html  css  js  c++  java
  • MapReduce 中job.setJarByClass()方法的疑惑

    在调试mr实例的时候,遇到如下的情况,如图所示

    说明:就是我的mr程序类名称和我设置的setJarByclass()中设置的不一样,但是程序竟然没有报错!!!!当时把我吓尿了

    疑惑:如果这样设置的话,那岂不是找不到的main方法了啊?

    最后查看setJarByClass()方法,惊奇的发现

    在 JobConf中有个setJarByClass方法

    /**
    * Set the job's jar file by finding an example class location.
    *
    * @param cls the example class.
    */

    public void setJarByClass(Class cls) {
    String jar = ClassUtil.findContainingJar(cls);
    if (jar != null) {
    setJar(jar);
    }
    }

    该方法的作用是 通过传入的class 找到job的jar包,上图我们设置的class 跟我们的job类位于同一个包中,通过public void setJarByClass(Class cls)  返回的是就是我们job包的jar,所以成功了

    如果 我们设置的的class跟主类不在同一个工程中,程序会报错:NotFoundClass

  • 相关阅读:
    自动轮播
    哈夫曼树的应用-金条划分
    计算两个日期相差的天数
    数据结构之算术表达式
    动态规划-矩阵最短路径
    动态规划-换钱最少货币数
    字母数字密码破解
    荷兰国旗问题
    集合并集
    进制数位幸运数
  • 原文地址:https://www.cnblogs.com/ggbond1988/p/4797014.html
Copyright © 2011-2022 走看看