2019 年 2 月月度总结

2 月份一直都在春节中度过,所以没有太多的进展。

工作

在工作方面,本月 15 号返回深圳,开始恢复工作。

此外,在 Side Project 方面

  • 春节完成了 TLDR 小程序的制作,并产生了一个衍生的开源项目:tldr-parser

情感相关

没有太大变化,稳固。

身体健康相关

本月开始实行早餐吃燕麦,午餐晚餐正常吃,争取下个月改成早餐、晚餐吃燕麦,午餐正常吃。逐步调整。

其他

本月给自己加了一个新的目标:一年看完 52 部电影

这个月看了四部,分别是反贪风暴系列的 一、二、三,以及到电影院看的《流浪地球》。

本月值得一提的是,写了大量的博客文章,2 月写的博客达到了 67 篇,其中 27 篇是随笔。

收支


年度任务对标

  • 年读书 52 本,2月应读书籍: 4 本。2月实读书籍: 9 本。
    • 得益于春节在老家无法写代码,只能读书,本月大量读书。
    • 《网站创富:从搭建、管理到营利》
    • 《程序员的自我修养》
    • 《你的知识需要管理》
    • 《卓越密码 : 如何成为专家》
    • 《四大那些事 : 四大会计师事务所工作生活实录》
    • 《一个瑜伽行者的自传 : 60周年纪念版全文译本》:这本书太奇葩了,我读不下去,停了。
    • 《MacTalk 跨越边界》
    • 《MacTalk 人生元编程》
    • 《实战 ES2015:深入现代 JavaScript 应用开发》
    • 《写出我心:普通人如何通过写作表达自己》
  • 每年国内旅游 5 次:
    • 本月去了一趟香港。
  • 得到课程学习:
    • 本月原计划开始得到课程的学习,暂未学习。下个月需要调整。

其他

本月公司来了一个新人。。。喊我成哥。。。然后,我今天早上问了一下,94年的。。。继续当全公司的年龄担当。

如何使用 MakeCode 来进行 micro:bit 的串口调试

micro:bit 支持在串口输出一些信息,并在你的调试工具中展示这些数据。

这个时候,你可以直接使用 MakeCode 自带的 WebUSB 的功能来实行这个操作。

如何使用?

想要使用串口调试非常方便,首先,你需要确保你的 micro:bit 可以使用 WebUSB (固件版本为 249,250及以上),然后,在你的 make:code 中使用设备配对的功能,来进行配对,将你的 micro:bit 与编辑器进行配对。

然后,新增一个串口输出字符串的块

添加完成块以后,将代码烧入到你的 micro:bit 中,然后在左侧会看到提示。

我这里只显示了“模拟器”,你链接了设备以后,这里还会显示设备的提醒,点击进去就可以看到控制台的输出了。

为什么我愤怒了?

一直以来,我的脾气都是很好的,不愿与他人争吵,产生纷争,因为太过麻烦。

但是今天的确失态了。

回顾自己今天的原因,为什么我失态了?

我觉得主要是两点:

  1. 超出我的预期:原本的方案是 Micro:bit + JS 开发,发现有一些硬伤后,我觉得可以考虑上 Rust ,但是同事觉得应该使用 CPP,对底层进行修改。我觉得成本太高了。而且不认为自己能够处理。
  2. 需要花费大量的时间:由于同事负责的并非是硬件,所以他提出方案后,我觉得这是对我的挑战。而且,由于他不是负责这部分业务,所以我们之间的想法会有所差异。

醒悟

别让情绪操纵自己,做正确的事情,而不是符合情绪的事情。

Micro:Bit 是如何将 600K + 的文件烧入 NRF51822 的?

前置信息

Micro:bit 的蓝牙芯片是 NRF51822

根据 Nodric Semiconductor 公司的说明,NRF51822 的 ROM 大小只有 256/128 K,但是当我们从 makecode 编辑器上下载 hex 文件的时候,即使只是输出一个 1 ,你的代码文件也有足足 630K。

