How is Javascript translated to bytecode?

前端 未结 5 1279
滥情空心
滥情空心 2020-12-16 11:30

I can\'t find information on the web how W3C languages compile to machine code. I know that the gap between the web and the processor must be somehow the browser, but how do

相关标签:
5条回答
  • 2020-12-16 11:46

    This may help : http://www.ecma-international.org/publications/standards/Ecma-262.htm

    There is no spec for how to translate into bytecode (That is up to the browser developers) but there are specs about how the language should behave

    0 讨论(0)
  • 2020-12-16 11:51

    In addition to the useful, specific answers already given, the phrase 'adaptive optimisation' is probably worth looking up if performance is your main interest. JavaScript and its interpreters are just the latest instance of systems that need to convert something else to machine code at runtime, so there's plenty of wider reading. The bytecode forms of Pascal, Smalltalk, Java, etc can easily enough be viewed as an intermediate form in the process of running a defined language on arbitrary hardware — Apple's SquirrelFish explicitly creates a bytecode and uses a JIT compiler on that, for example.

    0 讨论(0)
  • 2020-12-16 11:52

    For Firefox there's some specifications on its bytecodes:

    https://developer.mozilla.org/en-US/docs/Mozilla/Projects/SpiderMonkey/Bytecodes https://developer.mozilla.org/en-US/docs/Mozilla/Projects/SpiderMonkey/Internals/Bytecode

    For V8 it's compiled to native code directly:

    http://jayconrod.com/posts/51/a-tour-of-v8-full-compiler

    0 讨论(0)
  • 2020-12-16 12:00

    It's up to the implementation; the specification is the full description of the language and how it's supposed to work, implementations are free to satisfy that implementation in any way they like. Some implementations seem (from the outside) to run it purely as an interpreter in the old sense; others may or may not compile to bytecode; V8 (the JavaScript engine in Chrome, Chromium, Brave, Node.js, and others) used to compile to machine code (twice, for hotspots in the app), but now starts out parsing to bytecode and running it in an interpreter and only compiling hotspots as necessary (details). (There's also a V8 mode where it only interprets, which they're experimenting with for environments where compiling at runtime isn't an option, such as iOS where non-Apple apps aren't allowed to allocate executable memory.)

    The V8 team (V8 being the JavaScript engine in Chromium and Chrome) periodically publish descriptions of how they get the fantastic speed out of V8 that they do. You may find some of that on the V8 blog.

    Naturally, you can also kick around the code of any of the open-source implementations. V8 and SpiderMonkey (Mozilla's engine) are the two major open-source ones I know.

    0 讨论(0)
  • 2020-12-16 12:07

    Javascript (as it's name suggests) is a dynamic scripting language. Meaning that it's code is analysed and executed at runtime by the web-browser's Javascript engine.

    It is up to the Web-browser, how it wants to deal with Javascript. Some may generate an intermediate language, or bytecode. Some may directly analyse and execute it.

    Here are the steps to the simplest way to execute Javascript (parsing and executing at runtime):

  • Parsing and Preprocessing (recursive descent or otherwise)
  • Analysis
  • Execution


    Chrome's Javascript Engine compiles Javascript to native platform-specific machine code (for optimum performance) It also has a Garbage Collection Mechanism.

0 讨论(0)
提交回复
热议问题