Here is my CoffeeScript:
这是我的CoffeeScript:
buffer = new Buffer 100
buffer[i] = i for i in [0..99]
console.log buffer
which compiles to
编译成
var buffer, i;
buffer = new Buffer(100);
for (i = 0; i < buffer.length; i++) {
buffer[i] = i;
}
console.log(buffer);
When I run it with node, I get the following output:
当我用节点运行它时,我得到以下输出:
$ coffee exercise1
<Buffer 00 01 02 03 04 05 06 07 08 09 0a 0b 0c 0d 0e 0f 10 11 12 13 14 15 16 17 18 19 1a 1b 1c 1d 1e 1f 20 21 22 23 24 25 26 27 28 29 2a 2b 2c 2d 2e 2f 30 31 32 33 34 35 36 37 38 39 3a 3b 3c 3d 3e 3f 40 41 42 43 44 45 46 47 48 49 4a 4b 4c 4d 4e 4f 50 51 52 53 54 55 56 57 58 59 5a 5b 5c 5d 5e 5f 60 61 62 63>
instead of 0 to 99. Why is that?
而不是0到99.为什么?
1 个解决方案
#1
38
Ray nailed it in his comment. See the Buffer documentation; you have to specify an encoding
argument (you probably want 'utf8'
) on a Buffer's toString
.
雷在他的评论中钉了它。请参阅缓冲区文档;你必须在Buffer的toString上指定一个编码参数(你可能想要'utf8')。
// coffeescript
console.log buffer.toString 'utf8'
// javascript
console.log(buffer.toString('utf8'));
#1
38
Ray nailed it in his comment. See the Buffer documentation; you have to specify an encoding
argument (you probably want 'utf8'
) on a Buffer's toString
.
雷在他的评论中钉了它。请参阅缓冲区文档;你必须在Buffer的toString上指定一个编码参数(你可能想要'utf8')。
// coffeescript
console.log buffer.toString 'utf8'
// javascript
console.log(buffer.toString('utf8'));