⭐ 欢迎来到虫虫下载站! | 📦 资源下载 📁 资源专辑 ℹ️ 关于我们
⭐ 虫虫下载站

📄 nodeset.java

📁 java1.6众多例子参考
💻 JAVA
📖 第 1 页 / 共 3 页
字号:
      {        m_map = new Node[m_blocksize];        m_mapSize = m_blocksize;      }      else      {        m_mapSize += m_blocksize;        Node newMap[] = new Node[m_mapSize];        System.arraycopy(m_map, 0, newMap, 0, ff + 1);        m_map = newMap;      }    }    m_map[ff] = value;    ff++;    m_firstFree = ff;  }  /**   * Pop a node from the tail of the vector and return the result.   *   * @return the node at the tail of the vector   */  public final Node pop()  {    m_firstFree--;    Node n = m_map[m_firstFree];    m_map[m_firstFree] = null;    return n;  }  /**   * Pop a node from the tail of the vector and return the   * top of the stack after the pop.   *   * @return The top of the stack after it's been popped    */  public final Node popAndTop()  {    m_firstFree--;    m_map[m_firstFree] = null;    return (m_firstFree == 0) ? null : m_map[m_firstFree - 1];  }  /**   * Pop a node from the tail of the vector.   */  public final void popQuick()  {    m_firstFree--;    m_map[m_firstFree] = null;  }  /**   * Return the node at the top of the stack without popping the stack.   * Special purpose method for TransformerImpl, pushElemTemplateElement.   * Performance critical.   *   * @return Node at the top of the stack or null if stack is empty.     */  public final Node peepOrNull()  {    return ((null != m_map) && (m_firstFree > 0))           ? m_map[m_firstFree - 1] : null;  }  /**   * Push a pair of nodes into the stack.     * Special purpose method for TransformerImpl, pushElemTemplateElement.   * Performance critical.   *   * @param v1 First node to add to vector   * @param v2 Second node to add to vector   */  public final void pushPair(Node v1, Node v2)  {    if (null == m_map)    {      m_map = new Node[m_blocksize];      m_mapSize = m_blocksize;    }    else    {      if ((m_firstFree + 2) >= m_mapSize)      {        m_mapSize += m_blocksize;        Node newMap[] = new Node[m_mapSize];        System.arraycopy(m_map, 0, newMap, 0, m_firstFree);        m_map = newMap;      }    }    m_map[m_firstFree] = v1;    m_map[m_firstFree + 1] = v2;    m_firstFree += 2;  }  /**   * Pop a pair of nodes from the tail of the stack.    * Special purpose method for TransformerImpl, pushElemTemplateElement.   * Performance critical.   */  public final void popPair()  {    m_firstFree -= 2;    m_map[m_firstFree] = null;    m_map[m_firstFree + 1] = null;  }  /**   * Set the tail of the stack to the given node.   * Special purpose method for TransformerImpl, pushElemTemplateElement.   * Performance critical.   *   * @param n Node to set at the tail of vector   */  public final void setTail(Node n)  {    m_map[m_firstFree - 1] = n;  }  /**   * Set the given node one position from the tail.   * Special purpose method for TransformerImpl, pushElemTemplateElement.   * Performance critical.   *   * @param n Node to set   */  public final void setTailSub1(Node n)  {    m_map[m_firstFree - 2] = n;  }  /**   * Return the node at the tail of the vector without popping   * Special purpose method for TransformerImpl, pushElemTemplateElement.   * Performance critical.   *   * @return Node at the tail of the vector   */  public final Node peepTail()  {    return m_map[m_firstFree - 1];  }  /**   * Return the node one position from the tail without popping.   * Special purpose method for TransformerImpl, pushElemTemplateElement.   * Performance critical.   *   * @return Node one away from the tail   */  public final Node peepTailSub1()  {    return m_map[m_firstFree - 2];  }  /**   * Inserts the specified node in this vector at the specified index.   * Each component in this vector with an index greater or equal to   * the specified index is shifted upward to have an index one greater   * than the value it had previously.   *   * @param value Node to insert   * @param at Position where to insert   */  public void insertElementAt(Node value, int at)  {    if (!m_mutable)      throw new RuntimeException(XSLMessages.createXPATHMessage(XPATHErrorResources.ER_NODESET_NOT_MUTABLE, null)); //"This NodeSet is not mutable!");    if (null == m_map)    {      m_map = new Node[m_blocksize];      m_mapSize = m_blocksize;    }    else if ((m_firstFree + 1) >= m_mapSize)    {      m_mapSize += m_blocksize;      Node newMap[] = new Node[m_mapSize];      System.arraycopy(m_map, 0, newMap, 0, m_firstFree + 1);      m_map = newMap;    }    if (at <= (m_firstFree - 1))    {      System.arraycopy(m_map, at, m_map, at + 1, m_firstFree - at);    }    m_map[at] = value;    m_firstFree++;  }  /**   * Append the nodes to the list.   *   * @param nodes NodeVector to append to this list   */  public void appendNodes(NodeSet nodes)  {    int nNodes = nodes.size();    if (null == m_map)    {      m_mapSize = nNodes + m_blocksize;      m_map = new Node[m_mapSize];    }    else if ((m_firstFree + nNodes) >= m_mapSize)    {      m_mapSize += (nNodes + m_blocksize);      Node newMap[] = new Node[m_mapSize];      System.arraycopy(m_map, 0, newMap, 0, m_firstFree + nNodes);      m_map = newMap;    }    System.arraycopy(nodes.m_map, 0, m_map, m_firstFree, nNodes);    m_firstFree += nNodes;  }  /**   * Inserts the specified node in this vector at the specified index.   * Each component in this vector with an index greater or equal to   * the specified index is shifted upward to have an index one greater   * than the value it had previously.   */  public void removeAllElements()  {    if (null == m_map)      return;    for (int i = 0; i < m_firstFree; i++)    {      m_map[i] = null;    }    m_firstFree = 0;  }  /**   * Removes the first occurrence of the argument from this vector.   * If the object is found in this vector, each component in the vector   * with an index greater or equal to the object's index is shifted   * downward to have an index one smaller than the value it had   * previously.   *   * @param s Node to remove from the list   *   * @return True if the node was successfully removed   */  public boolean removeElement(Node s)  {    if (!m_mutable)      throw new RuntimeException(XSLMessages.createXPATHMessage(XPATHErrorResources.ER_NODESET_NOT_MUTABLE, null)); //"This NodeSet is not mutable!");    if (null == m_map)      return false;    for (int i = 0; i < m_firstFree; i++)    {      Node node = m_map[i];      if ((null != node) && node.equals(s))      {        if (i < m_firstFree - 1)          System.arraycopy(m_map, i + 1, m_map, i, m_firstFree - i - 1);        m_firstFree--;        m_map[m_firstFree] = null;        return true;      }    }    return false;  }  /**   * Deletes the component at the specified index. Each component in   * this vector with an index greater or equal to the specified   * index is shifted downward to have an index one smaller than   * the value it had previously.   *   * @param i Index of node to remove   */  public void removeElementAt(int i)  {    if (null == m_map)      return;          if (i >= m_firstFree)      throw new ArrayIndexOutOfBoundsException(i + " >= " + m_firstFree);    else if (i < 0)      throw new ArrayIndexOutOfBoundsException(i);    if (i < m_firstFree - 1)      System.arraycopy(m_map, i + 1, m_map, i, m_firstFree - i - 1);    m_firstFree--;    m_map[m_firstFree] = null;  }  /**   * Sets the component at the specified index of this vector to be the   * specified object. The previous component at that position is discarded.   *   * The index must be a value greater than or equal to 0 and less   * than the current size of the vector.   *   * @param node Node to set   * @param index Index of where to set the node   */  public void setElementAt(Node node, int index)  {    if (!m_mutable)      throw new RuntimeException(XSLMessages.createXPATHMessage(XPATHErrorResources.ER_NODESET_NOT_MUTABLE, null)); //"This NodeSet is not mutable!");    if (null == m_map)    {      m_map = new Node[m_blocksize];      m_mapSize = m_blocksize;    }    m_map[index] = node;  }  /**   * Get the nth element.   *   * @param i Index of node to get   *   * @return Node at specified index   */  public Node elementAt(int i)  {    if (null == m_map)      return null;    return m_map[i];  }  /**   * Tell if the table contains the given node.   *   * @param s Node to look for   *   * @return True if the given node was found.   */  public boolean contains(Node s)  {    runTo(-1);    if (null == m_map)      return false;    for (int i = 0; i < m_firstFree; i++)    {      Node node = m_map[i];      if ((null != node) && node.equals(s))        return true;    }    return false;  }  /**   * Searches for the first occurence of the given argument,   * beginning the search at index, and testing for equality   * using the equals method.   *   * @param elem Node to look for   * @param index Index of where to start the search   * @return the index of the first occurrence of the object   * argument in this vector at position index or later in the   * vector; returns -1 if the object is not found.   */  public int indexOf(Node elem, int index)  {    runTo(-1);    if (null == m_map)      return -1;    for (int i = index; i < m_firstFree; i++)    {      Node node = m_map[i];      if ((null != node) && node.equals(elem))        return i;    }    return -1;  }  /**   * Searches for the first occurence of the given argument,   * beginning the search at index, and testing for equality   * using the equals method.   *   * @param elem Node to look for    * @return the index of the first occurrence of the object   * argument in this vector at position index or later in the   * vector; returns -1 if the object is not found.   */  public int indexOf(Node elem)  {    runTo(-1);    if (null == m_map)      return -1;    for (int i = 0; i < m_firstFree; i++)    {      Node node = m_map[i];      if ((null != node) && node.equals(elem))        return i;    }    return -1;  }}

⌨️ 快捷键说明

复制代码 Ctrl + C
搜索代码 Ctrl + F
全屏模式 F11
切换主题 Ctrl + Shift + D
显示快捷键 ?
增大字号 Ctrl + =
减小字号 Ctrl + -