當(dāng)前位置:
首頁 >
用javascript实现一门编程语言-字符输入流
發(fā)布時間:2025/4/16
72
豆豆
生活随笔
收集整理的這篇文章主要介紹了
用javascript实现一门编程语言-字符输入流
小編覺得挺不錯的,現(xiàn)在分享給大家,幫大家做個參考.
目錄
字符輸入流
原文中是the character input stream,不知道怎么翻譯好,就翻譯成字符輸入流
我們在這部分將會創(chuàng)建一個stream object,用來提供從字符串讀取字符的方法。stream object包含四個方法:
- peek() -- 讀取下一個值
- next() -- 讀取下一個值,并且將這個值從輸入流移除
- eof() -- 當(dāng)輸入流中沒用值時,返回true
- croak(msg) -- 用來拋出錯誤
為什么將拋出錯誤的方法croak放到這里,是因為在這里能更簡單的來獲錯誤發(fā)生的位置,這對于提示錯誤信息很重要。
你可以根據(jù)自己的需要在這里添加任何函數(shù)。這四個函數(shù)對于我們這個教程已經(jīng)夠用了。
字符輸入流是面向字符的,所以next() 和 peek()函數(shù)的返回值是一個字符(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 + ")");} } 復(fù)制代碼原文鏈接: lisperator.net/pltut/parse…
轉(zhuǎn)載于:https://juejin.im/post/5b64103c6fb9a04fe370d54d
總結(jié)
以上是生活随笔為你收集整理的用javascript实现一门编程语言-字符输入流的全部內(nèi)容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: Flutter实现动画卡片式Tab导航
- 下一篇: Spring MVC 概述