我正在尝试为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链接到每个表格中的漫画。
答案 0 :(得分:1)
我绝对认为有一种更简单的方法可以做到这一点;但是,这实际上取决于你的总体目标是什么。如果您尝试在list
中显示此内容,可以考虑使用ListView
,但如果您只是将数据用于内容,则可以执行类似于您所拥有的操作。最终,你需要弄清楚你将如何处理应用程序,然后你可以找出实现它的最简单方法。但请记住:更容易并不总是更好。尝试并长期考虑您的项目,例如谁将要维护它,是否会增长或缩小,以及是否要添加功能。
至于extends
和implements
,它们分别是subclasses
和interfaces
,并且有不同的规则,可以在此处找到更多信息:http://docs.oracle.com/javase/tutorial/java/concepts/interface.html
祝你好运!