private String queryOrgDn(String parentid,String dn){
System.out.println("parentid : " +parentid);
int len = parentid.trim().length();
while(len > 5) {
AndFilter filter = new AndFilter();
filter.and(new EqualsFilter("objectclass","uumOrg"));
filter.and(new EqualsFilter("ESSPorgId",parentid));
List<Org> alist = ldapTemplate_user.search("", filter.encode(),new OrgAttributeMapper());
System.out.println("alist : " + alist.size());
if(null!=alist&&0<alist.size()){
Org _aorg = alist.get(0);
String _parentid = _aorg.getESSPparentId();
String _dn = dn + _aorg.getOu();
queryOrgDn(_parentid,_dn);//@2 这里循环调用此方法
}else break;
}
return dn;//@1
}
我打断点调试过了,在运行到@1处后,程序又会回到@2处,陷入死循环。不是很懂递归调用,请指教!谢谢
递归 Java
------解决方案--------------------
先前的程序中:你那个if语句的判定条件是alist.size()>0 , 但是你if语句里面并没有对 alist 数组长度改变什么,所以你的成句在 len < 5 的时候会一直循环
你加return后:你的程序会递归调用该方法,找到你想要的值,if条件不满足了,就会 break 掉,最后返回的想要的值。
你想要的递归一个是调用自身的方法来递归的
------解决方案--------------------
递归是自己调用自己,你不return的话,上一层调用就得不到返回值