當前位置:
首頁 >
前端技术
> javascript
>内容正文
javascript
用javascript实现一门编程语言-字符输入流
生活随笔
收集整理的這篇文章主要介紹了
用javascript实现一门编程语言-字符输入流
小編覺得挺不錯的,現在分享給大家,幫大家做個參考.
目錄
字符輸入流
原文中是the character input stream,不知道怎么翻譯好,就翻譯成字符輸入流
我們在這部分將會創建一個stream object,用來提供從字符串讀取字符的方法。stream object包含四個方法:
- peek() -- 讀取下一個值
- next() -- 讀取下一個值,并且將這個值從輸入流移除
- eof() -- 當輸入流中沒用值時,返回true
- croak(msg) -- 用來拋出錯誤
為什么將拋出錯誤的方法croak放到這里,是因為在這里能更簡單的來獲錯誤發生的位置,這對于提示錯誤信息很重要。
你可以根據自己的需要在這里添加任何函數。這四個函數對于我們這個教程已經夠用了。
字符輸入流是面向字符的,所以next() 和 peek()函數的返回值是一個字符(char類型,因為javascript中沒有char類型,所以返回的是長度唯一的string)。
以下是stream object的代碼:
function InputStream(input) {var pos = 0, line = 1, col = 0;return {next : next,peek : peek,eof : eof,croak : croak,};function next() {var ch = input.charAt(pos++);if (ch == "\n") line++, col = 0; else col++;return ch;}function peek() {return input.charAt(pos);}function eof() {return peek() == "";}function croak(msg) {throw new Error(msg + " (" + line + ":" + col + ")");} } 復制代碼原文鏈接: lisperator.net/pltut/parse…
轉載于:https://juejin.im/post/5b64103c6fb9a04fe370d54d
總結
以上是生活随笔為你收集整理的用javascript实现一门编程语言-字符输入流的全部內容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: Flutter实现动画卡片式Tab导航
- 下一篇: QLoo推出用于现有服务的GraphQL