@specialized type parameter

problem

在 scala 中,type parameter 可以為 primitive type,比如Int, Long, Float, Double...
但由于 JVM 的類型擦除,List[Int]在運行時仍會被轉(zhuǎn)化為List[Object]
即基礎(chǔ)類型需要被裝箱到某個wrapper class

@specialized

可以在聲明type parameter時,針對一些 type 使用@specialized annotation

import scala.{specialized => sp}
class Wrapper[@sp(Short, Int, Long, Float, Double) A](unwrap: A)

new Wrapper[Short](42)
res0: Wrapper[Short] = Wrapper$mcS$sp@2f657dc7

new Wrapper[Int](42)
res1: Wrapper[Int] = Wrapper$mcI$sp@213b4ebf

new Wrapper[Long](42L)
res2: Wrapper[Long] = Wrapper$mcJ$sp@600f799c

new Wrapper[Float](3.14f)
res3: Wrapper[Float] = Wrapper$mcF$sp@5b6b6cb0

new Wrapper[Double](3.14)
res4: Wrapper[Double] = Wrapper$mcD$sp@465ebfb9

new Wrapper[String]("hi")
res5: Wrapper[String] = Wrapper@7ee6425d

可以看到,編譯器會針對所聲明的5個基礎(chǔ)類型和1個泛型,編譯出6個不同版本的Wrapper.
這樣,對于specialized的類型,就可以避免運行時boxingunboxing開銷。

syntax

  • class 的 specialization 會應(yīng)用于所有使用了其 type parameter 的 members
  • 可以針對classmember分別設(shè)置spacialization
// class Vector specialized all primitive types
class Vector[@specialized A] {
  def apply(i: Int): A = //..
  // method map only specialized Int and Boolean
  def map[@specialized(Int, Boolean) B](f: A => B) =
  //..
}

related projects

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
【社區(qū)內(nèi)容提示】社區(qū)部分內(nèi)容疑似由AI輔助生成,瀏覽時請結(jié)合常識與多方信息審慎甄別。
平臺聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀點,簡書系信息發(fā)布平臺,僅提供信息存儲服務(wù)。

相關(guān)閱讀更多精彩內(nèi)容

  • 對象的創(chuàng)建與銷毀 Item 1: 使用static工廠方法,而不是構(gòu)造函數(shù)創(chuàng)建對象:僅僅是創(chuàng)建對象的方法,并非Fa...
    孫小磊閱讀 2,184評論 0 3
  • Spring Cloud為開發(fā)人員提供了快速構(gòu)建分布式系統(tǒng)中一些常見模式的工具(例如配置管理,服務(wù)發(fā)現(xiàn),斷路器,智...
    卡卡羅2017閱讀 136,586評論 19 139
  • 《Effective Java》筆記(上) 對象的創(chuàng)建與銷毀 Item 1: 使用static工廠方法,而不是構(gòu)造...
    OCNYang閱讀 2,787評論 2 17
  • { "Unterminated string literal.": "未終止的字符串文本。", "Identifi...
    一粒沙隨風(fēng)飄搖閱讀 11,336評論 0 3
  • "Unterminated string literal.": "未終止的字符串文本。", "Identifier...
    兩個心閱讀 8,559評論 0 4

友情鏈接更多精彩內(nèi)容