本文整理汇总了C#中Lucene.Net.Index.IndexWriter.NumRamDocs方法的典型用法代码示例。如果您正苦于以下问题:C# Lucene.Net.Index.IndexWriter.NumRamDocs方法的具体用法?C# Lucene.Net.Index.IndexWriter.NumRamDocs怎么用?C# Lucene.Net.Index.IndexWriter.NumRamDocs使用的例子?那么, 这里精选的方法代码示例或许可以为您提供帮助。您也可以进一步了解该方法所在类Lucene.Net.Index.IndexWriter
的用法示例。
在下文中一共展示了Lucene.Net.Index.IndexWriter.NumRamDocs方法的1个代码示例,这些例子默认根据受欢迎程度排序。您可以为喜欢或者感觉有用的代码点赞,您的评价将有助于系统推荐出更棒的C#代码示例。
示例1: IndexWriteHandler
/// <summary>
/// ����ִ����
/// </summary>
public void IndexWriteHandler()
{
//�����ĵ�������д��
writer = new Lucene.Net.Index.IndexWriter(Directorys.IndexDirectory, new ThesaurusAnalyzer(), !File.Exists(Directorys.IndexDirectory + "segments.gen"));
//���������Ƭ����
writer.SetMaxBufferedDocs(maxBufferLength);
//�״�����Ż�
writer.Optimize();
int count = 0;
//����ѭ��
while (true)
{
//����ɾ������
while (deleteQueue.Count > 0 && count < maxBufferLength)
{
count++;
writer.DeleteDocuments(deleteQueue.Dequeue());
}
//������¶���
while (updateQueue.Count > 0 && count < maxBufferLength)
{
count++;
Lucene.Net.Documents.Document doc = updateQueue.Dequeue();
writer.UpdateDocument(new Lucene.Net.Index.Term("id", doc.Get("id")), doc);
}
//������������
while (addQueue.Count > 0 && count < maxBufferLength)
{
count++;
writer.AddDocument(addQueue.Dequeue());
}
//������뵵����Ƭ
if (writer.NumRamDocs() > 0)
{
writer.Flush();
}
//��������Ƿ�ﵽ�����,�����������ʱ�Ż���Ƭ,�����߳���ͣ100����
if (count >= maxBufferLength)
{
writer.Optimize();
count = 0;
}
else
{
Thread.Sleep(100);
}
}
}