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 又进入循环里执行了会发生死循环