亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频

? 歡迎來(lái)到蟲(chóng)蟲(chóng)下載站! | ?? 資源下載 ?? 資源專輯 ?? 關(guān)于我們
? 蟲(chóng)蟲(chóng)下載站

?? treeobject.java

?? 用JAVA實(shí)現(xiàn)的對(duì)動(dòng)態(tài)樹(shù)狀信息的管理。操作員可以通過(guò)IE瀏覽器查看整個(gè)樹(shù)形結(jié)構(gòu)信息
?? JAVA
字號(hào):
package com.socialite.bizlogic.tree;

 
import com.socialite.bizlogic.tree.TreeNodeObject;
import com.socialite.bizlogic.util.XMLObject;

import javax.swing.tree.DefaultTreeModel;
import javax.swing.tree.DefaultMutableTreeNode;
import java.util.HashMap;
import java.util.ArrayList;
/*
DynamicTreeDemo:

rootNode = new DefaultMutableTreeNode("Root Node");
treeModel = new DefaultTreeModel(rootNode);
treeModel.addTreeModelListener(new MyTreeModelListener());

tree = new JTree(treeModel);
tree.setEditable(true);
tree.getSelectionModel().setSelectionMode
        (TreeSelectionModel.SINGLE_TREE_SELECTION);
tree.setShowsRootHandles(true);

By explicitly creating the tree's model, the code guarantees 
that the tree's model is an instance of DefaultTreeModel. That 
way, we know all the methods that the tree model supports. For 
example, we know that we can invoke the model's insertNodeInto 
method, even though that method is not required by the TreeModel 
interface.
*/

