optimize term and terms filter that do no match any documents
This commit is contained in:
parent
1bf30a9d57
commit
becf4baaa2
|
@ -64,7 +64,7 @@ public class PublicTermsFilter extends Filter {
|
|||
@Override
|
||||
public int hashCode() {
|
||||
int hash = 9;
|
||||
for (Iterator<Term> iter = terms.iterator(); iter.hasNext();) {
|
||||
for (Iterator<Term> iter = terms.iterator(); iter.hasNext(); ) {
|
||||
Term term = iter.next();
|
||||
hash = 31 * hash + term.hashCode();
|
||||
}
|
||||
|
@ -73,15 +73,21 @@ public class PublicTermsFilter extends Filter {
|
|||
|
||||
@Override
|
||||
public DocIdSet getDocIdSet(IndexReader reader) throws IOException {
|
||||
OpenBitSet result = new OpenBitSet(reader.maxDoc());
|
||||
OpenBitSet result = null;
|
||||
TermDocs td = reader.termDocs();
|
||||
try {
|
||||
for (Term term : terms) {
|
||||
td.seek(term);
|
||||
if (td.next()) {
|
||||
if (result == null) {
|
||||
result = new OpenBitSet(reader.maxDoc());
|
||||
}
|
||||
result.fastSet(td.doc());
|
||||
while (td.next()) {
|
||||
result.fastSet(td.doc());
|
||||
}
|
||||
}
|
||||
}
|
||||
} finally {
|
||||
td.close();
|
||||
}
|
||||
|
|
|
@ -46,15 +46,18 @@ public class TermFilter extends Filter {
|
|||
}
|
||||
|
||||
@Override public DocIdSet getDocIdSet(IndexReader reader) throws IOException {
|
||||
OpenBitSet result = new OpenBitSet(reader.maxDoc());
|
||||
OpenBitSet result = null;
|
||||
TermDocs td = reader.termDocs();
|
||||
try {
|
||||
td.seek(term);
|
||||
if (td.next()) {
|
||||
result = new OpenBitSet(reader.maxDoc());
|
||||
result.fastSet(td.doc());
|
||||
while (td.next()) {
|
||||
result.fastSet(td.doc());
|
||||
}
|
||||
}
|
||||
finally {
|
||||
} finally {
|
||||
td.close();
|
||||
}
|
||||
return result;
|
||||
|
|
Loading…
Reference in New Issue