模板化C++的等效C代码
Equivalent C code for templatized C++
这是我刚刚写的一个气泡排序函数:
template <class iter>
void bubble_sort(iter begin, iter end, int (*cmp)(void *, void *)) {
bool didSwap;
do {
didSwap = false;
for (iter temp = begin; (temp + 1) != end; ++temp)
if ((*cmp)((temp+1), (temp))) {
std::swap(*(temp+1), *temp);
didSwap = true;
}
--end;
} while (didSwap);
}
我想知道是否有可能在C中完成这样的操作。只要不与deque、vector、list等标准stl容器一起使用,比较函数就可以正常工作。但我担心的是iter begin
和iter end
。既然你不能用void做指针运算,我该怎么做呢?有可能做到这一点吗?
您可以按照qsort
函数的方式执行此操作,并传递数组的类型和大小的大小,以及指向数组开头的指针。
void bubble_sort(void* begin, size_t num, size_t size, int (*cmp)(void*,void*));
使用C
当然可以获得等效的结果。事实上,在引擎盖下,您拥有的大多数代码都将使用C语言的基本原理,例如使用指针。
至于iter begin, iter end
,它们本质上是C指针。C
中有一个名为qsort的内置例程,其函数签名与您提供的代码类似。
这是有效的:
void bubble_sort(void *array, size_t num, size_t ptr_size, int (*cmp)(void *, void *)) {
bool didSwap;
do {
didSwap = false;
for (size_t temp = 0; (temp+1) < num; ++temp)
if ((*cmp)((bool *)(array+(temp*ptr_size)), (bool *)(array+(-~temp*ptr_size)))) {
std::swap(*(bool *)(array+(temp*ptr_size)), *(bool *)(array+(-~temp*ptr_size)));
didSwap = true;
}
--num;
} while (didSwap);
}
尽管有人提到了一些关于向char *
选角,然后递增的内容,但char *
并不能很好地实现这一点,只有bool
。
这就是我主要调用函数的方式:
bubble_sort(arr, 20, sizeof(int), (int (*)(void *, void *))compare);
相关文章:
- C++我的数学有什么问题,为什么我的代码不能正确循环
- 代码在main()中运行,但在函数中出现错误
- 在VS代码中交叉编译Windows与Linux上的MinGW的SDL程序
- 编译包含字符串的代码时遇到问题
- 我在c++代码中生成了一个运行时#3异常
- 如何在linux终端中同时编译和运行c++代码
- 为cl.exe(Visual Studio代码)指定命令行C++版本
- 在Linux for Windows上编译C++代码时出错
- 我的字符计数代码计算错误.为什么
- 孤立代码块在结构中引发异常
- 在编译C++代码(具有dlib和opencv)到WASM时面临问题
- 为什么我的C#代码在调用回C++COM直到Task时会暂停.等待/线程.加入
- 处理小于cpu数据总线的数据类型.(c++转换为机器代码)
- 此代码是否违反一个定义规则
- 为什么我的代码在输出中增加了93天
- 我的简单if-else语句是如何无法访问的代码
- 使用动态分配的数组会导致代码分析发出虚假的C6386缓冲区溢出警告
- 为什么在这个代码结束循环中没有得到结束
- 在c代码之间共享数据的最佳方式
- 这个指针和内存代码打印是什么?我不知道是打印垃圾还是如何打印我需要的值