- 教程
- 概述
- 环境
- Basic 语法
- 数据类型
- 变量
- 运算符
- 模式匹配( Pattern Matching)
- 决策( Decision Making)
- Strings( Strings)
- Char Lists( Char Lists)
- 列表和元组( Lists and Tuples)
- 关键字列表( Keyword Lists)
- Maps
- 模块( Modules)
- 别名( Aliases)
- 功能( Functions)
- 递归
- 循环
- Enumerables( Enumerables)
- Streams( Streams)
- Structs( Structs)
- 协议 Protocols
- File I/O
- 进程( Processes)
- Sigils( Sigils)
- 理解( Comprehensions)
- Typespecs( Typespecs)
- 行为( Behaviours)
- 错误处理( Errors Handling)
- Macros( Macros)
- (库)Libraries
- 有用的资源
- 讨论
- Show 例子
- Show 例子
- Show 例子
- Show 例子
- Show 例子
- if statement
- if..else statement
- unless statement
- unless..else statement
- cond
- case
文章来源于网络收集而来,版权归原创者所有,如有侵权请及时联系!
Structs( Structs)
结构是在地图之上构建的扩展,提供编译时检查和默认值。
定义结构
要定义结构,使用defstruct构造 -
defmodule User do
defstruct name: "John", age: 27
end
与defstruct一起使用的关键字列表定义了struct将包含哪些字段及其默认值。 结构取其定义的模块的名称。在上面给出的示例中,我们定义了一个名为User的结构。 我们现在可以使用类似于用于创建地图的语法来创建用户结构 -
new_john = %User{})
ayush = %User{name: "Ayush", age: 20}
megan = %User{name: "Megan"})
上面的代码将生成三个具有值的不同结构 -
%User{age: 27, name: "John"}
%User{age: 20, name: "Ayush"}
%User{age: 27, name: "Megan"}
Structs提供编译时保证,只允许通过defstruct定义的字段(以及所有字段)存在于结构中。 因此,一旦在模块中创建了结构,就无法定义自己的字段。
访问和更新结构
当我们讨论地图时,我们展示了如何访问和更新地图的字段。 相同的技术(和相同的语法)也适用于结构。 例如,如果我们想要更新我们在前面的示例中创建的用户,那么 -
defmodule User do
defstruct name: "John", age: 27
end
john = %User{}
#john right now is: %User{age: 27, name: "John"}
#To access name and age of John,
IO.puts(john.name)
IO.puts(john.age)
运行上述程序时,会产生以下结果 -
John
27
要更新结构中的值,我们将再次使用我们在map章节中使用的相同过程,
meg = %{john | name: "Meg"}
结构也可以用于模式匹配,既可以匹配特定键的值,也可以确保匹配值是与匹配值相同类型的结构。
如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。

绑定邮箱获取回复消息
由于您还没有绑定你的真实邮箱,如果其他用户或者作者回复了您的评论,将不能在第一时间通知您!
发布评论