0

首先,我很抱歉我的英语不好,如果有什么不能理解的,请告诉我。

我有 2 个 Jtree。每棵树显然都有相同的信息。它们中唯一改变的是具有每个节点的属性的名称。

例如,JTree1 有一个 ID 和一个 ParentID。这些属性具有名称和值。名称:ID_Tree1。值:TESTID1 //名称:ParentID_Tree1。值:JTree2中的TESTPID1与JTree1中的值相同但名称不同。

有一段时间我将一个节点从 JTree1 转移到 JTree2 以创建它。传输/创建是正确的,但是当我读取节点时,它具有不同的属性名称架构(Jtree1 架构。)并且无法读取,因为需要具有 JTree2 架构。我有函数 changeAttributesNamesFromDOORSToTC() 来解决问题,因为它只是将名称更改为正确的名称并且 JTree2 可以理解

真正的问题:该函数在 JTree2 的节点中进行了更改,但同时它更改了 JTree1 中同一节点的值名称。它制作参考数据而不是我认为的作业。

我该如何解决这个问题!?

谢谢!

JTree treeDOORSCode; //JTree1
JTree treeTCCode;  //JTree2

主要代码:

//ACTUAL NODE
DefaultMutableTreeNode selectedTreeNode = (DefaultMutableTreeNode) CurrentSelection.getLastPathComponent();
NodeClass actualNode = (NodeClass)selectedTreeNode.getUserObject();


//ACTUAL PARENT NODE
DefaultMutableTreeNode selectedParentTreeNode = (DefaultMutableTreeNode)     selectedTreeNode.getParent();
NodeClass parentNode = (NodeClass) selectedParentTreeNode.getUserObject();
DefaultMutableTreeNode parent = findNode(NodeClass.getNodeParentIdentifierAttrDOORS(parentNode), treeTCCode);


//NEW NODE
DefaultMutableTreeNode newSelectedTreeNode = selectedTreeNode;

//NEW PART
NodeClass newNode = new NodeClass();
        newNode = insertNodeInfo(actualNode);

//Create the Model and insert the node
DefaultTreeModel treeModelTC = (DefaultTreeModel)treeTCCode.getModel();
treeModelTC.insertNodeInto(newSelectedTreeNode, parent, 0);

//NEW PART
newNode .changeAttributesNamesFromDOORSToTC();
newSelectedTreeNode.setUserObject(newNode);

更改 attr Name 值的函数:

public void changeAttributesNamesFromDOORSToTC(){

    for (int i = 0; i < this.attributes.size(); i++) {
        if (this.attributes.get(i).attributeName.equals(DOORS_ID)){
            if (this.tag.equals(TYPE_NAME_CASE)){
                this.attributes.get(i).attributeName = TC_IDCASE;
            }
            if (this.tag.equals(TYPE_NAME_FOLDER)){
                this.attributes.get(i).attributeName = TC_IDFOLDER;
            }
            if (this.tag.equals(TYPE_NAME_FEATURE)){
                this.attributes.get(i).attributeName = TC_IDFEATURE;
            }
        }
        if (this.attributes.get(i).attributeName.equals(DOORS_PARENTID)){
            this.attributes.get(i).attributeName = TC_PARENTID;
        }
        if (this.attributes.get(i).attributeName.equals(DOORS_SRS)){
            this.attributes.get(i).attributeName = TC_SRS;
        }

    }
}

属性类:

NodeAttributesClass (String attributeName, String attributeValue)
{
    this.attributeName = attributeName;
    this.attributeValue = attributeValue;
}

如果需要更多信息,请告诉我!

4

1 回答 1

0

java中的对象赋值实际上是一个引用副本。

NodeClass newActualNode = actualNode;

该行并不意味着“将 object actualNode 的值放入 object newActualNode”,因为实际上变量 actualNode 不是 NodeClass 的实例,而是对NodeClass 实例的引用。因此,当您NodeClass newActualNode = actualNode;复制引用时,现在两个变量都有效地指向同一个实例。

那么当你改变一个“the other”中的属性名称时,它也会改变,因为没有这样的other,它在内存中的同一个地方。

现在,您需要做的是使用您想要的值创建一个新的 NodeClass 实例。有几种方法可以做到这一点,我很难知道哪个更合适,因为我不知道内部结构,但最后你需要:

  • 为 newActualNode 变量创建一个新的 NodeClass 实例
  • 将 actualNode 的值(字段)放入 newActualNode
  • 在 newActualNode 中分配所需的属性名称

所以,它可能是这样的:

NodeClass newActualNode = new NodeClass(actualNode);  //copy constructor  NodeClass(NodeClass anotherNode);
newActualNode.changeAttributesNamesFromDOORSToTC(); //assuming the constructor doesn't put them right

或者您可以在 NodeClass 构造函数中使用一个标志来指示您想要什么样的属性名称。

并且复制构造函数应该如下所示:

public NodeClass(NodeClass anotherNode)
{
    this(anotherNode.someFields); //call to your "normal" constructor, with whatever params you need

    //copy the values into the new instance this, if you didn't do it in the above line
    this.field1 = anotherNode.field1;
    this.field2 = anotherNode.field2;
    //...
    this.fieldn = anotherNode.fieldn;
}

您可以对这段代码持保留态度,有几种方法可以做到这一点,如果有的话,差异是微妙的。重要的是您需要为另一棵树创建另一个实例。

编辑

如果这不起作用,我的猜测是,您需要newSelectedTreeNode.setUserObject(newNode);在插入之前执行此操作,如下所示:

NodeClass newNode = new NodeClass();
newNode = insertNodeInfo(actualNode);
newNode.changeAttributesNamesFromDOORSToTC();
DefaultMutableTreeNode newSelectedTreeNode = new DefaultMutableTreeNode();
newSelectedTreeNode.setUserObject(newNode);
treeModelTC.insertNodeInto(newSelectedTreeNode, parent, 0);

或者parent计算不正确,特别是您获得的是treeDOORSCode的父节点,而不是treeTCCode的父节点。

于 2013-07-30T11:48:56.333 回答