|
|
8a65218105
|
feat(segarray): 实现随机访问,优化迭代器和头尾访问实现逻辑,并与ringbuf对比不同应用场景下的优劣
|
2026-05-16 22:18:59 +08:00 |
|
|
|
115646ecd4
|
refactor(core): 统一内存管理与日志宏接口
|
2026-05-16 17:55:47 +08:00 |
|
|
|
0dd45ed7dd
|
refactor(segarray): 段使用rawbuf而不是darray,先按照最简单的方式调试通push和pop等操作
|
2026-05-15 19:01:37 +08:00 |
|
|
|
0236e6e315
|
feat(rawbuf): 新增 rawbuf 模块,做随机访问,支持malloc和静态内存。
(之前我突然对darray理解错了,现在的darray设计就是合理的。注意区分开rawbuf和darray)
|
2026-05-15 15:53:11 +08:00 |
|
|
|
3ceffc938e
|
segarray调试期间,发现我的darray设计的非常不合理,size基于insert,而set有基于size。这样新建的darray不能立刻使用set
|
2026-05-15 13:37:45 +08:00 |
|
|
|
d6a6bacbb0
|
ringbuf: add random access
|
2026-05-15 10:34:25 +08:00 |
|
|
|
dcce634326
|
segarray的流程还不对,今天太晚了,明天再调整。
|
2026-05-15 02:45:21 +08:00 |
|
|
|
fb7ac93623
|
refactor(queue): 统一初始化接口并添加 resize 功能
|
2026-05-15 01:40:59 +08:00 |
|
|
|
7741ac3f40
|
refactor(stack): 统一构造函数并添加扩容与满栈检测
|
2026-05-15 01:10:07 +08:00 |
|
|
|
d36346ce00
|
feat(algo): 新增算法模块并给darray集成排序和查找功能,index底层改为调用search
|
2026-05-15 00:04:04 +08:00 |
|
|
|
f8ba5197a8
|
darray添加iter操作,deque新增resize,更新deque的单元测试
|
2026-05-14 19:22:17 +08:00 |
|
|
|
3fda59ba06
|
refactor(queue):底层修改为deque
|
2026-05-14 18:29:12 +08:00 |
|
|
|
8a3455efee
|
refactor(ringbuf)!: 重命名模块并增加动态扩容与静态内存支持
|
2026-05-14 14:15:10 +08:00 |
|
|
|
55cff2c2ba
|
将darray的索引类型修正为 size_t 并 新增栈和队列的嵌入式接口
|
2026-05-14 01:45:28 +08:00 |
|
|
|
f512f72d2e
|
refactor(darray): 优化内存策略并移除动态扩容开关。固定容量场景交由上层封装,darray不再支持。
|
2026-05-14 00:32:49 +08:00 |
|
|
|
864273cef2
|
bugfix(stack): 栈的stack_new宏定义多套了一层sizeof,展开后sizeof(sizeof(int)),让obj_size=8了
|
2026-05-13 21:50:31 +08:00 |
|
|
|
97653622c1
|
stack->peek把data的内存给修改了,后续再排查一下原因
|
2026-05-13 19:27:38 +08:00 |
|
|
|
2278bad0a4
|
feat(perf): 重构性能测试框架(支持多组参数配置)并增加perf_log(利用darray实现并格式化输出)
|
2026-05-13 17:00:39 +08:00 |
|
|
|
cd6eff28a7
|
ringbuffer重构底层代码,并将obj和index的操作独立成内联函数,另外将deque的底层架构直接修改为ringbuffer
|
2026-05-12 18:42:43 +08:00 |
|
|
|
a58d480ae4
|
ringbuffer调试通过,疑问点:感觉复用darray相对于直接malloc并没有简化多少,只是把计算偏移这部分简化了。
|
2026-05-12 16:29:40 +08:00 |
|
|
|
9a9f18ac40
|
将index、len、size等变量的定义,都配置成size_t而不是uint32_t,至于列表对应的负数索引,先按照int吧,后续有必要再修改成ssize_t
|
2026-05-12 10:36:31 +08:00 |
|
|
|
26eeb65cc9
|
refactor(core)!: 重构链表核心API,增加 const 正确性与自定义断言
- 将所有打印和比较函数的参数指针从 `void*` 修改为 `const void*`,增强类型安全
- 引入自定义断言宏 `unicstl_assert` 及其实现,替换标准 `assert`
- 优化动态数组容量增长策略,新增 `unicstl_new_capacity` 函数
- 重构链表 接口:`push`/`pop` 重命名为 `push_back`/`pop_front`,新增 `push_front`/`pop_back`/`insert`/`remove`/`contains` 方法
- 移除链表结构体中未使用的 `_index_front` 和 `_index_back` 成员
- 在头文件中补充关键函数的时间复杂度注释
|
2026-05-12 02:26:21 +08:00 |
|
|
|
17a9d51437
|
linklist先照搬了queue,后续用到再修改吧。另外,darray中的部分函数传参,我添加了const修饰
|
2026-05-11 19:05:58 +08:00 |
|
|
|
1532d3716c
|
darray实现
|
2026-05-11 15:16:42 +08:00 |
|
|
|
9322db6b62
|
修改common为unicstl_internal,顺便给其他数据结构都添加默认的compare和print_obj接口
|
2025-04-30 23:26:36 +08:00 |
|
|
|
0f18ddf567
|
slice单元测试基本都添加完毕,现在可以针对性的进行修改了
|
2025-04-30 00:58:28 +08:00 |
|
|
|
643d601c6e
|
添加slice函数,但是还有两个问题没有解决
|
2025-04-30 00:01:37 +08:00 |
|
|
|
c8a48e6c63
|
想统一inset和pop但是编译测试不通
|
2025-04-29 16:25:27 +08:00 |
|
|
|
851f815120
|
修改list相关接口描述以及调通由于删除deque的接口导致的编译问题
|
2025-04-29 14:53:54 +08:00 |
|
|
|
446ede15db
|
添加list实现原理说明
|
2025-04-29 11:52:15 +08:00 |
|
|
|
6fb620850e
|
双向队列删除非核心代码,至于其底层实现是否权衡各种场景,则后续再考虑优化。
|
2025-04-29 11:41:31 +08:00 |
|
|
|
4acdcf3ec7
|
开启assert后解决编译和测试问题
|
2025-04-28 00:59:03 +08:00 |
|
|
|
4aa966bb93
|
修改iter的parent为_container,避免理解偏差
|
2025-04-27 13:42:30 +08:00 |
|
|
|
c70b007386
|
iter的node一定是当前节点,因此cur的前缀就有些多余了
|
2025-04-27 12:44:47 +08:00 |
|
|
|
4691b848ef
|
修改iter的成员属性_cur为_index更加直观
|
2025-04-27 12:41:10 +08:00 |
|
|
|
1982a90a3e
|
tree删除非必要属性,把order遍历相关的操作都放在iterator中了
|
2025-04-27 11:43:57 +08:00 |
|
|
|
d278ef008f
|
tree_order枚举类型重命名,防冲突
|
2025-04-27 11:41:20 +08:00 |
|
|
|
7a7af3152a
|
_rebalance作为私有函数
|
2025-04-27 11:06:16 +08:00 |
|
|
|
59e5c9be71
|
获取树高的接口重新定义
|
2025-04-27 11:05:12 +08:00 |
|
|
|
313406970c
|
修改头文件的核心操作和基础操作顺序,方便一眼看出
|
2025-04-27 02:29:09 +08:00 |
|
|
|
ca4ab10123
|
deque区分正向和反向遍历
|
2025-04-27 01:16:22 +08:00 |
|
|
|
9e270b7425
|
后续考虑matrix是利用list来实现还是直接函数指针实现。但考虑到用一维指针或者二维指针都有不方便的地方。
|
2025-04-27 00:16:44 +08:00 |
|
|
|
98eb005a4a
|
bfs的遍历还存在问题
|
2025-04-26 15:01:15 +08:00 |
|
|
|
ce973043d8
|
graph默认只对顶点进行遍历,后续实现bfs和dfs
|
2025-04-26 13:40:23 +08:00 |
|
|
|
3ac92de18e
|
边的核心操作都添测试通过了,但是我个人觉得写的不好。后续再考虑优化。
|
2025-04-25 18:19:22 +08:00 |
|
|
|
f63aa4db0a
|
为什么from_node和to_node的obj不符合预期
|
2025-04-25 16:55:22 +08:00 |
|
|
|
163f3c55da
|
vertex的添加代码实现并调试通过
|
2025-04-25 13:39:17 +08:00 |
|
|
|
46f1f365fb
|
添加新增的graph成员函数定义
|
2025-04-25 13:16:16 +08:00 |
|
|
|
af1a3703ba
|
graph的vertex和edge结构体都重新定义,kernel函数也重新命名
|
2025-04-25 13:03:23 +08:00 |
|
|
|
b788dd74ee
|
graph结构体node重新规划
|
2025-04-25 10:47:42 +08:00 |
|