Home : Software Terms : Low-Level Language Definition

Low-Level Language

A low-level language is a type of programming language that contains basic instructions recognized by a computer. Unlike high-level languages used by software developers, low-level code is often cryptic and not human-readable. Two common types of low-level programming languages are assembly language and machine language.

Software programs and scripts are written in high-level languages, like C#, Swift, and PHP. A software developer can create and edit source code in a high-level language using a programming IDE or even a basic text editor. However, the code is not recognized directly by the CPU. Instead, it must be compiled into a low-level language.

Assembly language is one step closer to a high-level language than machine language. It includes commands such as MOV (move), ADD (add), and SUB (subtract). These commands perform basic operations, such as moving values into memory registers and performing calculations. Assembly language can be converted to the machine language using an assembler.

Machine language, or machine code, is the lowest level of computer languages. It contains binary code, often generated by compiling high-level source code for a specific processor. Most developers never need to edit or even look at machine code. Only programmers who build software compilers and operating systems need to view machine language.

Updated: February 14, 2019

Cite this definition:


TechTerms - The Tech Terms Computer Dictionary

This page contains a technical definition of Low-Level Language. It explains in computing terminology what Low-Level Language means and is one of many software terms in the TechTerms dictionary.

All definitions on the TechTerms website are written to be technically accurate but also easy to understand. If you find this Low-Level Language definition to be helpful, you can reference it using the citation links above. If you think a term should be updated or added to the TechTerms dictionary, please email TechTerms!