当前位置: 首页 > news >正文

C语言的“动态数组”

C语言的“动态数组”

掩码结构体宏的实现本质上就是使用一个掩码数组 chMask 把结构体保护起来。见《大佬的PLOOC使用示例及其基于C语言的面向对象编程-傻孩子.pdf》

 1 /* 公众号:嵌入式大杂烩 */
 2 #ifndef __DYNAMIC_ARRAY_H
 3 #define __DYNAMIC_ARRAY_H
 4  
 5 /* 结构体“重命名” */
 6 typedefstruct dynamic_array dynamic_array_def;
 7  
 8 /* 初始化dynamic_array */
 9 dynamic_array_def *DA_Init(void);
10  
11 /* 销毁dynamic_array */
12 voidDA_Clean(dynamic_array_def *pThis);
13  
14 /* 设置dynamic_array长度 */
15 voidDA_SetSize(dynamic_array_def *pThis, unsigned len);
16  
17 /* 获取dynamic_array长度 */
18 unsignedDA_GetSize(dynamic_array_def *pThis);
19  
20 /* 设置dynamic_array某元素的值 */
21 intDA_SetValue(dynamic_array_def *pThis, unsigned index, int value);
22  
23 /* 获取dynamic_array某元素的值 */
24 intDA_GetValue(dynamic_array_def *pThis, unsigned index, int *pValue);
25  
26 #endif
dynamic_array.h
 1 /* 公众号:嵌入式大杂烩 */
 2 #include "dynamic_array.h"
 3 #include <stdlib.h>
 4  
 5 /* 创建一个动态数组结构体模板 */
 6 struct dynamic_array
 7 {
 8     int*array;
 9     unsigned len;
10 };
11  
12 /* 初始化dynamic_array */
13 dynamic_array_def *DA_Init(void)
14 {
15     dynamic_array_def *pArray =malloc(sizeof(dynamic_array_def));
16  
17     pArray->array=NULL;
18     pArray->len =0;
19 }
20  
21 /* 销毁dynamic_array */
22 voidDA_Clean(dynamic_array_def *pThis)
23 {
24     free(pThis->array);
25     pThis->len =0;
26     free(pThis);
27 }
28  
29 /* 设置dynamic_array长度 */
30 voidDA_SetSize(dynamic_array_def *pThis, size_t len)
31 {
32     pThis->len = len;
33     pThis->array=(int*)realloc(pThis->array, pThis->len*sizeof(int));
34 }
35  
36 /* 获取dynamic_array长度 */
37 size_tDA_GetSize(dynamic_array_def *pThis)
38 {
39     return pThis->len;
40 }
41  
42 /* 设置dynamic_array某元素的值 */
43 intDA_SetValue(dynamic_array_def *pThis, size_t index, int value)
44 {
45     if(index > pThis->len)
46     {
47         return-1;
48     }
49  
50     pThis->array[index]= value;
51     return0;
52 }
53  
54 /* 获取dynamic_array某元素的值 */
55 intDA_GetValue(dynamic_array_def *pThis, size_t index, int *pValue)
56 {
57     if(index > pThis->len)
58     {
59         return-1;
60     }
61  
62     *pValue = pThis->array[index];
63     return0;
64 }    
dynamic_array.c

 

http://www.hskmm.com/?act=detail&tid=28688

相关文章:

  • 背包 dp 历年真题:做题记录
  • 【触想智能】什么是工业平板电脑以及工业平板电脑对制造业具有什么意义
  • 2025 年国内无尘车间源头厂家最新推荐排行榜:聚焦无菌洁净领域优选企业助力企业精准选型万级/十万级/洁净/食品厂/千级无尘车间厂家推荐
  • 新手小白安装Typroa遇到的问题 - I
  • 怎么能跑得快,怎么突破瓶颈
  • (Sigcomm25) Stellar: 阿里新一代云AI RDMA网络
  • 高效工作,五步工作法
  • 虚树学习笔记
  • 市场营销:
  • Python3开发敏感词过滤程序底层逻辑记录
  • OUC《软件工程原理与实践》- 实验2:深度学习基础 - OUC
  • 类型转化
  • 【IEEE出版】第五届电子信息工程与计算机技术国际学术会议(EIECT 2025)
  • 【AP出版】第七届文学、艺术与人文发展国际学术会议(ICLAHD 2025)
  • 事件驱动重塑 AI 数据链路:阿里云 EventBridge 发布 AI ETL 新范式
  • 我把Excel变成了像素画板!用Python实现图片到单元格的映射
  • 如何通过内核版本检查判断FreeBSD是否需要重启
  • 2025 年山东染井吉野樱 / 高杆染井吉野樱花 / 染井吉野樱花小苗厂家推荐:绿影园林的培育技术与全规格供应解析
  • C#中关于InvokeRequired 属性 与Invoke方法
  • 云存储成本自动优化技术解析
  • MZOI 20251011【CSP-】模拟 T2 序列区间
  • SAP 中CONCATENATE 空格的时候,空格不生效
  • Java的各类定时任务实现
  • 03:运算符
  • JavaScript内存泄露原因及解决方案
  • 数据类型扩展
  • 2025 年最新金蝶云服务商推荐榜单:聚焦铂金伙伴技术实力与万级客户口碑,助力企业数字化转型精准选型上海金蝶云服务商推荐
  • OIFHA251011 比赛总结
  • P2051 [AHOI2009] 中国象棋 个人题解
  • 一种智能调度分布式路径计算解决方案