- Ziglings 解题报告, 已完成.
- 持续更新
- zig 中文教程
- better-zig/learn-zig: zig 学习练习代码
Zig 当前版本:
- zig 社区项目, 基本都是基于
zig dev
版本(不维护稳定版本). - so, 请使用
dev 版本
, 更快追踪最新特性变更
➤ zig version
0.10.0-dev.2617+47c4d4450
解题方式:
# 方式1: 逐一按照顺序解题
zig build
# 方式2: 传入指定题目编号, 可以忽略其他题目
zig build 1
zig build 83
zig build 84
- 本 repo fork 原项目, 会持续同步更新.
- 解题报告在
solutions
分支.
solutions 分支:
- 对每个语法练习题, 都补充了注释和错误点.
- 补充官方文档对各语法点的详细介绍(数据类型/基本操作等)
补充说明:
- ex001 - ex008 : 简单数据类型(数组, 字符串基本操作)
- ex009 - ex017 : 控制逻辑语句(if/else, while, for 语法)
- ex018 - ex020 : 函数定义(参数/返回值)
- ex021 - ex025 : 错误处理
- ⭐⭐⭐⭐⭐
- ex022 : zig 的自定义错误+类型 union 并集写法, 非常风*.
- zig 的错误处理, catch 语义, 融合了 go panic 机制+ 赋默认值, 很特别的设计
- try 语言, 实现了 常规语言的 try...catch 机制, 手动管理(忽略) panic.
- ex027 - ex027 : defer/errdefer 机制, 类似 go defer
- ⭐⭐⭐
- ex030 - ex032 : switch + else, 类似 rust match
- ex033 : if/err 语义
- ex34 : try catch
- ex35 - ex36 : enum 枚举类型
- ex37 - ex38 : struct 结构体类型
- ex39 - ex44 : pointer 指针类型, 取地址操作(类似 C 语言), 指针参数, 传引用类型
- ⭐⭐⭐⭐⭐
- ex045 - ex046 : optional 语义, 类似
dart Null Safety 语义
.- ⭐⭐
- ex047 - ex049 : struct method 语义, 类似
python class + self 语义
, 区分 类函数(静态) vs 类方法. - ex050 - ex051 : value 类型:
undefined vs null vs errors vs void
语义区别- ⭐⭐⭐
- ex052 - ex053 : 数组切片 + 指针
- ⭐⭐
- ex054 : 数组指针, 指向一片元素. (难理解, 类 C 语言)
- ⭐⭐⭐⭐⭐
- ex055 - ex058 : union 联合体类型(类 c 语言), 联合体+枚举 混合类型.
- ⭐⭐
- ex059 - ex060 : 数值计算: 整型(2 进制, 8 进制, 16 进制) vs 浮点型
- ⭐⭐
- ex061 : 定长数组指针
- ⭐
- ex062 - ex063 : for + break label + else 语义
- ⭐⭐⭐
- ex064 - ex065 : builtin functions 编译器内建函数, 实现类似
go reflect 反射
等语义- ⭐⭐⭐⭐
- ex066 - ex075 : builtin functions 编译期阶段的高阶用法
- ⭐⭐⭐⭐⭐
- ex066 - ex067 : 变量定义, 加
comptime
前缀, 强制指定编译期检查. (类似 rust 生命周期标记, 改变变量生命周期) - ex068 - ex069 : 函数参数, 加
comptime
前缀, 强制指定编译期检查. - ex070 : 函数参数, 指定为
anytype
类型, 配合@TypeOf() + @hasDecl()
实现多态(鸭子类型). 类似 go + reflect 反射效果.(用法也类似) - ex071 : 内联优化,
inline for
, 类似C/C++
内联概念. - ex072 : 内联优化,
inline while
. - ex073 : 任意表达式, 加
comptime
前缀, 强制指定编译期阶段检测(分配). - ex074 - ex075 : 默认省略
comptime
前缀的场景.
- ex076 - ex078 : 字符串类型,
sentinel
尾哨兵机制. 兼容C 字符串
语义,@ptrCast()
强制类型转换.- ⭐⭐⭐
- ex079 : 命名规则扩展,
@"x-y-z"
作为命名字段. 比较无聊的语法糖
. - ex080 - ex083: 泛型数据结构 + 鸭子类型(多态/反射) -
匿名结构体 + @typeName(@TypeOf()) + @as() + @field()
,- ⭐⭐⭐
- ex084 - ex091 : 异步并发编程,
suspend + resume + async + await + nosuspend + panic UB error
.- ⭐⭐⭐⭐⭐
- ex084 - ex086: 异步编程,
suspend + resume + async
, 简单用法 - ex087 : 异步编程, 使用
async + suspend + resume + global var
全局变量, 实现协程间同步通信. - ex088 - ex089: 异步编程, 使用
async + await + return
基于 await 实现协程同步. - ex090 : 异步编程,
nosuspend + suspend + panic UB(未定义)错误
- ex091 : 异步编程,
suspend + async + resume
, 完整理解每条语句的执行顺序.(控制流切换)
准备:
- 配置 zig 开发环境(vscode 设置)
- 安装 go-task
开始:
# 拉取本 repo 代码:
git clone git@github.com:better-zig/ziglings-solutions.git
# 切换分支:
git checkout solutions
验证:
# 切换本项目根目录
cd this-repo-root/
# 编译+运行, 交互式逐个修复有问题的测试题
zig build
# or:
task dev
Welcome to Ziglings! This project contains a series of tiny broken programs. By fixing them, you'll learn how to read and write Zig code.
Those tiny broken programs need your help! (You'll also save the planet from evil aliens and help some friendly elephants stick together, which is very sweet of you.)
This project was directly inspired by the brilliant and fun rustlings project for the Rust language. Indirect inspiration comes from Ruby Koans and the Little LISPer/Little Schemer series of books.
This will probably be difficult if you've never programmed before. But no specific programming experience is required. And in particular, you are not expected to have any prior experience with "systems programming" or a "systems" level language such as C.
Each exercise is self-contained and self-explained. However, you're encouraged to also check out these Zig language resources for more detail:
Also, the Zig community is incredibly friendly and helpful!
Install a development build of the Zig compiler. (See the "master" section of the downloads page.)
Verify the installation and build number of zig
like so:
$ zig version
0.10.0-dev.1427+xxxxxxxxx
Clone this repository with Git:
$ git clone https://github.com/ratfactor/ziglings
$ cd ziglings
Then run zig build
and follow the instructions to begin!
$ zig build
The Zig language is under very active development. In order to be current,
Ziglings tracks development builds of the Zig compiler rather than
versioned release builds. The last stable release was 0.9.1
, but Ziglings
needs a dev build with pre-release version "0.10.0" and a build number at least
as high as that shown in the example version check above.
It is likely that you'll download a build which is greater than the minimum.
(For those who cannot easily update Zig, there are also community-supported branches in this repo. At the moment, there's one for v0.8.1. Older version branches may or may not have all exercises and/or bugfixes.)
Once you have a build of the Zig compiler that works with Ziglings, they'll continue to work together. But keep in mind that if you update one, you may need to also update the other.
Also note that the current "stage 1" Zig compiler is very strict about input: no tab characters or Windows CR/LF newlines are allowed.
- 2022-03-19 zig 0.10.0-dev.1427 - method for getting sentinel of type changed
- 2021-12-20 zig 0.9.0-dev.2025 -
c_void
is nowanyopaque
- 2021-06-14 zig 0.9.0-dev.137 - std.build.Id
.Custom
is now.custom
- 2021-04-21 zig 0.8.0-dev.1983 - std.fmt.format()
any
format string required - 2021-02-12 zig 0.8.0-dev.1065 - std.fmt.format()
s
(string) format string required
It can be handy to check just a single exercise or start from a single exercise:
zig build 19
zig build 19_start
You can also run without checking for correctness:
zig build 19_test
Or skip the build system entirely and interact directly with the compiler if you're into that sort of thing:
zig run exercises/001_hello.zig
Calling all wizards: To prepare an executable for debugging, install it to zig-cache/bin with:
zig build 19_install
I've decide to limit Ziglings to the core language and not attempt coverage of the Standard Library. Perhaps you can change my mind?
Core Language
- Hello world (main needs to be public)
- Importing standard library
- Assignment
- Arrays
- Strings
- If
- While
- For
- Functions
- Errors (error/try/catch/if-else-err)
- Defer (and errdefer)
- Switch
- Unreachable
- Enums
- Structs
- Pointers
- Optionals
- Struct methods
- Slices
- Many-item pointers
- Unions
- Numeric types (integers, floats)
- Labelled blocks and loops
- Loops as expressions
- Builtins
- Inline loops
- Comptime
- Sentinel termination
- Quoted identifiers @""
- Anonymous structs/tuples/lists
- Async <--- IN PROGRESS!
Contributions are very welcome! I'm writing this to teach myself and to create the learning resource I wished for. There will be tons of room for improvement:
- Wording of explanations
- Idiomatic usage of Zig
- Maybe additional exercises?
Please see CONTRIBUTING.md in this repo for the full details.