tnblog
首页
视频
资源
登录

c 动态数组

5141人阅读 2019/8/15 23:18 总访问:3425405 评论:0 收藏:0 手机
分类: 传说中的c

国人随便写的

可以存储一些小的数据

DynamicArray.h

  1. #ifndef _New_DynamicArray_
  2. #define _New_DynamicArray_
  3. typedef struct _vector_array
  4. {
  5. unsigned char* mem_data; //存放我们数组的元素
  6. int max_mele;//当这块内存最大的容量;
  7. int elem_count;//当前这块内存存放的元素个数
  8. int sizeof_elem;//每个元素占的内存大小
  9. }vector_array,*vector_arrayPointer;
  10. //定义配置
  11. //v 表示指向哪个 sizeof_elem元素大小
  12. void vector_define(vector_arrayPointer v, int sizeof_elem);
  13. //清楚
  14. void vector_clear(vector_arrayPointer v)
  15. //往动态数组里面最后存放我们的元素
  16. void vector_push_back(vector_arrayPointer v,const void* elem_ptr);
  17. // 获取第i个元素的地址
  18. voidvector_at(vector_arrayPointer v,int index);
  19. //返回开始第一个数据指针
  20. voidvector_begin(vector_arrayPointer v);
  21. #define vector_size(v) ((v)->sizeof_elem);
  22. // 清理到这个数组所有元素,但是我们还要继续存放
  23. void vector_popall(vector_arrayPointer v);
  24. //删除元素
  25. void Remove_item(vector_arrayPointer v, int start, int count);
  26. //弹出最后一个元素
  27. //并把最后一个给准备好的内存里面
  28. void vector_popback(vector_arrayPointer v, void* out_of_elem);
  29. #endif

DynamicArray.c

  1. #include <stdio.h>
  2. #include <stdlib.h>
  3. #include <string.h>
  4. #include "DynamicArray.h"
  5. //定义自己的堆空间 叫my_malloc
  6. #define my_malloc malloc;
  7. //定义自己的释放方法 my_free
  8. #define my_free free;
  9. //定义自己的扩容方法my_realloc
  10. #define my_realloc realloc;
  11. #define ELEM_STMP 64
  12. //初始化
  13. //v 表示指向哪个 sizeof_elem元素大小
  14. void vector_define(vector_arrayPointer v, int sizeof_elem) 
  15. {
  16. memset(v, 0sizeof(vector_array));
  17. v->sizeof_elem = sizeof_elem;
  18. }
  19. //clear item
  20. void vector_clear(vector_arrayPointer v) 
  21. {
  22. if (v->mem_data)
  23. {
  24. my_free(v->mem_data);
  25. v->mem_data = NULL;
  26. v->elem_count = 0;
  27. v->max_mele = 0;
  28. }
  29. }
  30. //存到数组
  31. void vector_push_back(vector_arrayPointer v, const void* elem_ptr)
  32. {
  33. //判断是否还有多余的空间够存储
  34. if (v->elem_count >= v->max_mele)
  35. {
  36. v->max_mele += ELEM_STMP;
  37. my_realloc(v->mem_data,v->max_mele * v->sizeof_elem);
  38. }
  39. //存放元素
  40. memcpy(v->mem_data + v->elem_count * v->sizeof_elem,elem_ptr, v->sizeof_elem);
  41. v->elem_count++;
  42. }
  43. //下标获取值
  44. voidvector_at(vector_arrayPointer v, int index) 
  45. {
  46. if (index < v->elem_count && index >=0)
  47. {
  48. return (void*)(v->mem_data + index * v->sizeof_elem);
  49. }
  50. return NULL;
  51. }
  52. //返回开始第一个数据指针
  53. voidvector_begin(vector_arrayPointer v)
  54. {
  55. return v->mem_data;
  56. }
  57. // 清理到这个数组所有元素,但是我们还要继续存放
  58. void vector_popall(vector_arrayPointer v) 
  59. {
  60. v->elem_count = 0;
  61. }
  62. void Remove_item(vector_arrayPointer v, int start, int count)
  63. {
  64. if (start < 0 || start >= v->elem_count)
  65. {
  66. return;
  67. }
  68. if (start + count > v->elem_count)
  69. {
  70. count -= (start + count) - v->elem_count;
  71. }
  72. //判断元素大于0
  73. if ((v->elem_count - (start + count))>0)
  74. {
  75. memmove(v->mem_data + start * v->sizeof_elem,
  76. v->mem_data + (start + count) * v->sizeof_elem,
  77. (v->elem_count - (start + count)) * v->sizeof_elem);
  78. }
  79. v->elem_count -= count;
  80. }
  81. void vector_popback(vector_arrayPointer v, void* out_of_elem) 
  82. {
  83. if (v->elem_count<=0)
  84. {
  85. return;
  86. }
  87. v->elem_count --;
  88. if (out_of_elem)
  89. {
  90. memcpy(out_of_elem,v->mem_data+v->elem_count * v->sizeof_elem,v->sizeof_elem);
  91. }
  92. }


