创建类似java对象层次结构的树

时间:2012-08-20 02:26:40

标签: java android parsing rss

我正在尝试为Android创建一个Manga应用程序,其中每个章节都有自己的标题,发布日期,描述等。每个章节都属于一个漫画对象。这将是一个章节的集合,并将包括标题列表加上漫画本身的标题和作者(的)名称。数据本身将从不同的网页中解析(但这是另一个网站)。

我的困惑是关于阶级声明。 (即实施,延伸)

我尝试了很多东西,但是现在我的代码包括将章节作为内部类,如下所示:

public abstract class Manga implements MangaList {
public String name;
public String author;
public int chapters;

// names of the XML tags
static final String CHANNEL = "channel";
static final String PUB_DATE = "pubDate";
static final  String DESCRIPTION = "description";
static final  String LINK = "link";
static final  String TITLE = "title";
static final  String ITEM = "item";

private final URL feedUrl;

protected Manga(String feedUrl){
    try {
        this.feedUrl = new URL(feedUrl);
    } catch (MalformedURLException e) {
        throw new RuntimeException(e);
    }
}

protected InputStream getInputStream() {
    try {
        return feedUrl.openConnection().getInputStream();
    } catch (IOException e) {
        throw new RuntimeException(e);
    }
}

List<Chapter> Chapter;

public class Chapter implements Comparable<Chapter> {

    final SimpleDateFormat FORMATTER = 
            new SimpleDateFormat("EEE, dd MMM yyyy HH:mm:ss Z");
        private String title;
        private URL link;
        private String description;
        private Date date;

        public String getTitle() {
            return title;
        }

        public void setTitle(String title) {
            this.title = title.trim();
        }
        // getters and setters omitted for brevity 
        public URL getLink() {
            return link;
        }

        public void setLink(String link) {
            try {
                this.link = new URL(link);
            } catch (MalformedURLException e) {
                throw new RuntimeException(e);
            }
        }

        public String getDescription() {
            return description;
        }

        public void setDescription(String description) {
            this.description = description.trim();
        }

        public String getDate() {
            return FORMATTER.format(this.date);
        }

        public void setDate(String date) {
            // pad the date if necessary
            while (!date.endsWith("00")){
                date += "0";
            }
            date = "";
            try {
                this.date = FORMATTER.parse(date.trim());
            } catch (ParseException e) {
                throw new RuntimeException(e);
            }
        }

        public Chapter copy(){
            Chapter copy = new Chapter();
            copy.title = title;
            copy.link = link;
            copy.description = description;
            copy.date = date;
            return copy;
        }

        @Override
        public String toString() {
            StringBuilder sb = new StringBuilder();
            sb.append("Title: ");
            sb.append(title);
            sb.append('\n');
            sb.append("Date: ");
            sb.append(this.getDate());
            sb.append('\n');
            sb.append("Link: ");
            sb.append(link);
            sb.append('\n');
            sb.append("Description: ");
            sb.append(description);
            return sb.toString();
        }

        @Override
        public int hashCode() {
            final int prime = 31;
            int result = 1;
            result = prime * result + ((date == null) ? 0 : date.hashCode());
            result = prime * result
                    + ((description == null) ? 0 : description.hashCode());
            result = prime * result + ((link == null) ? 0 : link.hashCode());
            result = prime * result + ((title == null) ? 0 : title.hashCode());
            return result;
        }

        @Override
        public boolean equals(Object obj) {
            if (this == obj)
                return true;
            if (obj == null)
                return false;
            if (getClass() != obj.getClass())
                return false;
            Chapter other = (Chapter) obj;
            if (date == null) {
                if (other.date != null)
                    return false;
            } else if (!date.equals(other.date))
                return false;
            if (description == null) {
                if (other.description != null)
                    return false;
            } else if (!description.equals(other.description))
                return false;
            if (link == null) {
                if (other.link != null)
                    return false;
            } else if (!link.equals(other.link))
                return false;
            if (title == null) {
                if (other.title != null)
                    return false;
            } else if (!title.equals(other.title))
                return false;
            return true;
        }

        public int compareTo(Chapter another) {
            if (another == null) return 1;
            // sort descending, most recent first
            return another.date.compareTo(date);
        }
}

我的问题是,如果这是一种合适的格式,或者是否有更简单的方法来创建一个Mangas列表,每个都有自己的章节?

编辑:我查了一下,并决定使用SQLite数据库是一种更简单的方法来跟踪我将要解析的大量数据。

这样我可以维护两个数据库。一个用于漫画标题和作者,另一个用于章节和相关信息。相关章节将通过参考ID链接到每个表格中的漫画。

1 个答案:

答案 0 :(得分:1)

我绝对认为有一种更简单的方法可以做到这一点;但是,这实际上取决于你的总体目标是什么。如果您尝试在list中显示此内容,可以考虑使用ListView,但如果您只是将数据用于内容,则可以执行类似于您所拥有的操作。最终,你需要弄清楚你将如何处理应用程序,然后你可以找出实现它的最简单方法。但请记住:更容易并不总是更好。尝试并长期考虑您的项目,例如谁将要维护它,是否会增长或缩小,以及是否要添加功能。

至于extendsimplements,它们分别是subclassesinterfaces,并且有不同的规则,可以在此处找到更多信息:http://docs.oracle.com/javase/tutorial/java/concepts/interface.html

祝你好运!