https://github.com/enixjin/blockchain 说明有空再补。。。…
如果你使用的是Typescript>1.7,或者NodeJS>7.6, 那么你就已经可以使用新的async/await语法来部分代替原来的promise写法了。 先来看一个最简单的例子 Promise写法: doSomethingWithPromise(): Promise<string> { return Promise.resolve("success"); } doSomethingWithPromise().then(result=>console.log(`result is ${result}`));// result is success aysnc/await写法: async doSomething(){ return Promise.resolve("success"); } let result = await doSomething(); console.log(`result is ${result}`);// result is…
如何理解NodeJS (二)写好异步代码 链接:(一)基本原理 上篇说到,得益于异步的机制,NodeJS在拥有卓越性能的同时,也会使逻辑的实现变得更复杂和难于理解。 首先,其实NodeJS也是能实现blocking的代码的,比如读取一个文件: var fs = require("fs"); var contents = fs.readFileSync("data.txt", "utf8"); console.log(contents); console.log("done"); 这样写的输出结果就是先读取打印文件的内容,再输出done. 当然,这样就失去了使用NodeJS的优势,而且,绝大部分的库(比如文件的读取,数据库的操作等)都是使用异步机制,并且不提供类似fs的sync同步方法,而一般的Callback写法应该是这样的: var fs = require("fs"); fs.readFile("data.txt", "utf8"…
如何理解NodeJS (一)基本原理、优势、劣势等 用NodeJS相关技术作为项目的主平台开发已一年有余,写个小文章谈一下如何更好的理解NodeJS。 要理解NodeJS,就必须看看它和其他的Java,C#写的服务器有何不同。 如果你Google一下的话,就会发现很多类似这样的文章:w/1M concurrent connections! 或者这样的:600k concurrent websocket. 而Java服务器,在没有用任何工具的情况下大概一个服务器能撑500-1000个并发。(除非上和NodeJS原理相似的netty) 为什么NodeJS能在默认单线程的情况下实现如此高的并发呢?这和NodeJS的三大特点: Single threaded Event Loop Non-blocking I/O 是分不开的。 举个具体的比喻:我们传统的程序处理方式就和去银行办事情一样,我们手里拿着几件要办的事情来到银行。从门口的机器里面拿到一个号,一般有多个窗口在办业务(多线程),当叫到我们的号时,我们去特定的窗口把我们要办的事情都办完(阻塞性),然后下一个人。如下图: (一家拥有3个柜台/服务员的银行) 现在,更高效的NodeJS银行开张了,去里面办事是一种什么体验呢?…