分享最近一次递归的方法

    private static void createSheet(HSSFWorkbook wb, String[] head, String[][] body, String sheetName, int sheetIndex, int start) {
        int rowIndex = 0;
        System.out.println("@@@@@@@@@@" + sheetIndex);
        System.out.println("##########" + start);
        HSSFSheet sheet = wb.createSheet(sheetName + sheetIndex);   
        System.out.println("sheetName"+ sheet.getSheetName())  ;

        HSSFRow row = sheet.createRow(rowIndex);
        createHeadRow(wb,row, head);
        for(int i=start; i< body.length; i++) {
            if(rowIndex > 1000) {
                System.out.println("^^^^^^^^^" + rowIndex);
                createSheet(wb,head,body,sheetName,sheetIndex +1, i);
                System.out.println("&&&&&&&&&" + i );
                return;
            }
            rowIndex++;
            String[] array = body[i];
            HSSFRow r = sheet.createRow(rowIndex);
            createBodyRow(wb,r, array);
        }
    }

 

 

打出来的log是

@@@@@@@@@@1
##########0
sheetNameSubmittedMatches1
^^^^^^^^^1001
@@@@@@@@@@2
##########1001
sheetNameSubmittedMatches2
^^^^^^^^^1001
@@@@@@@@@@3
##########2002
sheetNameSubmittedMatches3
^^^^^^^^^1001
@@@@@@@@@@4
##########3003
sheetNameSubmittedMatches4
^^^^^^^^^1001
@@@@@@@@@@5
##########4004
sheetNameSubmittedMatches5
&&&&&&&&&4004
&&&&&&&&&3003
&&&&&&&&&2002
&&&&&&&&&1001

关键的地方是return语句(见加粗), 如果没有return, 则递归无法退出,因为看l蓝色加粗可知,在全部处理完body后,会继续回到前面一层往下执行, 而且每一层的 i 的值都不一样,说明内存里是不同的变量.

 

若没有return的话, log是

@@@@@@@@@@1
##########0
sheetNameSubmittedMatches1
^^^^^^^^^1001
@@@@@@@@@@2
##########1001
sheetNameSubmittedMatches2
^^^^^^^^^1001
@@@@@@@@@@3
##########2002
sheetNameSubmittedMatches3
^^^^^^^^^1001
@@@@@@@@@@4
##########3003
sheetNameSubmittedMatches4
^^^^^^^^^1001
@@@@@@@@@@5
##########4004
sheetNameSubmittedMatches5
&&&&&&&&&4004
^^^^^^^^^1002
@@@@@@@@@@5
##########4005

 

可以看出在最里面一层的递归结束后, i = 4004 +1 又进入循环里执行了会发生死循环

你可能感兴趣的:(递归)