第189章 ,/.

(本章已于2022年7月16日重写)

现在,我们只剩下了一个存储子命令,即store。

这个store可不是商店,而是一个动词,意为『储存』。

和if子命令一样,store子命令也有许多子命令。截止1.19版本,store子命令一共有5个子命令,但在这我们只能讲一个。

为什么?你仔细看看这五个子命令,斟酌一下你的水平,然后你就会发现在这里我们的确也只能讲一个。

这五个子命令分别是:

block ——将值存储到方块实体(方块NBT)中

bossbar ——将值存储到BOSS栏中

entity ——将值存储到实体NBT中

score ——将值存储到计分板中

storage ——将值存储到硬盘中

额,其实storage子命令我们也可以稍微讲一下......

在开讲之前,让我们先回顾一下第六十一章的内容。在那一章,我们了解到指令的返回结果有五种类型:

①指令执行成功的次数(SuccessCount)

②指令的查询结果(QueryResult)

③受到该指令影响的物品数量(AffectedItems)

④受到该指令影响的实体数量(AffectedEntities)

⑤受到该指令影响的方块数量(AffectedBlocks)

但Mojang可能觉得这五种太多了,而且2、3、4、5分得那么细也没啥用。于是,在Java1.13版本中,后四类合并成了一类,加上原先『指令执行成功的次数』,就变成了两大类型:

①指令执行成功的次数(success)

②指令返回的结果(result)

其中,前者可以被我们的比较器探测到并输出为红石信号强度。

回到store子命令上。虽然现在指令执行的结果只剩下两大类型,但也是有分类的嘛。所以说,store子命令的格式如下:

... store <返回类型>(block|bossbar|entity|score|storage)...

比如:

... store result block ...

这将会指定将指令执行所返回的结果(一般是run子命令执行的结果)存储到方块实体(方块NBT)中。

考虑到我们尚未真正开始学习NBT,因此这里我们就不讲block、bossbar和entity了,就仔细学习一下score,并稍微讲一下storage即可。

store的score子命令,其格式如下:

... store <返回类型> score <分数持有者><计分项>...

很简单吧?至少比/stats指令要简单许多。我们只需要指定返回类型,然后指定要存储到谁在哪个计分项上的分数即可。我们不需要考虑会不会受到其他指令的影响,也不需要考虑要在开始存储之后停止存储,甚至不需要考虑指定的分数持有者是否在被指定的计分项追踪。

举个简单的例子:

/execute as @a store result score @s ore_count run clear @s #forge:ores 0