我是Objective-C的新手,我正在寻找处理原始浮点数的最佳方法,并在Objective-C类中实现-hash方法时加倍.在这个问题中,我已经找到了关于isEqual和hash的一些好建议:
但它没有说明如何处理花车和双打.
我最好的尝试:
...
long lat = [[NSNumber numberWithDouble:self.latitude] longValue];
result = prime * result + (int) (lat ^ (lat >>> 32));
...
Run Code Online (Sandbox Code Playgroud)
但我不确定这是正确的方法.有任何想法吗 ?
我必须调用一些返回无类型java.util.List的Java库代码,我似乎无法将其转换为Scala 2.8列表,而没有编译器borking,并出现以下错误:
[INFO] found : java.util.List[?0] where type ?0
[INFO] required: java.util.List[AnyRef]
[INFO] val modules: Buffer[AnyRef] = asScalaBuffer(feedEntry.getModules)
Run Code Online (Sandbox Code Playgroud)
我试过了正常的
import scala.collection.JavaConversions._
val modules: Buffer[AnyRef] = feedEntry.getModules
Run Code Online (Sandbox Code Playgroud)
作为明确的
val modules: Buffer[AnyRef] = asScalaBuffer(feedEntry.getModules)
Run Code Online (Sandbox Code Playgroud)
我知道列表中的项目类型,我已经尝试将其设置为缓冲区的类型,但我一直得到相同的错误.
我环顾四周,但所有文档都假定要输入Java列表.如何转换无类型列表?
我有一个小的Scala/Neo4j应用程序,通过"技术"和"interestIn"关系链接人和主题.它有一个REST/Json Api(使用Scalatra),当我想在List [Person]和List [Topic]中添加一个"asJson"方法时,我遇到了一个典型的类型擦除问题.我想为不同的内容类型实现不同的Json序列化行为,但当然这些类型会被删除.到目前为止,我能够提出的最好的是以下运行时技巧:
implicit def topicsOrPeopleAsJson[T](list: List[T]) = new {
def asJson: String = {
list match {
case head :: tail if (head.isInstanceOf[Topic]) => topicsToJson(list.asInstanceOf[List[Topic]])
case head :: tail if (head.isInstanceOf[Person]) => peopleToJson(list.asInstanceOf[List[Person]])
case _ => "[]"
}
}
private def peopleToJson(people: List[Person]) = {
...
}
private def topicsToJson(topics: List[Topic]) = {
...
}
}
Run Code Online (Sandbox Code Playgroud)
这工作得很好,但我想知道是否有更好的解决方案,也许包括类型类,一个我不太熟悉的主题(还).