matlab中也有结构体,和大多数语言一样;
结构体数组具有下列属性:
数组中的所有结构体都具有相同数目的字段。
所有结构体都具有相同的字段名称。
不同结构体中的同名字段可包含不同类型或大小的数据。
数组中新结构体的任何未指定字段均包含空数组。
s = struct 创建不包含任何字段的标量 (1×1) 结构体。
s = struct(field,value)
创建具有指定字段和值的结构体数组。value
输入参数可以是任何数据类型,例如数值、逻辑值、字符或元胞数组。
如果 value
不是元胞数组,或者 value
是标量元胞数组,则 s
是标量结构体。例如,s = struct('a',[1 2 3])
创建一个 1×1 结构体,其中 s.a = [1 2 3]
。
如果 value
是非标量元胞数组,则 s
是维度与 value
相同的结构体数组。s
的每个元素包含 value
的对应元素。例如,s = struct('x',{'a','b'})
返回 s(1).x = 'a'
和 s(2).x = 'b'
。
如果 value
是空元胞数组 {}
,则 s
是空 (0×0) 结构体。
s = struct(field1,value1,...,fieldN,valueN)
创建一个包含多个字段的结构体数组。
如果 value
的所有输入都不是元胞数组,或者 value
中作为元胞数组的所有输入都是标量,则 s
是标量结构体。
如果任一 value
输入是非标量元胞数组,则 s
具有与该元胞数组相同的维度。此外,如果两个或多个 value
输入是非标量元胞数组,则它们必须都具有相同的维度。
对于类型为标量元胞数组或任何其他数据类型的数组的任何 value
,struct
将 value
的内容插入 s
的所有元素的相关字段中。例如,s = struct('x',{'a','b'},'y','c')
返回 s(1).x = 'a'
、s(2).x = 'b'
、s(1).y = 'c'
和 s(2).y = 'c'
。
如果任何 value
输入是空元胞数组 {}
,则输出 s
是空 (0×0) 结构体。要指定一个空字段并保留其他字段的值,请改用 []
作为 value
输入。
s = struct([])
创建不包含任何字段的空 (0×0) 结构体。
s = struct(obj)
创建包含与 obj
的属性对应的字段名称和值的标量结构体。struct
函数不会转换 obj
,而是将 s
创建为一个新的结构体。此结构体不保留类信息,因此专用、受保护和隐藏的属性在 s
中变为公共字段。struct
函数在您使用此语法时会发出警告。
创建结构体变量,主要可以分为两种:直接构建;利用struct创建
node(1).name = 'xiezhh';
node(2).name = 'heping';
node(1).age = 31;
node(2).age = 22;
这里node就是定义的结构体,node(1),node(2)...为每个结构体的存储单位,就像矩阵a(1),a(2)一样,每个单位包括name,age等不同数据。这里的构建是直接给每个结构体单位的每个数据赋值。
我们来输出一下node(1)查看显示结果:
node(1)
也可以单独查看一个或者修改
node(1).age=45
node(1).age
这里struct函数用来构建结构体类型
调用格式struct(name1,data1,name2,data2....)
我们以上面的结构体为例:
node = struct('name', {'xiezhh', 'heping'}, 'age',{31, 22})
node(1).name
注意这里的数据要用大括号括起来
简单看一下输出结果
删除单个字段;删除多个字段;
定义一个包含名为 a
、b
和 c
的字段的标量结构体。
s.a = 1; s.b = 2; s.c = 3;
删除字段 b
。
s = rmfield(s,field) s = struct with fields: a: 1 c: 3
定义一个包含 first
、second
、third
和 fourth
字段的标量结构体。
S.first = 1; S.second = 2; S.third = 3; S.fourth = 4;
删除字段 first
和 fourth
。
fields = {'first','fourth'}; S = rmfield(S,fields) S = struct with fields: second: 2 third: 3
按照某种方式获取成员变量;获取具体某个成员变量的值;使用函数获取某个成员变量的值;
fieldnames 获取成员变量名称
orderfields 获取成员变成的字母排序
clear all; s=struct('da',0,'xian',1,'yi',2,'pin',3) f1=fieldnames(s) %获取成员变量的名称 f2=orderfields(s) %按照成员变量的字母顺序排序
通过点来具体获取某个实际成员变量的值
clear all; s=struct('xingming',{'daxian','dashen'},'xingbie',{'nan','nv'},'fenshu',[67 90 99]); s(1).xingming s(1).xingbie s(1).fenshu s(1).fenshu(3)
通过使用函数getfield来获取成员变量的值
clear all; s1=struct('haha',8,'hehe',9) f1=getfield(s1,'haha')
使用函数来对成员变量重新赋值
clear all; s1=struct('haha',7,'hehe',8) s2=setfield(s1,'haha',9)
使用isfield函数来进行判断
clear all; s=struct('hehe',1,'haha',2) f1=isstruct(s) f2=isfield(s,'hehe') f3=isfield(s,'pipi') f4=isfield(s,{'hehe','pipi','haha','kuku'})
强制转换数据类型
clear all; s(1).name='daxian'; s(1).sex='nan'; s(1).salary=20; s(2).name='dashen'; s c=struct2cell(s)