团队)面向对象设计

一、面向对象程序设计

分为两部分,搜索对象设计和限制,服务层次设计引用。

package news;

/** * <p>Title: 新闻搜索引擎</p>
* <p>Copyright: Copyright (c) 2003</p> * <p>Company: </p> * @author 计算机99630 沈晨 * @version 1.0 * @Download:http://www.codefans.net */

import java.io.IOException;

import org.apache.lucene.analysis.cn.ChineseAnalyzer; import org.apache.lucene.document.Document; import org.apache.lucene.document.Field; import org.apache.lucene.index.IndexWriter;

public class Index {

IndexWriter _writer = null;   Index() throws Exception {     _writer = new IndexWriter("c:\\News\\index",                               new ChineseAnalyzer(), true);   }

/**    * 把每条新闻加入索引中 * @param url 新闻的url    * @param title 新闻的标题 * @throws java.lang.Exception    */   void AddNews(String url, String title) throws Exception {     Document _doc = new Document();     _doc.add(Field.Text("title", title));     _doc.add(Field.UnIndexed("url", url));     _writer.addDocument(_doc);   }

/**    * 优化并且清理资源 * @throws java.lang.Exception    */   void close() throws Exception {     _writer.optimize();     _writer.close();   } }

package news;

/** * <p>Title: 新闻搜索引擎</p>
* <p>Copyright: Copyright (c) 2003</p> * <p>Company: </p> * @author 计算机99630 沈晨 * @version 1.0 * @Download:http://www.codefans.net */

import java.util.Iterator; import java.util.Vector;

import com.heaton.bot.HTMLPage; import com.heaton.bot.HTTP; import com.heaton.bot.Link;

public class HTMLParse {   HTTP _http = null;   public HTMLParse(HTTP http) {     _http = http;   }

/**    * 对Web页面进行解析后建立索引 */ public void start() {     try {       HTMLPage _page = new HTMLPage(_http);       _page.open(_http.getURL(), null);       Vector _links = _page.getLinks();       Index _index = new Index();       Iterator _it = _links.iterator();       int n = 0;       while (_it.hasNext()) {         Link _link = (Link) _it.next();         String _herf = input(_link.getHREF().trim());         String _title = input(_link.getPrompt().trim());         _index.AddNews(_herf, _title);         n++;       }       System.out.println("共扫描到" + n + "条新闻");       _index.close();     }     catch (Exception ex) {       System.out.println(ex);     }   }   /**    * 解决java中的中文问题 * @param str 输入的中文 * @return 经过解码的中文 */ public static String input(String str) {     String temp = null;     if (str != null) {       try {         temp = new String(str.getBytes("ISO8859_1"));       }       catch (Exception e) {       }     }     return temp;   }

}

package news;

/** * <p>Title: 新闻搜索引擎</p>
* <p>Copyright: Copyright (c) 2003</p> * <p>Company: </p>
* @version 1.0   * @Download:http://www.codefans.net */

import com.heaton.bot.HTTP; import com.heaton.bot.HTTPSocket; import com.heaton.bot.ISpiderReportable; import com.heaton.bot.IWorkloadStorable; import com.heaton.bot.Spider; import com.heaton.bot.SpiderInternalWorkload;

public class Searcher     implements ISpiderReportable {   public static void main(String[] args) throws Exception {     IWorkloadStorable wl = new SpiderInternalWorkload();     Searcher _searcher = new Searcher();     Spider _spider         = new Spider(_searcher, "http://www.chenshen.com/index.html",                      new HTTPSocket(), 100, wl);     _spider.setMaxBody(100);     _spider.start();   }   public boolean foundInternalLink(String url) {     return false;   }   public boolean foundExternalLink(String url) {     return false;   }   public boolean foundOtherLink(String url) {     return false;   }   public void processPage(HTTP http) {     System.out.println("扫描网页:" + http.getURL());     new HTMLParse(http).start();   }   public void completePage(HTTP http, boolean error) {   }   public boolean getRemoveQuery() {     return true;   }   public void spiderComplete() {   } }

package newsserver;

import java.io.IOException; import java.io.PrintWriter; import javax.servlet.ServletException; import javax.servlet.http.HttpServlet; import javax.servlet.http.HttpServletRequest; import javax.servlet.http.HttpServletResponse;

import org.apache.lucene.analysis.Analyzer; import org.apache.lucene.analysis.cn.ChineseAnalyzer; import org.apache.lucene.document.Document; import org.apache.lucene.queryParser.QueryParser; import org.apache.lucene.search.Hits; import org.apache.lucene.search.IndexSearcher; import org.apache.lucene.search.Query;

