A股上市公司传智教育(股票代码 003032)旗下技术交流社区北京昌平校区

 找回密码
 加入黑马

QQ登录

只需一步,快速开始

© sheng6699 中级黑马   /  2014-4-23 20:53  /  1215 人查看  /  1 人回复  /   0 人收藏 转载请遵从CC协议 禁止商业使用本文

  • 第五回:异常处理
    有些新手总是习惯于使用返回值来进行错误处理, 如果使用异常处理这种方法将会使程序结构更合理, 效率更高。 比如在Client端需要通过EJB来进行DB操作, Client端需要知道DB处理有没有出错就可以通过层层的向上抛Exception的方法, 一直到Client端需要处理的地方截住, 然后进行例外处理。 如:
    后台DB处理:
    public static java.sql.Timestamp getDBSysdate() throws CSCWebException {
    Connection conn = null;
    Timestamp sysTime = null;

    try {
    conn = PJEJBSvrUtil.getWLPoolConnection();
    sysTime = CommonDAO.getDBSysdate(conn);
    } catch (SQLException ce) {
    throw new CSCWebException(ce.getMessage());
    } finally {
    try {
    if (conn != null) {
    conn.close();
    }
    } catch (Exception e) {
    throw new CSCWebException(e.getMessage());
    }
    }

    return sysTime;
    }
    在前台:
    try {
    commonIntf.getDBSysdate();
    } catch (CSCWebException cex) {
    cat.debug(“”, cex);
    return getExceptionForward(cex);
    }
    要防止违例被漏处理, 除非是你肯定不需要处理的, 提倡在遇到Exception的时候就要往上抛, 由最终调用处来进行处理, 当然也不能一概而论, 视情况而定。 比如我想例外在方法体内就要解决掉, 给出一个CSC中出现的bug。
    public boolean checkTelFormat(String telNo) {
    boolean error = false;

    if ( telNo == null || telNo.equals("") ) {
    error = true;
    } else {
    if ( ejb.util.StringUtil.chkPhone(telNo) ) {
    error = false;
    } else {
    error = true;
    }
    }

    if (telNo.startsWith("184") || telNo.startsWith("186")) {
    if (telNo.length() == 3) {
    error = true;
    }
    }

    if ( error ) {
    ObjMngr.showError("MCSTC001E");
    cmbTelNo.requestFocus();
    return false;
    } else {
    return true;
    }
    }
    用了一个Flag来记住每次Check的结果, 然后在最后再出Error Dialog, 这是比较典型的C的写法, 改写如下:
    public boolean checkTelFormat(String telNo) {
    try {
    if (telNo == null || telNo.equals("")) {
    throw new Exception();
    } else {
    if (!ejb.util.StringUtil.chkPhone(telNo)) {
    throw new Exception();
    }
    }
    if (telNo.startsWith("184") || telNo.startsWith("186")) {
    if (telNo.length() == 3) {
    throw new Exception();
    }
    }
    } catch (Exception e) {
    ObjMngr.showError("MCSTC001E");
    cmbTelNo.requestFocus();
    return false;
    }

    return true;
    }
    使用了抛Exception的方法, 在方法的最后截住, 这样一遇到Error就能马上处理掉, 从效率上讲也是最高的。


  •    
    第六回:数据库操作的问题
    根据现有的开发经验, 一般我们在SessionBean(或不用EJB的时候的Module Bean)中取到Connection然后调用专门操作数据库(DAO)中的方法, 也就是在Bean中进行Connection的打开与关闭操作, 而在DAO中进行Statement和ResultSet操作, 一般在最后都需要进行关闭它们。 接上节的例子, 在CommonDAO里面有这样的一个方法:
    public static java.sql.Timestamp getDBSysdate(Connection conn)
    throws CSCWebException {
    Statement stmt = null;
    ResultSet rs = null;
    Timestamp sysTime = null;

    try {
    stmt = conn.createStatement();
    rs = stmt.executeQuery("SELECT SYSDATE FROM DUAL");
    if (rs.next()) {
    sysTime = rs.getTimestamp("SYSDATE");
    }
    } catch (SQLException ce) {
    throw new CSCWebException(ce.getMessage());
    } catch (Exception e) {
    throw new CSCWebException(e.getMessage());
    } finally {
    try {
    if (rs != null) {
    rs.close();
    }
    if (stmt != null) {
    stmt.close();
    }
    } catch (Exception e) {
    throw new CSCWebException(e.getMessage());
    }
    }

    return sysTime;
    }
    在finally里面的语句总是会被执行到的, 所以即使上面抛出了SQLException也会去执行stmt与rs的close操作的。


  • 6
    zm828
    第七回:index越界(索引)
      这个也是常碰到的,有时候还很奇怪,不过只要对症下药就可以解决的。
    index越界包括很多:
    Ø String的index
    String的index从0开始, 最大为它的字符长度。常用的为substring这个方法:
    String str = “This is a sample”;
    str.substring(5, 7); 返回 is;

    str.substring(15, 16) 或 str.substring(15); 都返回最后一个字符 e;

    str.substring(16, 17); 这个会抛java.lang.StringIndexOutOfBoundsException错误;

    Ø 数组下标
    数组下标也由0开始, 最大为长度-1, 例:
    int[] columnLen = new int[]{20, 30, 40, 30, 25, 50, 65, 100};
    columnLen[0]为20;
    columnLen[7]为100;
    columnLen[8]会抛java.lang.ArrayIndexOutOfBoundsException错误。

    Ø Vector, ArrayList等Collection的size
    Vector与ArrayList同属于List, 它们都是有序的集合体, 下标也都是从0开始, 最大也是长度-1, 跟数组不同的是, 它们的元素必须都是Object, 但可以为不同类型的对象, 不过在取出之后得要进行类型转换。 而数组得要所有元素的类型相同。 ArrayList在构造之后, 并不存在元素的情况下, 如果调用set(index, Object)就会出错。得要先进行add(Object)才行。 例:
    ArrayList list = new ArrayList(10); // 这个地方的10只是list的初始容量, 并不代表它具有了10个元素, 这个跟数组不同, 数组在这种情况下具有了10个初始值, 初始值跟具体的元素类型有关, 一般的对象为null;
    list.set(0, “First”); // 会抛java.lang.IndexOutOfBoundsException
    list.add(“First”);
    list.set(0, “new First”); // 正确, 因为位置0已经存在元素



1 个回复

倒序浏览
值得学习ing!
回复 使用道具 举报
您需要登录后才可以回帖 登录 | 加入黑马