IT数码 购物 网址 头条 软件 日历 阅读 图书馆
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
图片批量下载器
↓批量下载图片,美女图库↓
图片自动播放器
↓图片自动播放器↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁
 
   -> C++知识库 -> 【C语言】C语言实现泛型编程 -> 正文阅读

[C++知识库]【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 语言也可以实现一定的泛型编程,但这样是不安全的,系统对其只有有限的检查。在编程时一定要多加细心。

  C++知识库 最新文章
【C++】友元、嵌套类、异常、RTTI、类型转换
通讯录的思路与实现(C语言)
C++PrimerPlus 第七章 函数-C++的编程模块(
Problem C: 算法9-9~9-12:平衡二叉树的基本
MSVC C++ UTF-8编程
C++进阶 多态原理
简单string类c++实现
我的年度总结
【C语言】以深厚地基筑伟岸高楼-基础篇(六
c语言常见错误合集
上一篇文章      下一篇文章      查看所有文章
加:2022-03-30 18:05:26  更:2022-03-30 18:07:45 
 
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁

360图书馆 购物 三丰科技 阅读网 日历 万年历 2025年1日历 -2025/1/10 20:49:48-

图片自动播放器
↓图片自动播放器↓
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
图片批量下载器
↓批量下载图片,美女图库↓
  网站联系: qq:121756557 email:121756557@qq.com  IT数码