Qsort的内部实施
发布时间:2020-12-16 10:40:55 所属栏目:百科 来源:网络整理
导读:qsort声明为 void qsort (void* base,size_t num,size_t size,int (*compar)(const void*,const void*)); 我想知道qsort如何实现反射属性.我的意思是它如何调用我们传递的名字的函数? 解决方法 qsort接收一个指向函数接收两个指针并返回int的指针,就是这样.
qsort声明为
void qsort (void* base,size_t num,size_t size,int (*compar)(const void*,const void*)); 我想知道qsort如何实现反射属性.我的意思是它如何调用我们传递的名字的函数? 解决方法
qsort接收一个指向函数接收两个指针并返回int的指针,就是这样.该指针称为compar.所有qsort需要做的就是调用这个函数是这样的:
(*compar)(base+i,base+j); 其中i和j是基数的偏移量.这真的很简单.您可以在K& R第二版,第5.11节,第120页中看到可能的实现: void qsort(void *v[],int left,int right,int (*comp)(void *,void *)) { int i,last; void swap(void *v[],int,int); if (left >= right) return; swap(v,left,(left + right)/2); last = left; for (i = left+1; i <= right; i++) if ((*comp)(v[i],v[left]) < 0) /* Here's the function call */ swap(v,++last,i); swap(v,last); qsort(v,last-1,comp); qsort(v,last+1,right,comp); } (编辑:李大同) 【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容! |
相关内容
- 做数据格式转换的DatatypeConverter类的例子程序
- vb中窗体的常用属性及其功能
- c# – 自SQL 2008升级以来,SqlDataReader.HasRows返回false
- oracle 12c CVU检查集群准备情况 runcluvfy.sh
- swift – 枚举的字符串插值产生“unknown()”字符串
- c# – 探索为每个使用它的ViewModel / Class提供DbContext的
- 详解xml文件描述,读取步骤以及将对象存放到xml文档中,并按
- ruby-on-rails-3 – 如何在Ruby on Rails 3中缓存查询
- c – lambda表达式的变体模板
- c# – 为什么编译器不能推断出这个select调用的类型?