C 语言泛型数组实现

typedef struct {
    // element byte size
    int stride;
    // element number
    int length;
    // memory data
    void* data;
} Array;


data是个指针,需要malloc申请动态内存。对,这里面放的是数组的数据。好的,那么现在数据有了,那么是什么类型的呢? 就看stride的了,这个值就是每个数组元素的字节大小。sizeof返回的值。数组的长度是什么,就是length。

这个Array的数据放在data指针指向的空间中,元素类型是stride,有length个元素。可以是任何类型,stride和length可以帮助我们遍历数组中的任何一个元素。且看,遍历的代码:

//  Get the type pointer points index of Array
#define pointerOfArray(array, index, type) \
        ((type*) ((char*) ((array)->data) + (array)->stride * (index))) \

参数解释:

  • array 就是数组的指针
  • index 就是数组元素的索引
  • type   就是数组元素的类型
  • 返回值是指向数组元素的指针

那么在给出一个宏定义:

//  Get the type element which index of Array
#define valueOfArray(array, index, type) \
        (*(pointerOfArray(array, index, type))) \


和上面参数一样,只是返回的是数组元素,而不是指向数组元素的指针。记住,数组元素可以是任何类型包括指针类型。如果是指针类型,pointerOfArray 返回的就是指向指针的指针,valueOfArray 返回的就是指针。


最后在给出一个宏:

// the type is the array element type
#define Array(name) Array \

这个宏啥也没做,但意义非同寻常,这里type可以表示了数组元素的类型,尤其是出现在API中,可以明确数组的意义。

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
c语言是一种面向过程的编程语言,不像某些面向对象的语言那样内置了的概念,但我们可以通过一些技巧来实现搜索代码。 一种常见的方法是使用void指针作为参数,这样可以接收任意类的数据。我们可以将待搜索的元素转换为void指针,并通过回调函数比较元素是否满足搜索条件。以下是一个简单的示例: ```c #include <stdio.h> typedef struct { int id; char name[20]; } Student; int compareInt(const void* a, const void* b) { int* pa = (int*)a; int* pb = (int*)b; return *pa - *pb; } int compareString(const void* a, const void* b) { char** pa = (char**)a; char** pb = (char**)b; return strcmp(*pa, *pb); } int compareStudent(const void* a, const void* b) { Student* sa = (Student*)a; Student* sb = (Student*)b; return sa->id - sb->id; } void* search(const void* array, int size, const void* target, int (*compare)(const void*, const void*)) { for(int i = 0; i < size; i++) { const void* current = (char*)array + i * size; // 根据实际类大小计算当前元素的指针 if(compare(current, target) == 0) { return (void*)current; } } return NULL; } int main() { int intArray[] = {1, 2, 3, 4, 5}; int intTarget = 3; int* intResult = (int*)search(intArray, sizeof(int), &intTarget, compareInt); printf("Int result: %d\n", *intResult); char* stringArray[] = {"apple", "banana", "cherry", "grape"}; char* stringTarget = "cherry"; char** stringResult = (char**)search(stringArray, sizeof(char*), &stringTarget, compareString); printf("String result: %s\n", *stringResult); Student studentArray[] = {{1, "Tom"}, {2, "Jerry"}, {3, "Alice"}}; Student studentTarget = {2, "Jerry"}; Student* studentResult = (Student*)search(studentArray, sizeof(Student), &studentTarget, compareStudent); printf("Student result: id=%d, name=%s\n", studentResult->id, studentResult->name); return 0; } ``` 在搜索函数中,我们通过计算偏移量来获取当前元素的指针,然后通过调用回调函数来比较元素。如果找到满足条件的元素,就返回该元素的地址,否则返回NULL。 这样我们就可以通过search函数来搜索不同类数组和元素了。当我们需要搜索其他类的数据时,只需编写相应的compare函数即可。 这只是一个简单的示例,实际上,代码的实现可以更加复杂和灵活。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值