/** * <p>Title: 新闻搜索引擎</p>
* <p>Copyright: Copyright (c) 2003</p> * <p>Company: </p>
* @version 1.0 * @Download:http://www.codefans.net */

public class Results     extends HttpServlet { private static final String CONTENT_TYPE = "text/html; charset=GBK";   //Initialize global variables   public void init() throws ServletException {   }

//Process the HTTP Get request   public void doGet(HttpServletRequest request, HttpServletResponse response) throws       ServletException, IOException {     String QC = request.getParameter("QueryContent");     if (QC == null) {       QC = "";     }     else {       QC = input(QC);     }     response.setContentType(CONTENT_TYPE);     PrintWriter out = response.getWriter();     try {       Search(QC, out);     }     catch (Exception ex) {       System.out.println(ex.getMessage());     }   }

public void Search(String qc, PrintWriter out) throws Exception {     // 从索引目录创建索引 IndexSearcher _searcher = new IndexSearcher("c:\\news\\index");     // 创建标准分析器 Analyzer analyzer = new ChineseAnalyzer();     // 查询条件 String line = qc;     // Query是一个抽象类 Query query = QueryParser.parse(line, "title", analyzer);

out.println("<html>");     out.println("<head><title>搜索结果</title></head>");     out.println("<body bgcolor=#ffffff>");     out.println("<center>" +                 "<form action=‘/NewsServer/results‘ method=‘get‘>" +                 "<font face=‘华文中宋‘ color=‘#3399FF‘>新闻搜索引擎</font>:" +                 "<input type=‘text‘ name=‘QueryContent‘ size=‘20‘>" +                 "<input type=‘submit‘ name=‘submit‘ value=‘开始搜索‘>" +                 "</form></center>"                 );     out.println("<p>搜索关键字:<font color=red>" + query.toString("title") +                 "</font></p>");     Hits hits = _searcher.search(query);     out.println(" 总共找到<font color=red>" + hits.length() + "</font>条新闻<br>");

final int HITS_PER_PAGE = 10;     for (int start = 0; start < hits.length(); start += HITS_PER_PAGE) {       int end = Math.min(hits.length(), start + HITS_PER_PAGE);       for (int i = start; i < end; i++) {         Document doc = hits.doc(i);         String url = doc.get("url");         if (url != null) {           out.println( (i + 1) + " <a href=‘" + url + "‘>" +                       replace(doc.get("title"), qc) +                       "</a><br>");         }         else {           System.out.println("没有找到!");         }       }     } out.println("</body></html>");     _searcher.close();   };

public String input(String str) {     String temp = null;     if (str != null) {       try {         temp = new String(str.getBytes("ISO8859_1"));       }       catch (Exception e) {       }     }     return temp;   }

public String replace(String title, String keyword) {     return title.replaceAll(keyword, "<font color=‘red‘>" + keyword + "</font>");   };

//Clean up resources   public void destroy() {   } }

时间: 2024-08-04 16:17:16

团队)面向对象设计的相关文章

水沝--JAVA团队课程设计博客

水沝--JAVA团队课程设计博客(五子棋) 3.1 团队名称.团队成员介绍.任务分配,团队成员课程设计博客链接(以表格形式呈现),标明组长. 团队名称 成员姓名 任务分配 个人博客链接 水沝 林晓龙(组长) 人机对战算法实现 李金妲 游戏界面的GUI设计.背景音乐功能.趣味对战算法实现 https://www.cnblogs.com/112Ada/p/12173236.html 韦荣桃 实现用户系统功能(登录.注册) https://www.cnblogs.com/Gejkdj/p/121587

7种面向对象设计的强大之处

凭什么要用面向对象来编程,不用是否可以?今天我们通过讲这么几个设计原则来说明为什么要用面向对象,它的好处在哪里. 一.单一职责原则: 全称:“Single-Responsibility Principle”面向对象设计 说明:就一个类而言,应该只专注于做一件事和仅有一个引起它变化的原因.所谓职责,我们可以理解他为功能,就是设计的这个类功能应该只有一个,而不是两个或更多.也可以理解为引用变化的原因,当你发现有两个变化会要求我们修改这个类,那么你就要考虑撤分这个类了.因为职责是变化的一个轴线,当需求

Java程序员应该了解的10个面向对象设计原则

