前言:
变长数组好处多多,他可以根据需要设置数组的长度,节省了内存开支,防止了因为数组越界导致的内存泄漏。
故:我们都要学会CAPL如何实现变长数组。整体代码如下
1:CAPL中的关联字段(Associative Field)
1.1 关联字段的概念
这个概念有点类似于Python中的字典,即定义时需定义一个key值,和一个value
# 字典定义格式: 变量 = {键1:值1, 键2:值2.....}
dict1 = {'name': 'xiaoming', 'age': 18, 'gender': '女'}
使用的时候直接在【‘’】内,输入key的值,既可以索引到key对应的value。
执行语句:print(dict1['name'])
就会在屏幕上打印'xiaoming'
CAPL中也存在类似的概念:称为关联字段,而11对应的key和value,Python中称为一个键值对。后面的CAPL中我们也引用“键值对”的概念。
1.2:CAPL中关联字段的定义
我们以数组为例,举例说明
int Array_1[long];
此段代码的意义在于:声明了一个int类型的数组,数组名称为Array_1,数组长度确没有作出说明,只写了个long(长整形的声明)
然后就可以实现一个长度变化的int类型的数组了
on key 'a'
{
/*代码段1:首先看变长数组如何实现*/
int i=0;
int Array_1[long]; //数组的【】不在使用显示常量或const修饰的变量显示大小,而是声明了一种变量类型
/**对变长数组进行赋值**/
for(;i<100;i++)
{
Array_1[i]=i;
}
write("直接赋值后看看数组的大小是多少%d",Array_1.size());
直接按'a'查看结果
我们再把 修改为 i<101,再添加一个打印Array[10的值]
on key 'a'
{
/*代码段1:首先看变长数组如何实现*/
int i=0;
int Array_1[long]; //数组的【】不在使用显示常量或const修饰的变量显示大小,而是声明了一种变量类型
/**对变长数组进行赋值**/
for(;i<101;i++)
{
Array_1[i]=i;
}
write("直接赋值后看看数组的大小是多少%d",Array_1.size()); //实际上是对
write("查看第10个值Array_1[10]=%d",Array_1[10]);
}
运行查看结果
第三步:遍历所有key值,查看对应的value。为了方便起见,我们修改i<20,并添加遍历和打印语句。
for(long mykey:Array_1)
{
write("遍历Array所有的值%d"Array_1[mykey]);
}
查看结果
这里首先关注for循环中的语句,for(long mykey:Array_1),首先拆分为两个部分来看,long mykey是定义了一个变量 mykey,类型为long类型,long mykey: 后面加了一个封号,这可以理解为CAPL自己独特的一个语法。
准确的来说是针对Asssociate Field的特殊用法,:代表此定义的变量是作为数组的key值,且联合for循环关键字。能实现遍历所有key
实际这段代码,for(long mykey:Array_1),等价于以下代码:
i=0;
for(;i<Array_1.size();i++)
输出结果也一样,说这么多其实就是需要让大家理解for(long mykey:Array_1)并不是错误的写法,大家需要了解它的运行逻辑。
此外还有两点需要特别注意:
**1)key值定义的类型,一定要和声明语句int Array_1[long];保持一致,不然程序会报错
**2)for(long mykey:Array_1)用来遍历所有key值,必须是数组已经被完整的赋值过一次,本段代码中也就是
for(;i<101;i++)
{
Array_1[i]=i;
}
语句来实现的赋值
1.3关联字段和和变长数组的联系
通过上一章,我们可以理解了,通过关联字段,可以设置任意长度的数组,可以任意赋值。
1.4 关联字段被定义后,可以调用使用的一些函数和方法
之前的代码中,我们就使用了关联字段的Array_1.size()。除了size(),之外还有四种方法或函数可以调用。如下图
**1)Array_1.clear :是清除整个关联字段,完整的调用语句Array_1.clear(); 注意这个()是必不可少的。
实测发现调用clear方法,不会产生返回值。由此可以知道,调用这个方法时,并不能通过返回值确定是否真的清除成功。
**2)containsKey(注意中间的K是一个大写),此条语句是判断有数组中有没有包含特定key值
Array_1.containsKey(5); 此语句的含义是检查是否包含key=5。当包含时,放回值1,不包含时返回值0。通常可以用来作为if和while的判断条件
**3)remove(),该方法包含一个参数,可以是常量和变量(变量最好可key的类型保持一致),是移除key对应的value,也就是通过key值移除一个键值对
**4)size()该方法没有参数,返回的是键值对的个数
1.5 关联字段的实质到底是什么?
之前的例子,我们对关联字段赋值时,key的值都是连续的,故后续使用上和数组很像,但是并不能说数组是和关联字段一样的。
比如上一代码可以修改为这样
for(;i<101;i++)
{if(i%2==0)
Array_1[i]=i;
}
这样,key只有 0 -2-4-。。。等偶数。
再此回想一下,数组 定义时 int Array_2[10],则数组元素从0-9一定是连续存在的,且根据C语言的知识我们可知。数组元素的地址一定是连续的,比如Array_2[0]的地址=0x00 00 00 00。则Array_2[1]的地址一定=0x00 00 00 04。
但是关联字段是不是这样?暂时不知道,因为CAPL无法打印变量地址。