- 浏览: 96044 次
- 性别:
- 来自: 武汉
文章分类
最新评论
-
fengweiyou:
只取当前年月日 TRUNC(SYSDATE) 就可以了
oracle函数只取年月日 -
spp_1987:
我在页面上 显示出来的 怎么是乱码啊。 能解决下吗
是什 ...
struts+jquery -
spp_1987:
//JSONObject json = JSONObject. ...
struts+jquery -
spp_1987:
不知道为什么 有错啊。 我用的是DispatchAction啊 ...
struts+jquery -
hiteny:
还是css用着方便@ 谢谢啦
css控制字符串显示长度
接着昨天学习的Lucene-2.3.1 源代码阅读学习(11)继续学习。
IndexWriter的一个构造器,定义如下所示:
已经知道,init方法的复杂性和重要性。对init方法所涉及到的有用的相关类进行系统地学习。
init方法的声明是这样的:
Directory是一个抽象类,它是与目录有关的一个类,主要定义了一些与目录相关的属性和行为,源代码如下所示:
从Directory抽象类的定义,我们可以得到如下几点:
1、管理锁工厂及其锁实例;
2、管理Directory目录实例的基本属性,主要是通过文件名称进行管理;
3、管理与操作该目录相关的一些流对象;
4、管理索引文件的拷贝。
然后就要对Directory抽象类的具体实现类进行学习了。
IndexWriter的一个构造器,定义如下所示:
public IndexWriter(String path, Analyzer a, boolean create) throws CorruptIndexException, LockObtainFailedException, IOException { init(FSDirectory.getDirectory(path), a, create, true, null, true); }
已经知道,init方法的复杂性和重要性。对init方法所涉及到的有用的相关类进行系统地学习。
init方法的声明是这样的:
private void init(Directory d, Analyzer a, final boolean create, boolean closeDir, IndexDeletionPolicy deletionPolicy, boolean autoCommit)
Directory是一个抽象类,它是与目录有关的一个类,主要定义了一些与目录相关的属性和行为,源代码如下所示:
package org.apache.lucene.store; import java.io.IOException; public abstract class Directory { // 有目录相关的一个锁工厂,主要是为向目录中写入文件服务,使用工厂模式,写入文件内容必须获取锁 protected LockFactory lockFactory; // 获取该目录下的所有文件名称字符串的一个数组 public abstract String[] list() throws IOException; // 判断指定文件名称为name的文件是否存在 public abstract boolean fileExists(String name) throws IOException; // 获取指定文件名称为name的文件最后修改的时间 public abstract long fileModified(String name) throws IOException; // 设置指定文件名称为name的文件的修改时间为当前时间 public abstract void touchFile(String name) throws IOException; // 删除已经存在于该目录下的指定文件名称为namde的文件 public abstract void deleteFile(String name) throws IOException; // 重新命名文件,将原文件名from修改为to public abstract void renameFile(String from, String to) throws IOException; // 获取指定文件名称为name的文件的长度 public abstract long fileLength(String name) throws IOException; // 在该目录下创建一个名称为name的文件,同时返回一个索引输出流,以便向其中写入内容 public abstract IndexOutput createOutput(String name) throws IOException; // 读取该目录下名称为name的文件,返回一个输入流,以便对该文件进行相关操作 public abstract IndexInput openInput(String name) throws IOException; /** 读取该目录下名称为name的文件,指定了读入缓冲区的大小为bufferSize,返回一个输入流 * Currently the only Directory implementations that respect this * parameter are {@link FSDirectory} and {@link * org.apache.lucene.index.CompoundFileReader}. */ public IndexInput openInput(String name, int bufferSize) throws IOException { return openInput(name); } // 获取一个锁对象,其中name指定的锁文件的名称,即write.lock文件 public Lock makeLock(String name) { return lockFactory.makeLock(name); } // 当指定名称为name的锁文件不再被使用的时候,从锁工厂LockFactory中清除该锁;注意:是从内存中清除,并非从文件系统中删除。 public void clearLock(String name) throws IOException { if (lockFactory != null) { lockFactory.clearLock(name); } } // 关闭该目录,不再对该目录操作了 public abstract void close() throws IOException; // 当该目录被管理,要对其进行操作之前,必须先创建一个锁工厂LockFactory实例,只有拥有了锁工厂才可以获取锁实例 public void setLockFactory(LockFactory lockFactory) { this.lockFactory = lockFactory; lockFactory.setLockPrefix(this.getLockID()); } // 获取锁工厂实例 public LockFactory getLockFactory() { return this.lockFactory; } // 过去锁实例的唯一表示ID的字符串描述 public String getLockID() { return this.toString(); } // 拷贝源目录src下的文件,复制到目的目录dest下面,拷贝完成后关闭源目录src public static void copy(Directory src, Directory dest, boolean closeDirSrc) throws IOException { final String[] files = src.list(); // 获取源目录src下的所有文件 if (files == null) // 如果源目录src下没有文件,则抛出异常 throw new IOException("cannot read directory " + src + ": list() returned null"); // 如果获取到的源目录src目录下的文件列表files不空,就执行复制操作 byte[] buf = new byte[BufferedIndexOutput.BUFFER_SIZE]; for (int i = 0; i < files.length; i++) { IndexOutput os = null; IndexInput is = null; try { // 在目的目录dest下面创建一个新文件,名称与从源目录src下获得的文件名称相同 os = dest.createOutput(files[i]); // 打开源目录下对应的该文件,返回一个索引输入流 is = src.openInput(files[i]); // 复制到目录目录下 long len = is.length(); long readCount = 0; while (readCount < len) { int toRead = readCount + BufferedIndexOutput.BUFFER_SIZE > len ? (int) (len - readCount) : BufferedIndexOutput.BUFFER_SIZE; is.readBytes(buf, 0, toRead); // 以字节流的方式读取源目录的文件,将toRead个字节读入到缓冲区buf中 os.writeBytes(buf, toRead); // 以字节流的方式写入目的目录的文件中,将缓冲区buf中toRead个字节写入到目的目录对应的文件中 readCount += toRead; } } finally { // 最后要关闭输入流 try { if (os != null) os.close(); } finally { if (is != null) is.close(); // 关闭输入流 } } } if (closeDirSrc) src.close(); // 关闭源目录 } }
从Directory抽象类的定义,我们可以得到如下几点:
1、管理锁工厂及其锁实例;
2、管理Directory目录实例的基本属性,主要是通过文件名称进行管理;
3、管理与操作该目录相关的一些流对象;
4、管理索引文件的拷贝。
然后就要对Directory抽象类的具体实现类进行学习了。
发表评论
-
Lucene学习(22)
2009-10-30 11:14 883关于FieldInfos类和FieldInfo类。 Fi ... -
Lucene学习(21)
2009-10-30 11:12 847回到IndexWriter索引器类中来,学习该类添加Docum ... -
Lucene学习(20)
2009-10-30 11:06 1034关于Field类和Document类。 ... -
Lucene学习(19)
2009-10-30 11:01 824研究SegmentInfo类的实现 ... -
Lucene学习(18)
2009-10-30 10:47 1876关于SegmentInfos类的具体 ... -
Lucene学习(17)
2009-10-30 10:40 857根据16中对IndexFileDeleter ... -
Lucene学习(16)
2009-10-30 10:33 1073在接触到索引删除的策略IndexDeletionPolicy ... -
Lucene学习(15)
2009-10-30 10:28 877关于索引删除的策略IndexDeletionPolicy 。 ... -
Lucene学习(14)
2009-10-30 10:23 760RAMDirectory类是与内存目录相关的,它和FSDire ... -
Lucene学习(13)
2009-10-30 10:21 1370Directory抽象类比较常用的具体实现子类应该是FSDir ... -
Lucene学习(11)
2009-10-30 10:06 1122对数据源进行分析,是为建立索引服务的;为指定的文件建立索引,是 ... -
Lucene学习(10)
2009-10-30 10:02 840Lucene的CJKAnalyzer分析器。 CJKAnal ... -
Lucene学习(9)
2009-10-30 09:34 917Lucene的StandardAnalyzer分析器。 ... -
Lucene学习(8)
2009-10-30 09:27 818Lucene分析器的实现。 Lucene(分词)过滤器Tok ... -
Lucene学习(7)
2009-10-30 09:22 757CharTokenizer是一个抽象类 ... -
Lucene学习(6)
2009-10-29 16:16 863Lucene分析器的实现。 Lucene分词器Tokeniz ... -
Lucene学习(5)
2009-10-29 16:13 899研究Lucene分析器的实现。 Analyzer抽象类 ... -
Lucene学习(4)
2009-10-29 16:09 881建立索引,通过已经生成的索引文件,实现通过关键字检索。 ... -
Lucene学习(3)
2009-10-29 16:06 848org.apache.lucene.demo.IndexFil ... -
Lucene学习(2)
2009-10-29 15:59 812IndexWriter是一个非常重要的工具。建立索引必须从它开 ...
相关推荐
【标题】:“Lucene学习资料收集” 【描述】:Lucene是一个开源的全文搜索引擎库,由Apache软件基金会开发。这个资料集可能包含了关于如何理解和使用Lucene的各种资源,特别是通过博主huanglz19871030在iteye上的...
**Lucene学习指南** Lucene是一个高性能、全文检索库,由Apache软件基金会开发并维护,是Java编程语言中广泛使用的搜索引擎库。它提供了一个简单的API,使得开发者能够方便地在应用中实现全文检索功能。本篇文章将...
Lucene的基础知识 1、案例分析:什么是全文检索,如何实现全文检索 2、Lucene实现全文检索的流程 a) 创建索引 b) 查询索引 3、配置开发环境 4、创建索引库 5、查询索引库 6、分析器的分析过程 a) 测试分析器的分词...
"lucene学习pdf2" 提供的文档,无疑是对Lucene深入理解的一把钥匙,它涵盖了Lucene的核心概念、操作流程以及高级特性。 首先,Lucene的基础知识是必不可少的。Lucene的核心在于索引和搜索,它将非结构化的文本数据...
本文将主要围绕Java Lucene进行深入探讨,并基于提供的“Lucene学习源码.rar”文件中的“Lucene视频教程_讲解部分源码”展开讨论。 一、Lucene核心概念 1. 文档(Document):Lucene中的基本单位,用于存储待检索...
《Lucene学习资料》 Lucene是一个开源的全文搜索引擎库,由Apache软件基金会维护。它提供了高级的文本分析和索引功能,使得开发者能够轻松地在应用程序中集成强大的搜索功能。这个资料包中的《Lucene in Action_2nd...
本篇文章将围绕"Lucene-2.0学习文档"的主题,结合Indexer.java、MyScoreDocComparator.java和MySortComparatorSource.java这三个关键文件,深入探讨Lucene的核心概念和实际应用。 首先,我们来看`Indexer.java`。这...
**Lucene 3.3.0 学习Demo** Lucene是一个开源的全文搜索引擎库,由Apache软件基金会开发。在3.3.0版本中,Lucene提供了强大的文本搜索功能,包括分词、索引创建、查询解析和结果排序等。这个"Lucene3.3.0学习Demo...
【标题】:“Lucene学习-02” 在深入探讨“Lucene学习-02”这一主题之前,我们先来理解一下Lucene的核心概念。Lucene是一个高性能、全文本搜索库,由Apache软件基金会开发,广泛应用于各种搜索引擎和信息检索系统。...
**Lucene.net学习帮助文档** Lucene.net是一个开源全文搜索引擎库,它是Apache Lucene项目的一部分,专门针对.NET Framework进行了优化。这个压缩包包含了Lucene.net的源码和中文学习文档,旨在帮助开发者深入理解...
在"一步一步跟我学习lucene(12)---lucene搜索之分组处理group查询"中,我们将重点关注如何利用Lucene实现这一高级搜索功能。 首先,Lucene是一个开源全文搜索引擎库,它为Java开发者提供了构建高效、可扩展的搜索...
【Lucene 3.6 学习笔记】 Lucene 是一个高性能、全文本搜索库,广泛应用于各种搜索引擎的开发。本文将深入探讨Lucene 3.6版本中的关键概念、功能以及实现方法。 ### 第一章 Lucene 基础 #### 1.1 索引部分的核心...
lucene学习笔记 1 .txt lucene学习笔记 2.txt lucene学习笔记 3 .txt lucene入门实战.txt Lucene 的学习 .txt Lucene-2.0学习文档 .txt Lucene入门与使用 .txt lucene性能.txt 大富翁全文索引和查询的例子...
通过这些学习资料,读者可以系统地学习搜索引擎的理论基础,掌握Lucene的核心功能,同时也能了解到如何在实际项目中应用这些技术,提升搜索系统的性能和用户体验。这些知识对于从事信息检索、网站开发、大数据分析等...
**Lucene学习工具包** Lucene是一个开源的全文搜索引擎库,由Apache软件基金会开发并维护。这个"Lucene学习工具包.zip"包含了学习Lucene所需的重要资料和资源,旨在帮助开发者深入理解和掌握Lucene的核心概念、功能...
《Lucene 4.8学习指南与实战案例分析》 Lucene是一个强大的全文搜索引擎库,由Apache软件基金会开发,主要用于Java环境。版本4.8在功能和性能上都有显著提升,是许多开发者进行文本检索应用开发的重要工具。本文将...