Content deleted Content added
m Reverted edits by 197.244.35.48 (talk): editing tests (HG) (3.4.12) |
Merge from Runtime following unopposed March proposal; see Talk:Runtime (program lifecycle phase)#Merge into Execution (computing) Tag: Disambiguation links added |
||
Line 30:
In Linux-based operating systems, a set of data stored in [[Processor register|registers]] is usually saved into a process descriptor in memory to implement switching of context.<ref name=":0" /> PCIDs are also used.
==Runtime==
'''Runtime''', '''run time''', or '''execution time''' is the final phase of a [[computer program]]{{'}}s [[Program lifecycle phase|life cycle]], in which the code is being executed on the computer's [[central processing unit]] (CPU) as [[machine code]]. In other words, "runtime" is the running phase of a program.
A [[Runtime error detection|runtime error is detected]] after or during the execution (running state) of a program, whereas a [[Compile time|compile-time]] error is detected by the [[compiler]] before the program is ever executed. [[Type checking]], [[register allocation]], [[code generation (compiler)|code generation]], and code optimization are typically done at compile time, but may be done at runtime depending on the particular language and compiler. Many other runtime errors exist and are handled differently by different [[Programming language|programming languages]], such as [[division by zero]] errors, ___domain errors, [[Bounds checking|array subscript out of bounds]] errors, [[arithmetic underflow]] errors, several types of underflow and [[overflow (disambiguation)|overflow]] errors, and many other runtime errors generally considered as software bugs which may or may not be caught and handled by any particular computer language.
=== Implementation details ===
When a program is to be executed, a [[loader (computing)|loader]] first performs the necessary [[memory (computers)|memory]] setup and links the program with any [[dynamic linking|dynamically linked]] [[software library|libraries]] it needs, and then the execution begins starting from the program's [[entry point]]. In some cases, a language or implementation will have these tasks done by the language runtime instead, though this is unusual in mainstream languages on common consumer operating systems.
Some program debugging can only be performed (or is more efficient or accurate when performed) at runtime. [[Logic error]]s and [[array data structure|array]] bounds checking are examples. For this reason, some programming [[software bug|bugs]] are not discovered until the program is tested in a [[production environment]] with real data, despite sophisticated compile-time checking and pre-release testing. In this case, the end-user may encounter a "runtime error" message.
=== Application errors (exceptions) ===
[[Exception handling]] is one language feature designed to handle runtime errors, providing a structured way to catch completely unexpected situations as well as predictable errors or unusual results without the amount of inline error checking required of languages without it. More recent advancements in runtime engines enable [[automated exception handling]] which provides "root-cause" debug information for every exception of interest and is implemented independent of the source code, by attaching a special software product to the runtime engine.
== Runtime system ==
Line 59 ⟶ 72:
Some virtual machine emulators, such as [[QEMU]] and [[video game console emulator]]s, are designed to also emulate (or "virtually imitate") different system architectures thus allowing execution of software applications and operating systems written for another [[CPU]] or architecture. [[OS-level virtualization]] allows the resources of a computer to be partitioned via the [[Kernel (operating system)|kernel]]. The terms are not universally interchangeable.
==References==▼
{{Reflist|refs=▼
<ref name="Aho_2007">{{cite book |author-last1=Aho |author-first1=Alfred V. |author-link1=Alfred V. Aho |author-last2=Lam |author-first2=Monica Sin-Ling |author-link2=Monica Sin-Ling Lam |author-last3=Sethi |author-first3=Ravi |author-link3=Ravi Sethi |author-last4=Ullman |author-first4=Jeffrey David |author-link4=Jeffrey David Ullman |title=Compilers: Principles, Techniques and Tools |date=2007 |publisher=[[Pearson Education]] |___location=Boston, MA, US |isbn=978-0-321-48681-3 |page=[https://archive.org/details/compilers00alfr_0/page/427 427] |edition=2nd |url-access=registration |url=https://archive.org/details/compilers00alfr_0/page/427}}</ref>}}▼
{{CPU_technologies}}▼
== See also ==
Line 71 ⟶ 78:
* [[Run time (program lifecycle phase)|Runtime program phase]]
* [[Program counter]]
▲==References==
▲{{Reflist|refs=
▲<ref name="Aho_2007">{{cite book |author-last1=Aho |author-first1=Alfred V. |author-link1=Alfred V. Aho |author-last2=Lam |author-first2=Monica Sin-Ling |author-link2=Monica Sin-Ling Lam |author-last3=Sethi |author-first3=Ravi |author-link3=Ravi Sethi |author-last4=Ullman |author-first4=Jeffrey David |author-link4=Jeffrey David Ullman |title=Compilers: Principles, Techniques and Tools |date=2007 |publisher=[[Pearson Education]] |___location=Boston, MA, US |isbn=978-0-321-48681-3 |page=[https://archive.org/details/compilers00alfr_0/page/427 427] |edition=2nd |url-access=registration |url=https://archive.org/details/compilers00alfr_0/page/427}}</ref>}}
▲{{CPU_technologies}}
{{DEFAULTSORT:Execution (Computing)}}
|