У меня есть абстрактный абстрактный класс Java и несколько подклассов, которые содержат аннотацию на уровне класса под названием @DBTable
. Я пытаюсь искать иерархию классов для аннотаций с использованием хвостовой рекурсией метода Scala:Ошибка аннотации Scala tailrec
def getDbTableForClass[A <: ImmutableEntity](cls: Class[A]): String = {
@tailrec
def getDbTableAnnotation[B >: A](cls: Class[B]): DBTable = {
if (cls == null) {
null
} else {
val dbTable = cls.getAnnotation(classOf[DBTable])
if (dbTable != null) {
dbTable
} else {
getDbTableAnnotation(cls.getSuperclass)
}
}
}
val dbTable = getDbTableAnnotation(cls)
if (dbTable == null) {
throw new
IllegalArgumentException("No DBTable annotation on class " + cls.getName)
} else {
val value = dbTable.value
if (value != null) {
value
} else {
throw new
IllegalArgumentException("No DBTable.value annotation on class " + cls.getName)
}
}
}
Когда я скомпилировать этот код, я получаю ошибку: «не могу оптимизировать @tailrec аннотированного метода: он называется рекурсивно с различными аргументами типа ". Что не так с моим внутренним методом?
Спасибо.
Спасибо за объяснение. Кстати, отличный язык! – Ralph
Я также буду замечать: какое точное точное сообщение об ошибке! «Не удалось оптимизировать метод @tailrec annotated: он называется рекурсивно с разными аргументами типа». Тот, кто пишет такие драгоценные камни, должен быть одним классным котом. – extempore