Zig (Programmiersprache)

aus Wikipedia, der freien Enzyklopädie
Zur Navigation springen Zur Suche springen
Zig
Basisdaten
Paradigmen: multiparadigmatisch (generisch, funktional, imperativ, strukturiert, parallel)
Erscheinungsjahr: 2016
Entwickler: Zig Software Foundation[1], Andrew Kelley
Aktuelle Version 0.12.0[2] (20. April 2024)
Typisierung: Stark, statisch
Wichtige Implementierungen: ziglang
Beeinflusst von: C, C++, Rust, Go, JavaScript/TypeScript
Betriebssystem: Plattformunabhängig
Lizenz: MIT-Lizenz
ziglang.org

Zig ist eine seit 2016 von Andrew Kelley entwickelte und seit 2020 von der Zig Software Foundation[3] übernommene Multiparadigmen-Systemprogrammiersprache. Der Compiler kann C/C++-Bibliotheken direkt importieren und Header-Dateien für diese Sprachen bei der Kompilierung generieren. Die direkt ausführbaren Binärdateien werden in der Ursprungsimplementation durch ein LLVM-Backend erzeugt.

Die Sprache zeigt durch das Attribut comptime (für engl. compile-time, „(zur) Kompilierzeit“) auf, wie durch Auswertung von Ausdrücken zur Kompilierzeit generische Typen einfacher geschrieben werden können, und dabei laufzeitoptimierter Code entsteht. Bei der Fehlerbehandlung und Parallelausführung lehnt es sich an Go an. Im Gegensatz zu anderen Erweiterungen von C können neue und alte Module frei gemischt werden und erlauben so eine graduelle Umstellung. Die Laufzeitbibliothek wurde nicht erweitert – es genügt eine libc-Implementierung. Auf Betriebssystemen mit stabilen Syscall-Interfaces (wie z. B. Linux) kann Zig auch völlig ohne libc laufen.

Beispiele[Bearbeiten | Quelltext bearbeiten]

Hello World (mit Formatstring)[Bearbeiten | Quelltext bearbeiten]

pub fn main() !void {
    const stdout = @import("std").io.getStdOut().writer();
    try stdout.print("Hello, {s}!\n", .{"world"});
}

Generische Verlinkte Listen[Bearbeiten | Quelltext bearbeiten]

pub fn main() void {
    var node = LinkedList(i32).Node {
        .prev = null,
        .next = null,
        .data = 1234,
    };

    var list = LinkedList(i32) {
        .first = &node,
        .last = &node,
        .len = 1,
    };
}

fn LinkedList(comptime T: type) type {
    return struct {
        pub const Node = struct {
            prev: ?*Node,
            next: ?*Node,
            data: T,
        };

        first: ?*Node,
        last:  ?*Node,
        len:   usize,
    };
}

Weblinks[Bearbeiten | Quelltext bearbeiten]

Einzelnachweise[Bearbeiten | Quelltext bearbeiten]

  1. ZSF ⚡ Zig Programming Language. Abgerufen am 7. März 2024.
  2. Release 0.12.0.
  3. ZSF ⚡ Zig Programming Language. Abgerufen am 7. März 2024.