//TreeObject的同步,ArrayList,HashMap對(duì)象的同步還沒(méi)有考慮(考慮了前者,后者應(yīng)該就有保證了)


 public class TreeObject{
 	
 	private DefaultTreeModel dfModel;
	private TreeNodeObject node;
	private DefaultMutableTreeNode fatherDfNode=null;
	private TreeNodeObject rootNode=null;
	private DefaultMutableTreeNode dfNode;
	private static HashMap hMap=new HashMap(200);
	
	private ArrayList aList=new ArrayList();
	
	
	//構(gòu)造函數(shù),組裝DefaultTreeModel
	
	public TreeObject(XMLObject xmlTree){
		
		String c=xmlTree.getValue("bizlogic.resultparameter.count");
		
		int count=0;
		if(c==null){
			//什么也不做,此時(shí)rootNode==null
		}else{
			
			
    		try{    
        		count=Integer.parseInt(c);
        	}catch(NumberFormatException e){
        		
        		return;//什么也不做,此時(shí)rootNode==null
        	}
        }
        
        
        //先以根節(jié)點(diǎn)構(gòu)造一個(gè)DefaultTreeModel
        String node_id="0";
        String father_id=null;
        String name="Root";
        String url=null;
        
        //以rootNode為根節(jié)點(diǎn)構(gòu)造一個(gè)DefaultTreeModel樹(shù)對(duì)象
        rootNode=new TreeNodeObject(node_id,father_id,name,url);
        dfNode=new DefaultMutableTreeNode(rootNode);
        dfModel=new DefaultTreeModel(dfNode);
        
        //HashMap中添加node_id到dfNode的映射
        hMap.put(node_id,dfNode);
         
        //開(kāi)始組裝樹(shù) 
        for(int i=1;i<=count;i++){
        	node_id=xmlTree.getValue("bizlogic.resultparameter.node_id"+i);
        	father_id=xmlTree.getValue("bizlogic.resultparameter.father_id"+i);
        	name=xmlTree.getValue("bizlogic.resultparameter.name"+i);
        	url=xmlTree.getValue("bizlogic.resultparameter.url"+i);
        	
        	//構(gòu)造一個(gè)TreeNodeObject對(duì)象
        	node=new TreeNodeObject(node_id,father_id,name,url);
        	
        	//以node對(duì)象為UserObject構(gòu)造一DefaultMutableTreeNode
        	dfNode=new DefaultMutableTreeNode(node);
        	
        	if(!(node_id.trim().equalsIgnoreCase("0"))){//不是root
				
				
				//查找父親節(jié)點(diǎn)
				fatherDfNode=(DefaultMutableTreeNode)hMap.get(father_id);
				if(fatherDfNode!=null){//找到則添加為子節(jié)點(diǎn)
					fatherDfNode.add(dfNode);
					
					//HashMap中添加node_id到dfNode的映射
        			hMap.put(node_id,dfNode);
					
				}else{//找不到則先將TreeNodeObject類(lèi)型對(duì)象node放入ArrayList
					
					aList.add(node);
				}
        	}
        }
        
        //多次遍歷ArrayList,將沒(méi)有組裝到樹(shù)中的節(jié)點(diǎn)組裝	
        
        while(!(aList.isEmpty())){
        	int aListSize=aList.size();
        	for(int i=0;i<aListSize;i++){
        		node=(TreeNodeObject)aList.get(i);
        		dfNode=new DefaultMutableTreeNode(node);
        		node_id=node.getNodeId();
        		father_id=node.getFatherId();
        		
        		//查找父親節(jié)點(diǎn)
				fatherDfNode=(DefaultMutableTreeNode)hMap.get(father_id);
				if(fatherDfNode!=null){//找到則添加為子節(jié)點(diǎn)
					fatherDfNode.add(dfNode);
					
					//HashMap中添加node_id到dfNode的映射
        			hMap.put(node_id,dfNode);
					
					//刪除ArrayList中該節(jié)點(diǎn) 
        			aList.remove(i);
                }
            }
       }
    }
    /*
    *
    * 判斷是否組裝了實(shí)際的樹(shù)
    */
   /*ublic boolean isExist(){
    	if(!rootNode==null){
    		return true;
    	}
    	return false;
    }
    */
    
    //增加新節(jié)點(diǎn)
    public void addNode(TreeNodeObject who){
    	DefaultMutableTreeNode fatherDfNode=null;
    	DefaultMutableTreeNode dfNode=null;
    	
    	String node_id=who.getNodeId();
    	String father_id=who.getFatherId();
    	
    	dfNode=new DefaultMutableTreeNode(who);
    	fatherDfNode=(DefaultMutableTreeNode)hMap.get(father_id);
    	
    	fatherDfNode.add(dfNode);//執(zhí)行增加子節(jié)點(diǎn)	
    	
    	//HashMap中添加node_id到dfNode的映射
        hMap.put(node_id,dfNode);
        
    }
    
    //刪除節(jié)點(diǎn),如果是非葉子節(jié)點(diǎn)則子樹(shù)一起刪除
    public void deleteNode(TreeNodeObject who){
    	DefaultMutableTreeNode dfNode=null;
    	
    	String node_id=who.getNodeId();

    	//從hashMap中得到要?jiǎng)h除的對(duì)象
    	dfNode=(DefaultMutableTreeNode)hMap.get(node_id);
    	
    	//修改hashMap
    	
    	//???更新HashMap,此時(shí)已經(jīng)被刪除的子樹(shù)中節(jié)點(diǎn)已經(jīng)不存在,hMap對(duì)應(yīng)的值應(yīng)該是null???
    	//hMap.remove(node_id);//這種方法行嗎,需要用下面的第歸方法嗎
    	
    	removeObjectFromHashMap(node_id);
    	
    	//Removes the subtree rooted at this node from the tree, giving this node a null parent.
    	dfNode.removeFromParent();//從樹(shù)中刪除該節(jié)點(diǎn)對(duì)應(yīng)的子樹(shù)
    	
    }
    
    //第歸刪除HashMap中的節(jié)點(diǎn)
    private void removeObjectFromHashMap(String whoId){
    	
    	DefaultMutableTreeNode dfNode=null;
    	
    	//String node_id=who.getNodeId();

    	//從hashMap中得到要?jiǎng)h除的mapping
    	dfNode=(DefaultMutableTreeNode)hMap.get(whoId);

    	DefaultMutableTreeNode dfChild=null;
    	TreeNodeObject child=null;
    	String node_id=null;
    	
    	int childCount=dfNode.getChildCount();

    	if(childCount==0){
    		hMap.remove(whoId);
    	}else{
    		for(int i=1;i<childCount;i++){
    			
    			//得到DefaultMutableTreeNode,轉(zhuǎn)化為T(mén)reeNodeObject,得到node_id
    			dfChild=(DefaultMutableTreeNode)dfNode.getChildAt(i);
    			child=(TreeNodeObject)dfChild.getUserObject();
    			node_id=child.getNodeId();
    			
    			//第歸調(diào)用
    			removeObjectFromHashMap(node_id);
    		}
    	}
    }
    
    
    //修改節(jié)點(diǎn)(node_id是不能變的),father_id也不能改變,如果要改變father_id,以后實(shí)現(xiàn)move方法
    public void modifyNode(TreeNodeObject newNode){
    	
    	DefaultMutableTreeNode dfNode=null;
    	TreeNodeObject node=null;
    	
    	String node_id=newNode.getNodeId();

    	//從hashMap中得到要修改的對(duì)象
    	dfNode=(DefaultMutableTreeNode)hMap.get(node_id);
    	node=(TreeNodeObject)dfNode.getUserObject();
    	
    	//String old_father_id=node.getFatherId();
    	//String new_node_id=newNode.getNodeId();
    	//String new_father_id=newNode.getFatherId();
    	String new_name=newNode.getName();
    	String new_url=newNode.getUrl();
    	
    	node.setName(new_name);
    	node.setUrl(new_url);
    	
    	//下面的工作還需要嗎
    	dfNode=new DefaultMutableTreeNode(node);
    	hMap.put(node_id,dfNode);
    	
    }
  	
    	
}
    	
    	
 /*
TreeObject.java的幾個(gè)問(wèn)題:
(1)第93行,108行,119行,124行。
看出來(lái)問(wèn)題沒(méi)有?93和119無(wú)論結(jié)點(diǎn)是否能在散列表中找到父結(jié)點(diǎn),都創(chuàng)建一個(gè)DefaultMutableTreeNode,不錯(cuò)但效率低下。應(yīng)當(dāng)在找到父結(jié)點(diǎn)之后(100和125的for循環(huán)內(nèi)部)才創(chuàng)建一個(gè)DefaultMutableTreeNode表示子結(jié)點(diǎn)。
(2)117到134的for循環(huán)
有問(wèn)題。如果132行remove一個(gè)元素,將導(dǎo)致后續(xù)元素整體向前挪動(dòng)。導(dǎo)致問(wèn)題一:整體挪動(dòng)效率低下。問(wèn)題二:下標(biāo)i++將使得一個(gè)元素在這趟for循環(huán)中無(wú)法訪問(wèn)到。
解決辦法一:仍然使用ArrayList,針對(duì)第二個(gè)問(wèn)題,在132行之后加一個(gè)i--。
解決辦法二:將aList定義為鏈表LinkedList,而不是ArrayList;并且不要通過(guò)get(int),而是通過(guò)迭代器ListIterator的next()和remove()。
(3)115行開(kāi)始的while循環(huán)
有死循環(huán)的可能性。如果一趟while循環(huán)沒(méi)有使得aList元素個(gè)數(shù)減少呢?所以在while循環(huán)外部首先記錄aList長(zhǎng)度,在循環(huán)內(nèi)部最后判斷aList長(zhǎng)度是否發(fā)生了變化,如果未變化則跳出while循環(huán)(接下來(lái)該怎么處理,你自己決定)。
(4)178的疑問(wèn)
應(yīng)該用你定義的遞歸方法removeObjectFromHashMap,這樣刪除得徹底。
(5)242的疑問(wèn)
不需要。因?yàn)槟闶菍?duì)散列表中的對(duì)象調(diào)用方法,并不影響散列表今后的查找。
(6)221的move方法,比較容易,你應(yīng)該會(huì)寫(xiě)吧。
注:這幾點(diǎn)在v2中修改
*/       	
        	
        		
			
			
		
		
		

