您现在的位置是:网站首页> 编程资料编程资料
详解Go 将在下个版本支持新型排序算法pdqsort_Golang_
2023-05-26
467人已围观
简介 详解Go 将在下个版本支持新型排序算法pdqsort_Golang_
继Go 1.18支持泛型后,Go 将在下个版本中支持pdqsort排序算法再次引起了开发者们的热切讨论。

目前,Go仓库的最新commit中提交了pdqsort的相关功能描述:
- 在所有基准测试中,pdqsort未表现出比以前的其它算法慢;
- 在常见模式中,pdqsort通常更快(即在排序切片中快10倍)
那么pdqsort是什么呢?
pdqsort是Pattern-defeating quicksort的缩写,是一种新型的排序算法,将随机快速排序的快速平均情况与堆排序的最坏情况快速组合在一起,同时在具有特定模式的输入上实现了线性时间。 pdqsort是David Mussers introsort的扩展和改进。 在zlib许可下,所有代码都是免费的。
目前在C++和Rust中均有实现,而据不少开发者实测发现,pdqsort较常用的introsort会有较大的性能提升。
C++ 代码Demo:
#include#include #include #include #include int main() { std::array s = {5, 7, 4, 2, 8, 6, 1, 9, 0, 3}; auto print = [&s](std::string_view const rem) { for (auto a : s) { std::cout << a << ' '; } std::cout << ": " << rem << '\n'; }; std::sort(s.begin(), s.end()); print("sorted with the default operator<"); std::sort(s.begin(), s.end(), std::greater ()); print("sorted with the standard library compare function object"); struct { bool operator()(int a, int b) const { return a < b; } } customLess; std::sort(s.begin(), s.end(), customLess); print("sorted with a custom function object"); std::sort(s.begin(), s.end(), [](int a, int b) { return a > b; }); print("sorted with a lambda expression"); }
执行结果:
0 1 2 3 4 5 6 7 8 9 : sorted with the default operator<
9 8 7 6 5 4 3 2 1 0 : sorted with the standard library compare function object
0 1 2 3 4 5 6 7 8 9 : sorted with a custom function object
9 8 7 6 5 4 3 2 1 0 : sorted with a lambda expression
Rust 代码Demo:
extern crate pdqsort; let mut v = [-5i32, 4, 1, -3, 2]; pdqsort::sort(&mut v); assert!(v == [-5, -3, 1, 2, 4]); pdqsort::sort_by(&mut v, |a, b| b.cmp(a)); assert!(v == [4, 2, 1, -3, -5]); pdqsort::sort_by_key(&mut v, |k| k.abs()); assert!(v == [1, 2, -3, 4, -5]);
而就Go支持pdqsort算法,在HN上引起了不少的讨论,有人表示,我们研究排序算法这么久了,很惊讶我们还能想出能产生实际改进的优化方案。对此,你怎么看,快快上手体验一下吧。
参考链接:
https://github.com/golang/go/commit/72e77a7f41bbf45d466119444307fd3ae996e257
https://news.ycombinator.com/item?id=31106157
https://en.cppreference.com/w/cpp/algorithm/sort
到此这篇关于Go 将在下个版本支持新型排序算法pdqsort的文章就介绍到这了,更多相关Go 排序算法pdqsort内容请搜索以前的文章或继续浏览下面的相关文章希望大家以后多多支持!
相关内容
- k8s在go语言中的使用及client 初始化简介_Golang_
- go语言实现屏幕截图的示例代码_Golang_
- go mod的使用方法小结_Golang_
- 一文搞懂Go语言中条件语句的使用_Golang_
- 一文带你掌握Go语言运算符的使用_Golang_
- Go语言中循环语句使用的示例详解_Golang_
- 关于Golang获取当前项目绝对路径的问题_Golang_
- golang常用加密解密算法总结(AES、DES、RSA、Sha1、MD5)_Golang_
- 关于go-micro与其它gRPC框架之间的通信问题及解决方法_Golang_
- go程序部署到linux上运行的实现方法_Golang_
