Added ex. 37,38 structs
parent
2cded107cd
commit
507355ec3b
@ -0,0 +1,59 @@
|
|||||||
|
//
|
||||||
|
// Being able to group values together lets us turn this:
|
||||||
|
//
|
||||||
|
// point1_x = 3;
|
||||||
|
// point1_y = 16;
|
||||||
|
// point1_z = 27;
|
||||||
|
// point2_x = 7;
|
||||||
|
// point2_y = 13;
|
||||||
|
// point2_z = 34;
|
||||||
|
//
|
||||||
|
// into this:
|
||||||
|
//
|
||||||
|
// point1 = Point{ .x=3, .y=16, .y=27 };
|
||||||
|
// point2 = Point{ .x=7, .y=13, .y=34 };
|
||||||
|
//
|
||||||
|
// The Point above is an example of a "struct" (short for "structure").
|
||||||
|
// Here's how it could have been defined:
|
||||||
|
//
|
||||||
|
// const Point = struct{ x: u32, y: u32, z: u32 };
|
||||||
|
//
|
||||||
|
// Let's store something fun with a struct: a roleplaying character!
|
||||||
|
//
|
||||||
|
const std = @import("std");
|
||||||
|
|
||||||
|
// We'll use an enum to specify the character class.
|
||||||
|
const Class = enum{
|
||||||
|
wizard,
|
||||||
|
thief,
|
||||||
|
bard,
|
||||||
|
warrior,
|
||||||
|
};
|
||||||
|
|
||||||
|
// Please add a new property to this struct called "health" and make
|
||||||
|
// it a u8 integer type.
|
||||||
|
const Character = struct{
|
||||||
|
class: Class,
|
||||||
|
gold: u32,
|
||||||
|
experience: u32,
|
||||||
|
};
|
||||||
|
|
||||||
|
pub fn main() void {
|
||||||
|
// Please initialize Glorp with 100 health.
|
||||||
|
var glorp_the_wise = Character{
|
||||||
|
.class = Class.wizard,
|
||||||
|
.gold = 20,
|
||||||
|
.experience = 10,
|
||||||
|
};
|
||||||
|
|
||||||
|
// Glorp gains some gold.
|
||||||
|
glorp_the_wise.gold += 5;
|
||||||
|
|
||||||
|
// Ouch! Glorp takes a punch!
|
||||||
|
glorp_the_wise.health -= 10;
|
||||||
|
|
||||||
|
std.debug.print("Your wizard has {} health and {} gold.", .{
|
||||||
|
glorp_the_wise.health,
|
||||||
|
glorp_the_wise.gold
|
||||||
|
});
|
||||||
|
}
|
@ -0,0 +1,53 @@
|
|||||||
|
//
|
||||||
|
// Grouping values in structs is not merely convenient. It also allows
|
||||||
|
// us to treat the values as a single item when storing them, passing
|
||||||
|
// them to functions, etc.
|
||||||
|
//
|
||||||
|
// This exercise demonstrates how we can store structs in an array and
|
||||||
|
// how doing so lets us print them all (both) using a loop.
|
||||||
|
//
|
||||||
|
const std = @import("std");
|
||||||
|
|
||||||
|
const Class = enum{
|
||||||
|
wizard,
|
||||||
|
thief,
|
||||||
|
bard,
|
||||||
|
warrior,
|
||||||
|
};
|
||||||
|
|
||||||
|
const Character = struct{
|
||||||
|
class: Class,
|
||||||
|
gold: u32,
|
||||||
|
health: u8,
|
||||||
|
experience: u32,
|
||||||
|
};
|
||||||
|
|
||||||
|
pub fn main() void {
|
||||||
|
var chars: [2]Character = undefined;
|
||||||
|
|
||||||
|
// Glorp the Wise
|
||||||
|
chars[0] = Character{
|
||||||
|
.class = Class.wizard,
|
||||||
|
.gold = 20,
|
||||||
|
.health = 100,
|
||||||
|
.experience = 10,
|
||||||
|
};
|
||||||
|
|
||||||
|
// Please add "Zump the Loud" with the following properties:
|
||||||
|
//
|
||||||
|
// class bard
|
||||||
|
// gold 10
|
||||||
|
// health 100
|
||||||
|
// experience 20
|
||||||
|
//
|
||||||
|
// Feel free to run this program without adding Zump. What does
|
||||||
|
// it do and why?
|
||||||
|
|
||||||
|
// Printing all RPG characters in a loop:
|
||||||
|
for (chars) |c, num| {
|
||||||
|
std.debug.print("Character {} - G:{} H:{} XP:{}\n",
|
||||||
|
.{num+1, c.gold, c.health, c.experience});
|
||||||
|
}
|
||||||
|
|
||||||
|
std.debug.print("\n", .{});
|
||||||
|
}
|
Loading…
Reference in New Issue