Как я могу проверить объект, чтобы увидеть его тип и вернуть приведенный объект - PullRequest
8 голосов
/ 17 апреля 2010

У меня есть метод, которому я передаю объект. В этом методе я проверяю его тип и, в зависимости от типа, делаю с ним что-то и возвращаю Long. Я попробовал все возможные способы сделать это, и я всегда получаю несколько ошибок компилятора, говорящих мне, что он ожидает определенный объект, но получает другой. Может кто-нибудь объяснить мне, что я делаю неправильно, и направить меня в правильном направлении? То, что я пробовал до сих пор, ниже:

  override def getInteger(obj:Object) = {
    if (obj.isInstanceOf[Object]) null
    else if (obj.isInstanceOf[Number]) 
      (obj:Number).longValue()
    else if (obj.isInstanceOf[Boolean]) 
      if (obj:Boolean) 1 else 0
    else if (obj.isInstanceOf[String]) 
      if ((obj:String).length == 0 | (obj:String) == "null") 
        null
      else
          try {
            Long.parse(obj:String)
          } catch {
            case e: Exception => throw new ValueConverterException("value \"" + obj.toString() + "\" of type " + obj.getClass().getName() + " is not convertible to Long")        
          }
  }

Ответы [ 3 ]

37 голосов
/ 17 апреля 2010

Сопоставление с образцом сделало бы его намного приятнее.

def getInteger(obj: Any) = obj match {
  case n: Number => n.longValue
  case b: Boolean => if(b) 1 else 0
  case s: String if s.length != 0 && s != "null" => s.toLong
  case _ => null
}
6 голосов
/ 17 апреля 2010

Этот код требует использования совпадения:

obj match {
  case n: Number => n.longValue
  case b: Boolean => if (b) 1 else 0
  case s: String => if ((s eq null) || s.length == 0) null else {
            // try ... catch ... etc.
          }
  case o: Object => null
}

Следовал моему собственному совету из моего комментария к моему первоначальному ответу ...

2 голосов
/ 17 апреля 2010

Это может быть начало:

def getInteger (o : Any) : Long = o match {
     case (o: Boolean) => if (o) 1 else 0       
     case (l: Long) => l                        
     case (s: String) => java.lang.Long.parseLong (s)   
     case _ => 0L 
}  

(мне нечего переопределить, и я пропустил попытку / улов для краткости)

...