面向对象设计原则: 是OOPS(Object-Oriented Programming System,面向对象的程序设计系统)编程的核心,但大多数Java程序员追逐像Singleton.Decorator.Observer这样的设计模式,而不重视面向对象的分析和设计.甚至还有经验丰富的Java程序员没有听说过OOPS和SOLID设计原则,他们根本不知道设计原则的好处,也不知道如何依照这些原则来进行编程. 众所周知,Java编程最基本的原则就是要追求高内聚和低耦合的解决方案和代码模块设计.查看Ap

设计模式2 面向对象设计原则

面向对象设计原则  原则的目的 面向对象设计原创表  单一职责原则案例 开闭原则 案例 依赖倒转原则 案例 面向对象设计原则  对于面向对象软件系统的设计而言,在支持可维护性的同时,提高系统的可复用性是一个至关重要的问题,如何同时提高一个软件系统的可维护性和可复用性是面向对象设计需要解决的核心问题之一.在面向对象设计中,可维护性的复用是以设计原则为基础的.每一个原则都蕴含一些面向对象设计的思想,可以从不同的角度提升一个软件结构的设计水平.  面向对象设计原则为支持可维护性复用而诞生,这些原则蕴含

面向对象设计原则

七大原则:开闭原则.里氏代换原则.依赖倒转原则.合成/聚合复用原则.迪米特法则.接口隔离原则,单一职责原则. 开闭原则是面向对象的可复用的基石.其他六种原则是手段和工具. 各规则详细(本部分为转载) http://kb.cnblogs.com/page/214010/ 正如牛顿三大定律在经典力学中的位置一样,“开-闭”原则(Open-Closed Principle)是面向对象的可复用设计(Object Oriented Design或OOD)的基石.其他设计原则(里氏代换原则.依赖倒转原则.合

面向对象设计的SOLID原则

S.O.L.I.D是面向对象设计和编程(OOD&OOP)中几个重要编码原则(Programming Priciple)的首字母缩写. SRP The Single Responsibility Principle 单一责任原则 OCP The Open Closed Principle  开放封闭原则 LSP The Liskov Substitution Principle 里氏替换原则 DIP The Dependency Inversion Principle 依赖倒置原则 ISP The

软件工程概论第八章--面向对象设计

面向对象设计主要讲设计的概念.软件体系结构.系统设计.详细设计.应用设计模式.用户界面设计和设计文档等方面知识,面向对象的设计是面向对象技术中比较重要的阶段. 设计的概念中讲了设计活动和设计原则,设计是一个建模活动,此活动能实现从需求分析到软件实现间的跨越.设计原则主要有模块化.耦合度和内聚性和复用性,模块化可以使复杂的系统简化,耦合度和内聚性分别是子系统间的关联程度和系统内部的相关程度,降低耦合性提高内聚性.复用性利用以开发的软件元素生成新的软件系统. 软件体系结构主要有仓库体系结构,分层体系

【设计模式】#001 面向对象设计的八个原则

1.对于面向对象的软件系统设计来说,在支持可维护性的同事,需要提高系统的可复用性 2.软件的复用可以提高软件的开发效率,提高软件的质量,节约开发成本,恰当的复用还可以改善系统的可维护性 3.面向对象设计简化成三条 3.1 封装变化点 3.2 对接口编程 3.3 多使用组合,少使用继承 点击查看大图:

面向对象设计——“泛型”的起步

泛型是 2.0 版 C# 语言和公共语言运行库 (CLR) 中的一个新功能.泛型将类型参数的概念引入 .NET Framework,类型参数使得设计如下类和方法成为可能:这些类和方法将一个或多个类型的指定推迟到客户端代码声明并实例化该类或方法的时候.例如,通过使用泛型类型参数 T,您可以编写其他客户端代码能够使用的单个类,而不致引入运行时强制转换或装箱操作的成本或风险. --MSDN 我的计算机是以Visual Basic 6.0拉开帷幕的,让我印象比较深的是两个排序:选择排序和冒泡排序.当然本

面向对象设计——协变与逆变

在面向对象的设计中,我们一直追求一种结果,就是良好的复用性,基于这个理念,面向对象的设计中加入了协变与逆变(Covariance and Contravariance)两个概念,我们先来简单了解一下这两个概念. 简介: 协变:由子类向父类方向转变, 用out关键字标识 逆变:由父类向子类方向转变, 用in关键字 举例:Animal是父类,Dog是从Animal继承的子类:如果一个对象的类型是Dog,那么他必然是Animal.有一个获取宠物的方法要接受Dog参数,那么另一个接受Animal参数的方