在我的 micro:bit 还没有到手的时候,我一直在怀疑,make:code 是使用了什么样的黑科技,才能够实现将 630K 的文件烧录到 256K 的 ROM 里。我甚至怀疑 micro:bit 根本无法烧录这个文件。

micro:bit 到手以后,我试着去烧录,发现虽然文件大,但是的的确确可以烧录进去。

当时我就震惊了!Micro:bit 这是掌握了核心科技啊,能够把 600K + 的文件烧录进 256K 的 ROM 里。

随着研究的深入,以及开始对 hex 文件进行解包以后。我发现,原来 hex 文件中包含了整个项目的所有的文件,我们看到的 ts 文件等都会打包在这个文件中。

这就更加令我震惊了,难道 Micro:bit 已经可以实现在 16K Ram ,256K Rom 的芯片上移植一个 Node.js 的运行环境?那这个公司的黑科技未免也太多了。而且,因为要烧录整个文件进去,600K+的文件再怎么压缩也要占个100~200K,剩下给运行环境的空间并不大。

继续研究,发现我可以在本地重新打包,于是,我尝试重新打包文件

pxt build 

打包完成后,生成了 built 文件夹,里面就是我们的 hex 文件。

诶,这里怎么还有一个 asm 文件? asm 不是汇编语言 assembly language 的缩写么?打开一看,的确是汇编语言。

再看一下文件大小,豁然开朗。

原来, Makecode 将整个项目文件都打包进入到 package 中,然后,将代码文件转译为汇编语言文件(实际应该是转成二进制可执行文件,这里的 asm 文件应该是用于调试的),写入到 nrf51822 中。

这样,我们实际写入的代码其实只有 24 K,就能够理解为什么 600 多K 的项目能够写入到 nrf51822 了,因为其实 其中的 600 k 都是源码文件,在烧录的时候会被抛弃掉。

如何在本地运行一个 Micro:bit 编辑器

micro:bit makecode在线编辑器

一般来说,我们会使用 micro:bit 的 makecode 平台进行内容的编辑,不过,有些时候,我们希望在本地进行编辑,因此, 我们需要把 编辑器运行在本地。

在本地运行编辑器的方法非常的简单,首先,确保你已经安装了 Node.js 环境,然后执行如下命令安装 pxt

npm install pxt

安装完成后,执行如下命令来启动编辑器

mkdir microbit # 创建一个新的目录,方便管理文件
pxt target microbit # 创建 micro:bit 目录
pxt serve # 启动编辑器

启动后,会自动打开浏览器,访问编辑器。如果没有启动,你可以点击命令行里的连接,自己打开编辑器。

连接位置

打开以后,就可以看到在本地运行的 makecode 编辑平台了。

makecode 编辑平台

如何解包 Micro:bit 可视化编辑器生成的 Hex 文件

在上一篇文章《Micro:Bit 中隐藏的 Typescript 文件》中我提到,micro:bit 的代码中有一些 Typescript 文件,记录了我们的接口。如果我们可以将其下载到本地,完整的解读,那么我们可以得到一个更加完善的接口文档。接下来,我们就对编辑器生成的 Hex 文件进行解包。

Hex 解包过程

生成 Hex 文件

首先,你需要生成一个 用于解包的 Hex 文件,这样可以方便你看自己想看的接口。比如我要看的蓝牙接口默认并不在项目里,需要自己以拓展的形式加入到项目中。

安装 PXT 命令行工具

想要解包,你需要使用 micro:bit 自己的解包工具(集成在其命令行里)

我们需要使用 npm 来安装 pxt 命令行工具,所以,在继续执行下面的命令前,使用 node --version来确定你已经装了 node.js 环境。

npm install pxt

安装完成后,创建一个新的文件夹,比如叫 extract ,并安装 micro:bit 解包所需的依赖

