Twitter Util 技术文档
2024-12-27 20:59:30作者:胡唯隽
1. 安装指南
在您的项目中使用 Twitter Util 前,您需要先将其作为依赖项添加到您的构建配置中。以下是一个使用 SBT (Scala Build Tool) 的例子:
val utilCore = "com.twitter" %% "util-core" % "24.5.0"
确保您的构建工具支持 Maven Central 仓库,因为这是 Twitter Util 发布的地方。
2. 项目的使用说明
Twitter Util 提供了许多 idiomatic、小型且通用的工具。以下是一些主要功能的使用说明:
单位转换
时间
import com.twitter.conversions.DurationOps._
val duration1 = 1.second
val duration2 = 2.minutes
println(duration1.inMillis) // 输出:1000
空间
import com.twitter.conversions.StorageUnitOps._
val amount = 8.megabytes
println(amount.inBytes) // 输出:8388608
println(amount.inKilobytes) // 输出:8192
Futures
Twitter Util 提供了一个非演员 (non-actor) 的 Scala Futures 实现。
import com.twitter.conversions.DurationOps._
import com.twitter.util.{Await, Future, Promise}
val f = new Promise[Int]
val g = f.map { result => result + 1 }
f.setValue(1)
println(Await.result(g, 1.second)) // 输出:2
// 另一个选项:
g.onSuccess { result =>
println(result) // 输出:2
}
// 使用 for 表达式:
val xFuture = Future(1)
val yFuture = Future(2)
for {
x <- xFuture
y <- yFuture
} {
println(x + y) // 输出:3
}
对象池
对象池的顺序是先进先出 (FIFO)。
常量对象池
import scala.collection.mutable
import com.twitter.util.{Await, SimplePool}
val queue = new mutable.Queue[Int] ++ List(1, 2, 3)
val pool = new SimplePool(queue)
// 注意:池返回的是 Futures,不会在耗尽时阻塞。
println(Await.result(pool.reserve())) // 输出:1
pool.reserve().onSuccess { item =>
println(item) // 输出:2
}
动态创建的对象池
这里有一个生成偶数的对象池,它一次存储 4 个数字:
import com.twitter.util.{Future, FactoryPool}
val pool = new FactoryPool[Int](4) {
var count = 0
def makeItem() = { count += 1; Future(count) }
def isHealthy(i: Int) = i % 2 == 0
}
在成功预留一个对象时,它将检查对象的健康状态。
哈希
util-hashing 是一组哈希函数和哈希分布器(例如 ketama)。
使用哈希函数
import com.twitter.hashing.KeyHasher
KeyHasher.FNV1_32.hashKey("string".getBytes)
以下是可用的哈希函数列表:
FNV1_32
FNV1A_32
FNV1_64
FNV1A_64
KETAMA
CRC32_ITU
HSIEH
使用 KetamaDistributor
import com.twitter.hashing.{KetamaDistributor, KetamaNode, KeyHasher}
val nodes = List(KetamaNode("host:port", 1 /* 权重 */, "foo" /* 句柄 */))
val distributor = new KetamaDistributor(nodes, 1 /* 复制数 */)
println(distributor.nodeForHash("abc".##)) // 输出:client
时间和持续期
与双精度浮点数运算类似,Time 和 Duration 的运算现在不会溢出。相反,它们会溢出到 Top 和 Bottom 值,分别类似于正无穷和负无穷。
由于 Time.now 的分辨率降低(并且由于使用系统时间而变得更加昂贵),引入了新的 Stopwatch API 以计算时间间隔。
它的使用非常简单:
import com.twitter.util.{Duration, Stopwatch}
val elapsed: () => Duration = Stopwatch.start()
然后通过应用 elapsed 来读取:
val duration: Duration = elapsed()
3. 项目API使用文档
Twitter Util 的 API 文档可以在其 Scaladoc 中找到。具体的文档可以在 这里 查看。由于文档链接的存在,这里不提供具体的API使用示例。
4. 项目安装方式
Twitter Util 可以通过 Maven Central 仓库进行安装。您需要在项目的 build.sbt 文件中添加以下依赖项:
libraryDependencies += "com.twitter" %% "util-core" % "24.5.0"
确保您的构建工具配置了 Maven Central 仓库。在大多数情况下,这是默认配置的。
登录后查看全文
热门项目推荐
相关项目推荐
Kimi-K2.5Kimi K2.5 是一款开源的原生多模态智能体模型,它在 Kimi-K2-Base 的基础上,通过对约 15 万亿混合视觉和文本 tokens 进行持续预训练构建而成。该模型将视觉与语言理解、高级智能体能力、即时模式与思考模式,以及对话式与智能体范式无缝融合。Python00- QQwen3-Coder-Next2026年2月4日,正式发布的Qwen3-Coder-Next,一款专为编码智能体和本地开发场景设计的开源语言模型。Python00
xw-cli实现国产算力大模型零门槛部署,一键跑通 Qwen、GLM-4.7、Minimax-2.1、DeepSeek-OCR 等模型Go06
PaddleOCR-VL-1.5PaddleOCR-VL-1.5 是 PaddleOCR-VL 的新一代进阶模型,在 OmniDocBench v1.5 上实现了 94.5% 的全新 state-of-the-art 准确率。 为了严格评估模型在真实物理畸变下的鲁棒性——包括扫描伪影、倾斜、扭曲、屏幕拍摄和光照变化——我们提出了 Real5-OmniDocBench 基准测试集。实验结果表明,该增强模型在新构建的基准测试集上达到了 SOTA 性能。此外,我们通过整合印章识别和文本检测识别(text spotting)任务扩展了模型的能力,同时保持 0.9B 的超紧凑 VLM 规模,具备高效率特性。Python00
KuiklyUI基于KMP技术的高性能、全平台开发框架,具备统一代码库、极致易用性和动态灵活性。 Provide a high-performance, full-platform development framework with unified codebase, ultimate ease of use, and dynamic flexibility. 注意:本仓库为Github仓库镜像,PR或Issue请移步至Github发起,感谢支持!Kotlin08
VLOOKVLOOK™ 是优雅好用的 Typora/Markdown 主题包和增强插件。 VLOOK™ is an elegant and practical THEME PACKAGE × ENHANCEMENT PLUGIN for Typora/Markdown.Less00
热门内容推荐
最新内容推荐
Degrees of Lewdity中文汉化终极指南:零基础玩家必看的完整教程Unity游戏翻译神器:XUnity Auto Translator 完整使用指南PythonWin7终极指南:在Windows 7上轻松安装Python 3.9+终极macOS键盘定制指南:用Karabiner-Elements提升10倍效率Pandas数据分析实战指南:从零基础到数据处理高手 Qwen3-235B-FP8震撼升级:256K上下文+22B激活参数7步搞定机械键盘PCB设计:从零开始打造你的专属键盘终极WeMod专业版解锁指南:3步免费获取完整高级功能DeepSeek-R1-Distill-Qwen-32B技术揭秘:小模型如何实现大模型性能突破音频修复终极指南:让每一段受损声音重获新生
项目优选
收起
OpenHarmony documentation | OpenHarmony开发者文档
Dockerfile
538
3.76 K
Ascend Extension for PyTorch
Python
343
410
本项目是CANN提供的数学类基础计算算子库,实现网络在NPU上加速计算。
C++
886
602
openEuler内核是openEuler操作系统的核心,既是系统性能与稳定性的基石,也是连接处理器、设备与服务的桥梁。
C
337
181
暂无简介
Dart
775
192
deepin linux kernel
C
27
11
🎉 (RuoYi)官方仓库 基于SpringBoot,Spring Security,JWT,Vue3 & Vite、Element Plus 的前后端分离权限管理系统
Vue
1.34 K
757
React Native鸿蒙化仓库
JavaScript
303
356
openJiuwen agent-studio提供零码、低码可视化开发和工作流编排,模型、知识库、插件等各资源管理能力
TSX
987
252
仓颉编译器源码及 cjdb 调试工具。
C++
154
895