📄 arraybunch.java
字号:
/*
(c) Copyright 2005, 2006, 2007 Hewlett-Packard Development Company, LP
All rights reserved - see end of file.
$Id: ArrayBunch.java,v 1.13 2007/01/02 11:52:20 andy_seaborne Exp $
*/
package com.hp.hpl.jena.mem;
import java.util.ConcurrentModificationException;
import com.hp.hpl.jena.graph.Triple;
import com.hp.hpl.jena.graph.query.*;
import com.hp.hpl.jena.util.iterator.*;
/**
An ArrayBunch implements TripleBunch with a linear search of a short-ish
array of Triples. The array can grow, but it only grows by 4 elements each time
(because, if it gets big enough for this linear growth to be bad, it should anyways
have been replaced by a more efficient set-of-triples implementation).
@author kers
*/
public class ArrayBunch implements TripleBunch
{
protected int size = 0;
protected Triple [] elements;
protected volatile int changes = 0;
public ArrayBunch()
{ elements = new Triple[5]; }
public boolean containsBySameValueAs( Triple t )
{
int i = size;
while (i > 0) if (t.matches( elements[--i])) return true;
return false;
}
public boolean contains( Triple t )
{
int i = size;
while (i > 0) if (t.equals( elements[--i] )) return true;
return false;
}
public int size()
{ return size; }
public void add( Triple t )
{
if (size == elements.length) grow();
elements[size++] = t;
changes += 1;
}
/**
Note: linear growth is suboptimal (order n<sup>2</sup>) normally, but
ArrayBunch's are meant for <i>small</i> sets and are replaced by some
sort of hash- or tree- set when they get big; currently "big" means more
than 9 elements, so that's only one growth spurt anyway.
*/
protected void grow()
{
Triple [] newElements = new Triple[size + 4];
System.arraycopy( elements, 0, newElements, 0, size );
elements = newElements;
}
public void remove( Triple t )
{
changes += 1;
for (int i = 0; i < size; i += 1)
{
if (t.equals( elements[i] ))
{ elements[i] = elements[--size];
return; }
}
}
public void app( Domain d, StageElement next, MatchOrBind s )
{
int i = size, initialChanges = changes;
while (i > 0)
{
if (changes > initialChanges) throw new ConcurrentModificationException();
if (s.matches( elements[--i] )) next.run( d );
}
}
public ExtendedIterator iterator()
{
return iterator( new HashCommon.NotifyEmpty() { public void emptied() {} } );
}
public ExtendedIterator iterator( final HashCommon.NotifyEmpty container )
{
// System.err.println( ">> ArrayBunch::iterator: intial state" );
// for (int j = 0; j < size; j += 1) System.err.println( "== " + elements[j] );
// System.err.println( ">> (done)" );
return new NiceIterator()
{
protected final int initialChanges = changes;
protected int i = size;
protected final Triple [] e = elements;
public boolean hasNext()
{
if (changes > initialChanges) throw new ConcurrentModificationException();
return i > 0;
}
public Object next()
{
if (changes > initialChanges) throw new ConcurrentModificationException();
if (i == 0) noElements( "no elements left in ArrayBunch iteration" );
return e[--i];
}
public void remove()
{
if (changes > initialChanges) throw new ConcurrentModificationException();
// System.err.println( ">> ArrayBunch.iterator::remove" );
// System.err.println( "++ size currently " + size );
// System.err.println( "++ container is " + container );
// System.err.println( "++ selector currently " + i + " (triple " + e[i] + ")" );
int last = --size;
e[i] = e[last];
e[last] = null;
if (size == 0) container.emptied();
// System.err.println( "++ post remove, triples are:" );
// for (int j = 0; j < size; j += 1) System.err.println( "== " + e[j] );
}
};
}
}
/*
* (c) Copyright 2005, 2006, 2007 Hewlett-Packard Development Company, LP
* All rights reserved.
*
* Redistribution and use in source and binary forms, with or without
* modification, are permitted provided that the following conditions
* are met:
* 1. Redistributions of source code must retain the above copyright
* notice, this list of conditions and the following disclaimer.
* 2. Redistributions in binary form must reproduce the above copyright
* notice, this list of conditions and the following disclaimer in the
* documentation and/or other materials provided with the distribution.
* 3. The name of the author may not be used to endorse or promote products
* derived from this software without specific prior written permission.
*
* THIS SOFTWARE IS PROVIDED BY THE AUTHOR ``AS IS'' AND ANY EXPRESS OR
* IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES
* OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED.
* IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR ANY DIRECT, INDIRECT,
* INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT
* NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
* DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
* THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
* (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF
* THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
*/
⌨️ 快捷键说明
复制代码
Ctrl + C
搜索代码
Ctrl + F
全屏模式
F11
切换主题
Ctrl + Shift + D
显示快捷键
?
增大字号
Ctrl + =
减小字号
Ctrl + -