- Learn Type:Driven Development
- Yawar Amin Kamon Ayeva
- 200字
- 2021-07-02 14:41:23
Analyzing code for hidden errors
Let's suppose that you have the following JavaScript:
// src/Ch01/Ch01_Demo.js
function makePerson(id, name) { return {id, name}; }
A lot of things can go wrong with the preceding code; they are as follows:
- The caller can pass in nulls or undefined values as arguments
- The caller can pass in unintended types of arguments
- The caller can manipulate the returned person object any way they like, for example, they can add or remove properties
In other words, this code doesn't prevent a number of potential errors. In JavaScript, we have linters, such as ESLint (https://eslint.org/), that check for a lot of possible errors, but you have to remember to find them, enable them, and then work around their limitations. A linter can be helpful in various other ways, such as by pointing out the recommended best practices in a coding style. However, linters in JavaScript are often re-purposed to perform static type checking tasks as well; because they offer so much flexibility and need to be configured (in fact, people usually upload their preferred sets of configuration for different styles of programming), there may be large differences in what exactly gets checked across different codebases.
- Vue.js 3.x快速入門
- Java程序設計(慕課版)
- C# 從入門到項目實踐(超值版)
- DevOps入門與實踐
- JavaScript+jQuery開發實戰
- Learning AWS Lumberyard Game Development
- 薛定宇教授大講堂(卷Ⅳ):MATLAB最優化計算
- 用Flutter極速構建原生應用
- Learning OpenStack Networking(Neutron)
- PySide 6/PyQt 6快速開發與實戰
- C#開發案例精粹
- 零基礎學C語言(升級版)
- Python函數式編程(第2版)
- Android系統下Java編程詳解
- FusionCharts Beginner’s Guide:The Official Guide for FusionCharts Suite