您好,登錄后才能下訂單哦!
本篇內容介紹了“scala的泛型類怎么使用”的有關知識,在實際案例的操作過程中,不少人都會遇到這樣的困境,接下來就讓小編帶領大家學習一下如何處理這些情況吧!希望大家仔細閱讀,能夠學有所成!
泛型類指可以接受類型參數的類。泛型類在集合類中被廣泛使用。
泛型類使用方括號 []
來接受類型參數。一個慣例是使用字母 A
作為參數標識符,當然你可以使用任何參數名稱。
class Stack[A] { private var elements: List[A] = Nil def push(x: A) { elements = x :: elements } def peek: A = elements.head def pop(): A = { val currentTop = peek elements = elements.tail currentTop }}
上面的 Stack
類的實現中接受類型參數 A
。這表示其內部的列表,var elements: List[A] = Nil
,只能夠存儲類型 A
的元素。方法 def push
只接受類型 A
的實例對象作為參數(注意:elements = x :: elements
將 elements
放到了一個將元素 x
添加到 elements
的頭部而生成的新列表中)。
要使用一個泛型類,將一個具體類型放到方括號中來代替 A
。
val stack = new Stack[Int]stack.push(1)stack.push(2)println(stack.pop) println(stack.pop)
實例對象 stack
只能接受整型值。然而,如果類型參數有子類型,子類型可以被傳入:
class Fruit
class Apple extends Fruit
class Banana extends Fruit
val stack = new Stack[Fruit]
val apple = new Apple
val banana = new Banana
stack.push(apple)
stack.push(banana)
類 Apple
和類 Banana
都繼承自類 Fruit
,所以我們可以把實例對象 apple
和 banana
壓入棧 Fruit
中。
注意:泛型類型的子類型是*不可傳導*的。這表示如果我們有一個字母類型的棧 Stack[Char]
,那它不能被用作一個整型的棧 Stack[Int]
。否則就是不安全的,因為它將使我們能夠在字母型的棧中插入真正的整型值。結論就是,只有當類型 B = A
時, Stack[A]
是 Stack[B]
的子類型才成立。因為此處可能會有很大的限制,Scala 提供了一種 類型參數注釋機制 用以控制泛型類型的子類型的行為。
“scala的泛型類怎么使用”的內容就介紹到這里了,感謝大家的閱讀。如果想了解更多行業相關的知識可以關注億速云網站,小編將為大家輸出更多高質量的實用文章!
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。