cd extract
pxt target microbit

解包 Hex 文件

当环境好了以后,我们就可以开始准备解包我们的 Hex 文件了。

pxt extract 文件路径

解压完成后,会在文件路径下生成一个项目文件夹

解压所得文件

这样,你就可以看到我们在在线编辑器中所看到的文件了。

测试随笔

作为一个开发者,相信你或多或少都会接触过测试,小到”单元测试“,大到”特性测试“,团队人少的开发自己测试,团队人多的专门招个人测试,甚至是有自己专门的测试团队、测试部门。

当我们从简简单单的关注功能到了关注代码质量、关注产品性能、关注软件工程的时候,我们就不可避免的要与测试打交道,可是,你又是否真正关注过测试?

在我看来,测试真正的价值是将软件工程中的一些变量,变成了不变的量。对于一个项目来说,变量越多,我们要处理的问题就越复杂。而测试可以确保我们需要的东西从变量,转变为常量。当他成为常量时,我们在后续的处理相对就更加简单了。

如果用线性代数的话来说,测试其实就是将维度降低了,你每写下一个测试,都将代表着你的软件复杂度的维度降低一维,你解决问题的难度也就越低。

Micro:bit 中隐藏的 TypeScript

Micro:Bit 目前提供的可视化编程是基于 JavaScript 实现的,如果你将你的界面从 Block 块编辑器切换为 JavaScript 编辑器,就可以看到对应的代码了。

micro:bit 中的 JavaScript

除了 JavaScript 以外,你还可以在 Micro:Bit 中找到 TypeScript 代码。

点击右上方的小齿轮,选择项目设定

进入项目设定

在页面的左侧可以看到一个资源管理器,点击资源管理器,就可以看到你的项目中的所有文件。

资源管理器

在这些 typescript 中,你可以看到一些我们在使用块时的定义

定义

借助这些 Typescript 文件,相信可以帮助你更好的使用 micro:bit 的编辑器。

Micro:Bit 如何升级固件

在 Micro:Bit 的官方编辑器上,有一个功能:设备配对,这个是依赖于 Chrome 的 Web USB 接口实现的,通过浏览器烧写你的 Micro:Bit 。

设备配对的入口
在线编辑的说明

点击设备配对时,你会看到一个设备,点击就可以配对了。

配对界面

不过,并不是每次都可以完成配对的,很多时候,你可能没有办法搜索到。这是因为你的 Micro:Bit 设备依然运行的是旧版的固件,你需要升级一下固件。

升级固件

检测你的固件版本

在升级固件版本之前,你需要先去检测当前的固件版本。你可以使用 USB 数据线,将 Micro:Bit 与你的电脑相连。

连接成功后,你可以在 USB 驱动器中看到 Details.txt 文件

Details.txt 文件路径

打开这个文件后,你可以看到硬件的版本。

硬件版本

比如,我手上的这个硬件版本为 250 ,是可以使用 WebUSB 的。如果你的版本是0234, 0241, 0243之一,你就需要升级你的版本到最新(此文写于 2018 年 2 月 2日,当日最新版本是 250)。如果你的版本是 249 ,可以不需要升级。

进入维护模式

进入维护模式和进入配对模式一样,也需要按下特殊的键位。你需要在按下 Reset 按钮的同时,插上数据线,这样,你就可以看到在磁盘中多了一个 MAINTENANCE 的驱动器。

进入维护模式

下载最新固件

接下来,你需要去下载最新的固件。你可以在官网的 Firmware 页面找到下载。

下载最新固件

点击下载,将固件下载到本地,并将其拖入到 MAINTENANCE 驱动器即可。

Micro:Bit 会自动开始刷新固件,等待其重启以后,你就可以在浏览器中下载固件,并进行固件的刷写了。非常的方便。

在线下载
按钮重新恢复为绿色的时候,就说明下载成功了。