如何在CAPL中实现变长数组(一维数组)

前言:

变长数组好处多多,他可以根据需要设置数组的长度,节省了内存开支,防止了因为数组越界导致的内存泄漏。

故:我们都要学会CAPL如何实现变长数组。整体代码如下

cpp 复制代码
/*@!Encoding:936*/
includes
{
  
}

variables
{
  
}

on key 'a'
{
  /*代码段1:首先看变长数组如何实现*/
  int Array_1[long];       //数组的【】不在使用显示常量或const修饰的变量显示大小,而是声明了一种变量类型
  stack long MyKey=100;    //stack 是CAPL特有的一个修饰关键字,是将变量存放于堆区,每次进入代码,都需要执行初始化
  stack long i=0;
  Array_1[MyKey]=MyKey;    //这段代码有两个作用,1:是对数组的长度设置为101,2:是将数组的最后一个成员值=100
  write("直接赋值后看看数组的大小是多少%d",Array_1.size());   //实际上是对
  /*代码段2:如何快速的对所有数组赋值*/
  for(;i<MyKey;i++)
  {
    Array_1[MyKey]=MyKey;
  }
  for(long Mykey:Array_1)  //遍历关联字段的所有KEY值,功能可以理解如下代码
    /*
    
    for(long Mykey;Mykey<=MyKey;Mykey++) 
    {
    
    
    }
    
    
    */
  {
    
    write("%d",Array_1[Mykey]);
  }
  /*最后看看变长数组,自带的几种Method*/
  Array_1.containsKey(99);  //是检查是否包含第99个数组成员。返回值1,代表成员存在。0代表不存在
  Array_1.remove(98);       //移除第98个数组成员,移除后,数组成员变成100个,移除的98位,被99位的成员覆盖,即移除后,大覆盖小
  
}

总结:1:注意CAPL中变长数组声明方式,关注特殊的声明方式

2:注意变长数组,特殊的for()遍历key的用法,另外注意只有初始化赋值后,才能使用for遍历key的用法

3:注意,当变长数组执行remove()方法后,才能继续初始化变长数组。

相关推荐
是梦终空1 分钟前
vue下载依赖报错npm ERR node-sass@4.14.1 postinstall: `node scripts/build.js`的解决方法
javascript·npm·vue·node-sass·vue依赖
依米_3 分钟前
一文带你剖析 Promise.then all 实现原理,状态机、发布订阅模式完美实现异步编程
javascript·设计模式
陈陈小白3 分钟前
npm run dev报错Error: listen EADDRINUSE: address already in use :::8090
前端·npm·node.js·vue
G018_star sky♬4 分钟前
使用npm运行js脚本覆盖vue依赖包
javascript·vue.js
杂鱼豆腐人5 分钟前
pnpm环境下防止误使用npm的方法
前端·git·npm·node.js·git bash
我是ed7 分钟前
# vue2 使用 cesium 展示 TLE 星历数据
前端
m0_7369270424 分钟前
2025高频Java后端场景题汇总(全年汇总版)
java·开发语言·经验分享·后端·面试·职场和发展·跳槽
宇余29 分钟前
从 useState 到 URLState:前端状态管理的另一种思路
前端·vue.js
白兰地空瓶35 分钟前
🚀 10 分钟吃透 CSS position 定位!从底层原理到避坑实战,搞定所有布局难题
前端·css