Scala中(of class scala.Tuple2)异常,match case匹配失败

使用UntypedAbstractActor时,出现message匹配不上自定义的对象,但是debug时发现类型确实是,而且用了case class,各种方法都不行

类结构,最终有效代码:

abstract class Master(latch: CountDownLatch) extends UntypedAbstractActor {
override def onReceive(message: Any) = {

    logger.info("master,actor is:" + self)
    logger.info("Master当前消息类型:" + message.getClass.getSimpleName)
    message match {
        //启动
        case start: String => {
            logger.info("=======================start================")
            visitedPageStore.add(start)
            getParser() ! visitedPageStore.getNext()
        }
        //页面
        case (content: PageContent, _) => {
            logger.info("========================page==============")
            getIndexer() ! content
            //存储待访问页面链接
            visitedPageStore.addAll(content.getLinksToFollow())
            if (visitedPageStore.isFinished()) {
                //完成了则提交
                getIndexer() ! COMMIT_MESSAGE
            } else {
                //继续获取下一个页面
                for (page <- visitedPageStore.getNextBatch()) {
                    getParser() ! page
                }
            }

        }
        //索引
        case (indexedMessage: IndexedMessage, _) => {
            logger.info("====================index=================")
            visitedPageStore.finished(indexedMessage.getPath)
            if (visitedPageStore.isFinished())
                getIndexer() ! COMMIT_MESSAGE

        }
        //提交
        case (COMMITTED_MESSAGE, _) => {
            logger.info("======================end================")
            logger.info("Shutting down, finished")
            getContext().system.terminate()
            latch.countDown()
        }
        case _ => {
            logger.info("Unknown execution steps")
        }
    }

}
}
子类:
class SimpleActorMaster(latch: CountDownLatch) extends Master(latch) {}

打印当前message的类型输出如下:

Master当前消息类型:String

Master当前消息类型:Tuple2

这里第二次匹配case的时候竟然是元组类型,仔细看debug,

难怪原来使用case content: PageContent一直匹配不成功。。原来message消息类型不是纯粹的就是消息本身的类型,可能还携带了actor地址。。。

 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值