给国人一个小目标,三年后不干c#了!

转型不转行!




欢迎加群讨论技术,1群:677373950(满了,可以加,但通过不了),2群:656732739

评价

css弹性盒子,flex布局

css弹性盒子由于版本不同浏览器问题造成了一些不同的写法display:flexbox;在google浏览器中如果使用下面的写法就不行displa...

css图片和文字对齐问题

文字和图片写到一排经常会出现对不齐的问题 这样感觉图片会上来一点没有和文字对齐,如下图 但是如果修改下html结...

GitHub 上传项目

补充简化方法:登录git创建项目--&gt;拉取刚刚创建的项目--&gt;复制需要的代码进去--&gt;上传提交即可先拉取项目在上传代码...

NET core 使用 EF code First

下面这些内容很老了看这篇:https://www.tnblog.net/aojiancc2/article/details/5365 项目使用多层,把数据库访问...

Windows平台分布式架构实践 - 负载均衡

原文地址: https://www.cnblogs.com/atree/p/windows_loadbalancer.html 概述  最近.NET的世界开始闹腾了,微软官方终...

css实现简单矩形对话框

在前端做项目时,我们可能会遇到写对话框的需求,这次做视频会议页面就遇到了,记录下日后有个参照。//网页部分 &lt;divcla...

cAPS.NET 保存base64位格式的图片

publicvoidUpload() { //取出图片对应的base64位字符 stringimgBase=Request[&quot;imgBase&quot;]; //c#里边的base6...

使用OLEDB读取不同版本Excel的连接字符串设置

使用OleBD读取excel的时候,excel不同的版本,连接字符串的写法也会不一样。///&lt;summary&gt; ///读取excel ///&lt;/su...

vs2017 对 cOM 组件的调用返回了错误 HRESULT E_FAIL

vs2017添加引用报错 对 COM 组件的调用返回了错误 HRESULT E_FAIL 1.以管理员身份打开vs2017开发人员命令指示符 2...

分布式服务架构与微服务架构概念的区别与联系

分布式:分散压力。微服务:分散能力。当下理解分布式:不同模块部署在不同服务器上作用:分布式解决网站高并发带来问题集...

分布式-微服务-集群的区别

1.分布式将一个大的系统划分为多个业务模块,业务模块分别部署到不同的机器上,各个业务模块之间通过接口进行数据交互。区...

NPOI操作excel 2007/2010版本

HSSFWorkbook:是操作Excel2003以前(包括2003)的版本,扩展名是.xlsXSSFWorkbook:是操作Excel2007的版本,扩展名是.xlsx先...

这样学英语三个月超过你过去学三年

本文作者三年间从四级勉强及格到高级口译笔试210,口试232。找工作面试时给其口试的老外考官听了一分钟就说你的英语不用考...

EasyUI弹窗批量修改combogrid下拉框的值

JS方法//点击弹出批量修改框 UpdateLot:function(){ varrow=$(&quot;#dg&quot;).datagrid(&quot;getChecked&quot;); if(...

js与controller中分割字符串的方法

js: varstr=OpenRule; varstrs=newArray(); strs=str.split(&quot;,&quot;); for(vari=0;i&lt;strs.length;i++){ $(&q...

如何修改cSS中存在的element.style内联样式

改腾讯地图的时候调整了下样式,发现样式一直存在问题,修改style里面的值,一点用都没有,html中这个值还找不到是在哪里出...
这一世以无限游戏为使命!
排名
2
文章
633
粉丝
44
评论
93
docker中Sware集群与service
尘叶心繁 : 想学呀!我教你呀
一个bug让程序员走上法庭 索赔金额达400亿日元
叼着奶瓶逛酒吧 : 所以说做程序员也要懂点法律知识
.net core 塑形资源
剑轩 : 收藏收藏
映射AutoMapper
剑轩 : 好是好,这个对效率影响大不大哇,效率高不高
ASP.NET Core 服务注册生命周期
剑轩 : http://www.tnblog.net/aojiancc2/article/details/167
ICP备案 :渝ICP备18016597号-1
网站信息:2018-2025TNBLOG.NET
技术交流:群号656732739
联系我们:contact@tnblog.net
公网安备:50010702506256
欢迎加群交流技术