【C语言】C语言实现泛型编程

泛型编程让你编写完全一般化并可重复使用的算法,其效率与针对某特定数据类型而设计的算法相同。
这里提供一种方法,通过空指针类型void*

现交换两个元素内容的函数 swap

#include <stdio.h>


/** \brief   交换arg1与arg2的值使用空指针类型来实现泛型,
 *
 * \param   arg1 -- 空指针类型,指向需要交换的数据类型
 * \param   arg2 -- 空指针类型,指向需要交换的数据类型
 * \param   type -- 需要交换的2个数据类型的字节大小,用sizeof求数据类型的字节大小
 * \return    无
 *
 */
void swap(void *arg1, void *arg2, unsigned type)
{
    char temp = 0;
    char *p1 = (char*)arg1;
    char *p2 = (char*)arg2;

    while(type--)
    {
        temp = *p1;
        *p1 = *p2;
        *p2 = temp;
        p1++;
        p2++;
    }
}


int main()
{
    int arg1 = 0x11223344;
    int arg2 = 0x55667788;

    printf("arg1 = %X   arg2 = %X\n", arg1, arg2);
    swap(&arg1, &arg2, sizeof(arg1));
    printf("arg1 = %X   arg2 = %X\n", arg1, arg2);
}

/*
输出结果
arg1 = 11223344   arg2 = 55667788
arg1 = 55667788   arg2 = 11223344
*/

在数组中查询元素,找到则返回它的索引,没找到返回-1

#include <stdio.h>

/** \brief  比较内存地址mem1与mem2上的数据
 *
 * \param   mem1 -- 空指针类型,内存地址1
 * \param   mem2 -- 内存地址2
 * \param   type -- 数据类型占用的字节大小
 * \return  地址上的数据一样则返回0,不一样则返回-1
 *
 */
int lmemcmp(void *mem1, void *mem2, unsigned type)
{
    char *p1 = 0;
    char *p2 = 0;

    p1 = (char*)mem1;
    p2 = (char*)mem2;
    while(type--)
    {
        if(*p1 != *p2)
        {
            return -1;
        }
        p1++;
        p2++;
    }
    return 0;
}


/** \brief  此函数在数组 buff 中查找 key元素,找到后返回它的索引,找不到返回 -1。
 *
 * \param   key -- 空指针类型,指向需要查找的元素
 * \param   buff -- 空指针类型,指向数组buff
 * \param   type -- 数组buff的元素类型占用的字节大小
 * \param   count -- 数组buff的元素个数
 * \return  找到后返回它的索引,找不到返回 -1。
 *
 */
int lsearch(void *key, void *buff, unsigned type, unsigned count)
{
    void *p = NULL;

    for(unsigned i = 0; i < count; i++)
    {
        p = buff + i * type;
        if(lmemcmp(key, p, type) == 0)
            return i;
    }
    return -1;
}


int main()
{
    int buff[] = {1,2,3,4,5,6,7,8};
    int i = 8;
    printf("%d\n", lsearch(&i, buff, sizeof(*buff), sizeof(buff) / sizeof(*buff)));
}

C 语言也可以实现一定的泛型编程,但这样是不安全的,系统对其只有有限的检查。在编程时一定要多加细心。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值