Twitter4j:搜索和跟踪之间的区别

Twitter4j : difference between search and track

我从 Twitter4j 开始,我需要从 Stream 获取带有特定主题标签的推文。

我找到了 2 种方法:

StatusListener listener = new StatusListener() {
...
    public void onStatus(Status status) {
                statuses.add(status);
                HashtagEntity[] H = status.getHashtagEntities();
                System.out.println(statuses.size()+":Got tweet:\n" + status.getText()+"\n"+status.getUser().getScreenName()
                        + " | "+status.getId()+" | "+H.length+"\n");
                if(H.length>0){
                    for(int i=0;i<H.length-1;i++){
                        System.out.print(H[i]+"");
                    }
                }
                if (statuses.size() > nbremax) {
                    synchronized (lock) {
                        lock.notify();
                    }
                    System.out.println("unlocked");
                }
            }
}
FilterQuery fq = new FilterQuery();    
fq.track("#hashtag");
TwitterStream twitterStream = ...;
twitterStream.addListener(listener);
twitterStream.filter(fq);

Twitter twitter = ...;
Query query = new Query("#hastag");
QueryResult result = twitter.search(query);
for (Status status : result.getTweets()) {
    HashtagEntity[] H = status.getHashtagEntities();
    System.out.println("Got tweet:\n" + status.getText()
            +"\n"+status.getUser().getScreenName()+ " | "+status.getId()+
            " | retweet ? "+status.isRetweet()+" | "+H.length);
    System.out.println(status.getCreatedAt()+" | "+status.getGeoLocation()+
                    " | "+status.getPlace()+" | "+status.getSource());
    if(H.length>0){
        for(int i=0;i<H.length;i++){
            System.out.print(H[i].getText()+" ; ");
            if(i==H.length-1){
               System.out.println("\n");
            }
        }
    }

它们有什么区别?哪种方法最适合搜索特定主题标签?

搜索:您将检索所有现有 包含给定主题标签的推文立即

track :所有包含给定主题标签的推文都将给你从现在 .