Hack语言特性之类型化

简介: Hack最基础的特性就是类型标注。PHP5已经开始支持对象的类型化,PHP7也提供了标量类型化声明。Hack提供了全面的类型标注支持,与其typecher配合使用,还可以实现快速、前置静态类型验证。什么是类型标注?类型标准允许给类属性、方法/函数参数、方法/函数返回值及代码其它组件添加显示类型,如int。

Hack最基础的特性就是类型标注。PHP5已经开始支持对象的类型化,PHP7也提供了标量类型化声明。Hack提供了全面的类型标注支持,与其typecher配合使用,还可以实现快速、前置静态类型验证。

什么是类型标注?

类型标准允许给类属性、方法/函数参数、方法/函数返回值及代码其它组件添加显示类型,如int。

举个例子,下面的代码是用正规的PHP编写的,没有任何类型:

<?php

namespace Hack\UserDocumentation\Overview\Typing\Examples\PHPFunction;

function bar($a, $b) {
  if ($a > 0) {
    return true;
  } else {
    return $b < 0;
  }
}

var_dump(bar(3, -1));
var_dump(bar(-1, 10));
Output
bool(true)
bool(false)

代码作者的本意很清楚,$a 和 $b都是int型,代码也是用于算术运算。但实际上没有写任何代码来保证这个计算能正常进行。

假设你在对该代码进行测试,在$a的值始终为正整数时好像每次都是正常的。你不会天真的以为这是段无错代码吧,看看这种情况:当$a <= 0,且$b不是int型值时,就会导致意图不明的结果!

Hack的类型标注机制可以帮助你防止这类运行时错误。你可以显式告知Hack你所希望的变量类型:

<?hh

namespace Hack\UserDocumentation\Overview\Typing\Examples\HackFunction;

function bar(int $a, int $b) {
  if ($a > 0) {
    return true;
  } else {
    return $b < 0;
  }
}

var_dump(bar(3, -1));
var_dump(bar(-1, 10));
Output
bool(true)
bool(false)

typechecker现在可以准确知晓开发者的意图:两个参数都是整数。typechecker会扫描所有代码,且在每行代码执行时知道是否不变量是否满足条件。不用关心$a在运行时的值 - typechecker会确保$b类型是准确的。换句话说,Hack的typechecker执行静态类型检查 - Hack是一种静态类型语言。

静态类型语言 在编译期间进行类型检测,通常可以防止类型相关的错误。

动态类型语言 在运行时进行类型检测,允许更多的灵活性,在损失让类型错误通过的情况下
你可以采用Hack的强类型特性,也可以继续在Hack中享受动态类型语言的灵活性。

为什么这一点很有用?

如果你正在编写代码,可能有隐式类型的概念;当你敲出一行代码时,你脑袋里是会假定变量、参数等的类型的。Hack的类型标注机制帮助开发者少犯错误并少引入错误:

  • 在运行之前捕捉bug
  • 允许IDE自动完成类型敏感的函数,并提供行间错误通知
  • 清晰的向其它开发者表明意图
  • 阻止不安全的编码实践如 switch fallthrough.
目录
相关文章
|
2月前
|
JavaScript 前端开发 测试技术
如何写高质量的JavaScript代码
在现代Web开发中,JavaScript扮演着至关重要的角色。本文介绍了提升JavaScript代码质量的关键技巧:采用语义化命名增强代码可读性;通过模块化设计提升代码的可维护性和复用性;利用恰当的注释与文档说明代码功能;合理管理全局变量避免命名冲突;实施有效的异常处理增加程序稳定性;并借助工具和框架提高开发效率和代码质量。这些实践共同助力打造高效、可维护的Web应用。代码示例和效果参见相关链接。
22 3
|
4月前
|
前端开发 JavaScript 安全
高级前端开发需要知道的 25 个 JavaScript 单行代码
1. 不使用临时变量来交换变量的值 2. 对象解构,让数据访问更便捷 3. 浅克隆对象 4. 合并对象 5. 清理数组 6. 将 NodeList 转换为数组 7. 检查数组是否满足指定条件 8. 将文本复制到剪贴板 9. 删除数组重复项 10. 取两个数组的交集 11. 求数组元素的总和 12. 根据指定条件判断,是否给对象的属性赋值 13. 使用变量作为对象的键 14. 离线状态检查器 15. 离开页面弹出确认对话框 16. 对象数组,根据对象的某个key求对应值的总和 17. 将 url 问号后面的查询字符串转为对象 18. 将秒数转换为时间格式的字符串 19.
52 3
高级前端开发需要知道的 25 个 JavaScript 单行代码
|
5月前
|
JavaScript 前端开发 数据处理
掌握JavaScript中的二进制运算,提升你的编程技能!
掌握JavaScript中的二进制运算,提升你的编程技能!
|
5月前
|
JavaScript 前端开发 IDE
JavaScript与TypeScript:核心异同点解析
JavaScript与TypeScript:核心异同点解析
51 0
|
5月前
|
前端开发 JavaScript 程序员
JavaScript高级技巧:深入探索JavaScript语言的高级特性和用法
JavaScript高级技巧:深入探索JavaScript语言的高级特性和用法
|
5月前
|
自然语言处理 前端开发 JavaScript
【前端|Javascript第1篇】一文搞懂Javascript的基本语法
【前端|Javascript第1篇】一文搞懂Javascript的基本语法
182 0
|
存储 JavaScript 前端开发
JavaScript语言基础之for-of语句
for-of语句是一种用于遍历可迭代对象的语法,本文将详细介绍for-of语句的用法及其与其他遍历语句的区别。
|
JavaScript 前端开发
JavaScript 语言基础之 for-in 语句
for-in 语句是 JavaScript 中用于遍历对象属性的一种循环语句。本文将深入介绍 for-in 语句的用法、注意事项以及常见应用场景。
|
存储 JavaScript 前端开发
JavaScript 语言基础数据类型
JavaScript 语言中的数据类型包括原始数据类型和对象数据类型,原始数据类型包括 Undefined、Null、Boolean、Number 和 String,而对象数据类型包括 Object、Array 和 Function。本文将详细介绍每一种数据类型的特点和用法。
|
JavaScript 前端开发
《JavaScript高级程序设计》__ 语言基础(上)(1)
前言 大家好,我是HoMeTown,web领域有一本神书大家应该都有看过,这本书我看过两遍,但是每次看都是粗粗的略过一些重要的知识点,甚至一些面试过程中的问题,在这本书里都能找到答案。
147 3
下一篇
无影云桌面