?? 快捷鍵說(shuō)明

復(fù)制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號(hào) Ctrl + =
減小字號(hào) Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
亚洲韩国精品一区| 99国产欧美久久久精品| 亚洲成av人片www| 一区二区三区毛片| 一区二区三区四区亚洲| 国产精品乱码一区二区三区软件 | 成人av小说网| 成人免费视频一区| 成人免费观看视频| 99视频精品全部免费在线| av成人老司机| 欧美亚洲国产一区在线观看网站 | 中文字幕亚洲成人| 亚洲色图欧美在线| 亚洲综合丝袜美腿| 日韩av一级电影| 久久精品国产亚洲5555| 国产在线日韩欧美| 成人午夜看片网址| 91免费视频网址| 欧美欧美午夜aⅴ在线观看| 欧美一区二区免费视频| 久久在线观看免费| 欧美经典一区二区三区| 亚洲天堂福利av| 午夜精品一区二区三区免费视频| 日韩精品视频网站| 国产一区二区精品久久99| 成人性生交大片免费看视频在线 | 麻豆成人久久精品二区三区红| 久久狠狠亚洲综合| 国产成人综合亚洲网站| 91免费观看视频在线| 欧美男男青年gay1069videost| 日韩一区二区高清| 国产日韩欧美高清| 亚洲综合999| 国内久久精品视频| 色国产综合视频| 日韩美一区二区三区| 国产精品久久久久久久岛一牛影视| 亚洲欧美视频在线观看| 午夜影院在线观看欧美| 国产福利91精品| 欧美亚洲图片小说| 国产午夜精品一区二区| 亚洲一区二区精品视频| 国产黄色精品视频| 欧美亚洲一区二区三区四区| 国产亚洲一区二区三区四区 | 最新热久久免费视频| 亚洲18色成人| 国产成人在线观看免费网站| 欧美视频在线播放| 中文天堂在线一区| 秋霞国产午夜精品免费视频| 99视频热这里只有精品免费| 日韩免费高清av| 亚洲一级片在线观看| 成人一级视频在线观看| 日韩三级伦理片妻子的秘密按摩| 中文字幕av一区二区三区高| 日本va欧美va瓶| 91黄视频在线| 国产精品美女久久久久aⅴ| 美日韩一级片在线观看| 欧美丝袜第三区| 中文字幕一区在线观看| 国内外成人在线视频| 4438x亚洲最大成人网| 亚洲天天做日日做天天谢日日欢 | 在线一区二区视频| 国产欧美一区二区三区鸳鸯浴 | 久久精品国产澳门| 91久久精品一区二区三区| 久久久久久毛片| 麻豆精品一二三| 91免费视频观看| 亚洲欧洲色图综合| 国产精品1024| 精品精品国产高清a毛片牛牛| 性做久久久久久免费观看欧美| 97se亚洲国产综合自在线观| 欧美高清在线精品一区| 精品一区二区三区蜜桃| 欧美丝袜第三区| 亚洲综合男人的天堂| 色婷婷综合久久久中文字幕| 国产精品传媒入口麻豆| 成人看片黄a免费看在线| 久久蜜臀中文字幕| 激情成人综合网| 精品少妇一区二区三区在线播放 | 国产成a人无v码亚洲福利| 日韩精品一区二区三区在线观看| 五月激情综合网| 在线亚洲免费视频| 亚洲综合一二区| 欧美性色欧美a在线播放| 一卡二卡三卡日韩欧美| 在线中文字幕一区二区| 亚洲一区二区高清| 欧美三日本三级三级在线播放| 亚洲资源在线观看| 2欧美一区二区三区在线观看视频| 亚洲国产精品久久久男人的天堂 | 欧美videofree性高清杂交| 美女视频黄免费的久久 | 3d成人动漫网站| 日韩高清一级片| 日韩一级成人av| 久久se精品一区二区| 亚洲精品一区二区三区99| 国产精品1区二区.| 中文字幕成人在线观看| 99久精品国产| 亚洲一区二区高清| 日韩一区二区精品在线观看| 韩国成人精品a∨在线观看| 久久久精品一品道一区| 成人性色生活片| 一区二区免费视频| 欧美二区三区的天堂| 老司机精品视频在线| 久久日一线二线三线suv| 成人精品亚洲人成在线| 一区二区高清在线| 日韩一区二区精品葵司在线 | 欧美久久久一区| 久久99久久99| 国产精品视频看| 欧美亚洲国产一区二区三区va | 在线精品视频一区二区| 爽爽淫人综合网网站| 久久综合一区二区| 不卡的电影网站| 亚洲超碰97人人做人人爱| 日韩精品自拍偷拍| 成人av电影在线| 香蕉影视欧美成人| 久久久久久久久久久电影| 91丨九色丨尤物| 麻豆视频一区二区| 亚洲天堂成人在线观看| 日韩一区二区高清| 99精品国产99久久久久久白柏| 婷婷久久综合九色综合伊人色| 精品国产乱码久久久久久牛牛| av欧美精品.com| 六月丁香综合在线视频| 国产精品国产三级国产普通话蜜臀 | 99精品欧美一区| 日韩1区2区日韩1区2区| 国产精品嫩草影院av蜜臀| 欧美丰满美乳xxx高潮www| 国产成人精品亚洲777人妖| 亚洲一区二区在线视频| 久久久高清一区二区三区| 欧美三级电影网站| 国产91精品一区二区麻豆网站| 亚洲国产视频一区| 日本一区二区三区电影| 欧美一级免费观看| 色综合婷婷久久| 国产激情一区二区三区| 日本特黄久久久高潮| 自拍偷在线精品自拍偷无码专区 | 精品国产乱码久久| 欧美丝袜丝交足nylons图片| 国产成人免费av在线| 日韩av不卡在线观看| 亚洲精品视频在线观看免费| 久久久综合视频| 91精品国产免费久久综合| 91久久奴性调教| www.成人网.com| 国产精品亚洲一区二区三区在线 | 成人激情免费视频| 伦理电影国产精品| 亚洲国产精品久久久久秋霞影院| 国产精品欧美精品| 国产亚洲欧美中文| 欧美草草影院在线视频| 欧美精品日韩一区| 91国偷自产一区二区三区成为亚洲经典 | 亚洲成人资源在线| 亚洲欧美激情小说另类| 国产欧美日韩激情| 久久天天做天天爱综合色| 91精品国产高清一区二区三区蜜臀| 色哟哟日韩精品| 91蝌蚪porny九色| 成人午夜激情片| 大胆欧美人体老妇| 国产成人免费网站| 国产伦精品一区二区三区在线观看 | 香蕉成人伊视频在线观看| 一区二区三区免费观看| 亚洲卡通欧美制服中文| 国产精品传媒视频|