加入收藏 | 设为首页 | 会员中心 | 我要投稿 李大同 (https://www.lidatong.com.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 综合聚焦 > 服务器 > 安全 > 正文

Scala参数模式(喷涂路由示例)

发布时间:2020-12-16 19:19:52 所属栏目:安全 来源:网络整理
导读:抱歉模糊的标题…不知道如何表征这一点. 我已经在Scala中看到/使用过某种代码构造已有一段时间了,但我不知道它是如何工作的.它看起来像这样(来自Spray路由的示例): path( "foo" / Segment / Segment ) { (a,b) = { // -- What's this style with a,b?...}}
抱歉模糊的标题…不知道如何表征这一点.

我已经在Scala中看到/使用过某种代码构造已有一段时间了,但我不知道它是如何工作的.它看起来像这样(来自Spray路由的示例):

path( "foo" / Segment / Segment ) { (a,b) => {  // <-- What's this style with a,b?
...
}}

在此示例中,路径中的Segements分别绑定到关联块内的a和b.我知道如何使用这种模式,但它是如何工作的?为什么不把它绑定到“foo”?

我不太喜欢喷雾如何为我的目的而工作,但Scala的设施是什么,我怎么写自己的?

解决方法

Senia的回答有助于理解Spray-routing指令以及它们如何使用HLists进行工作.但我得到的印象是你真的只对使用的Scala结构感兴趣

path( "foo" / Segment / Segment ) { (a,b) => ... }

听起来好像你将它解释为特殊的Scala语法,它以某种方式将这两个Segment实例连接到a和b.事实并非如此.

path( "foo" / Segment / Segment )

只是对带有单个参数的路径的普通调用,该表达式涉及对/方法的两次调用.没什么特别的,只是普通的方法调用.

该调用的结果是一个函数,它需要另一个函数 – 当匹配请求进入时你想要发生的事情 – 作为参数.这就是这部分:

{ (a,b) => ... }

它只是一个有两个参数的函数.第一部分(路径的调用)和第二部分(当收到匹配的消息时你想要做什么)在语法上没有任何关联.它们与Scala完全分开.但是,Spray的语义连接它们:第一部分创建一个函数,当收到匹配的消息时,它将调用第二部分.

(编辑:李大同)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章
      热点阅读