CN113419717A - 一种java集合快速排序方法和设备 - Google Patents

一种java集合快速排序方法和设备 Download PDF

Info

Publication number
CN113419717A
CN113419717A CN202110703483.1A CN202110703483A CN113419717A CN 113419717 A CN113419717 A CN 113419717A CN 202110703483 A CN202110703483 A CN 202110703483A CN 113419717 A CN113419717 A CN 113419717A
Authority
CN
China
Prior art keywords
sorting
java
sorted
data set
preset
Prior art date
Legal status (The legal status is an assumption and is not a legal conclusion. Google has not performed a legal analysis and makes no representation as to the accuracy of the status listed.)
Pending
Application number
CN202110703483.1A
Other languages
English (en)
Inventor
张康
Current Assignee (The listed assignees may be inaccurate. Google has not performed a legal analysis and makes no representation or warranty as to the accuracy of the list.)
Guangdong Huanwang Technology Co Ltd
Original Assignee
Guangdong Huanwang Technology Co Ltd
Priority date (The priority date is an assumption and is not a legal conclusion. Google has not performed a legal analysis and makes no representation as to the accuracy of the date listed.)
Filing date
Publication date
Application filed by Guangdong Huanwang Technology Co Ltd filed Critical Guangdong Huanwang Technology Co Ltd
Priority to CN202110703483.1A priority Critical patent/CN113419717A/zh
Publication of CN113419717A publication Critical patent/CN113419717A/zh
Pending legal-status Critical Current

Links

Images

Classifications

    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F8/00Arrangements for software engineering
    • G06F8/30Creation or generation of source code
    • G06F8/31Programming languages or programming paradigms
    • G06F8/315Object-oriented languages
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F9/00Arrangements for program control, e.g. control units
    • G06F9/06Arrangements for program control, e.g. control units using stored programs, i.e. using an internal store of processing equipment to receive or retain programs
    • G06F9/44Arrangements for executing specific programs
    • G06F9/448Execution paradigms, e.g. implementations of programming paradigms
    • G06F9/4488Object-oriented

Landscapes

  • Engineering & Computer Science (AREA)
  • Software Systems (AREA)
  • Theoretical Computer Science (AREA)
  • General Engineering & Computer Science (AREA)
  • Physics & Mathematics (AREA)
  • General Physics & Mathematics (AREA)
  • Computing Systems (AREA)
  • Stored Programmes (AREA)

Abstract

本发明涉及一种java集合快速排序方法和设备,包括:获取待排序java数据集合;构建预设排序方法,预设排序方法包括待排序java数据集合的排序方法;获取待排序java数据集合的排序参数,基于排序参数调用预设排序方法对待排序java数据集合进行排序。本发明的有益效果为:通过将java中的排序方法预先封装到预设排序方法中,在具体使用时只需调用该排序方法即可,让后调用的时候根据输入的参数在排序方法内部进行排序操作,从而直接调用本专利提供的方法,方法内部封装好了各种排序方法,节省时间,提升工作效率,同时将排序代码封装到方法内部从而降低了排序的难度。

Description

一种java集合快速排序方法和设备
技术领域
本发明属于IT技术领域,具体涉及一种java集合快速排序方法和设备。
背景技术
目前在项目开发过程中一般接口都是需要进行数据的排序后才能接口返回的,这样接口调用方在调用接口的时候就可以直观的看到数据的情况,如根据时间进行排序、根据数据值进行排序等。目前通用的做法是通过写代码的方法来完成不同集合之间的数据排序问题,例如List<Double>类型进行排序,泛型为Double类型的时候会让compareTo()方法不是那么的准确,那么一般常用的做法是:TreeSet<Double>set=new TreeSet(list),使用TreeSet进行排序。当List<int>或者List<String>的时候可以使用compareTo方法进行前后比较来排序。而上述方法在具体实现时都需要去写代码并且进行类型转换才能够得到结果,操作起来非常的麻烦效率也非常低。
发明内容
为了解决现有技术存在的操作不便、效率低的问题,本发明提供了一种java集合快速排序方法和设备,其具有操作便利、排序效率高等特点。
根据本发明的具体实施方式的一种java集合快速排序方法,包括:
获取待排序java数据集合;
构建预设排序方法,所述预设排序方法包括所述待排序java数据集合的排序方法;
获取所述待排序java数据集合的排序参数,基于所述排序参数调用所述预设排序方法对所述待排序java数据集合进行排序。
进一步地,所述待排序java数据集合包括:
Set、Map和List三种java集合类型。
进一步地,所述构建预设排序方法包括:
将所述Set、Map和List三种java集合类型的集合的排序方法封装到所述预设排序方法中。
进一步地,所述预设排序方法包括order()方法。
进一步地,所述获取所述待排序java数据集合的排序参数,基于所述排序参数调用所述预设排序方法对所述待排序java数据集合进行排序包括:
获取待排序java数据集合的类型参数和排序类型参数,所述order()方法基于所述类型参数和所述排序类型参数对所述待排序java数据集合进行排序。
进一步地,所述排序类型参数包括升序和降序。
进一步地,还包括:
将排序后结果返回所述待排序java数据集合完成排序。
根据本发明具体实施方式提供的一种设备,包括:
处理器,以及与所述处理器相连接的存储器;
所述存储器用于存储计算机程序,所述计算机程序至少用于执行以上所述的java集合快速排序方法;
所述处理器用于调用并执行所述存储器中的所述计算机程序。
本发明的有益效果为:通过将java中的排序方法预先封装到预设排序方法中,在具体使用时只需调用该排序方法即可,让后调用的时候根据输入的参数在排序方法内部进行排序操作,从而直接调用本专利提供的方法,方法内部封装好了各种排序方法,节省时间,提升工作效率,同时将排序代码封装到方法内部从而降低了排序的难度。
附图说明
为了更清楚地说明本发明实施例或现有技术中的技术方案,下面将对实施例或现有技术描述中所需要使用的附图作简单地介绍,显而易见地,下面描述中的附图仅仅是本发明的一些实施例,对于本领域普通技术人员来讲,在不付出创造性劳动的前提下,还可以根据这些附图获得其他的附图。
图1是根据一示例性实施例提供的java集合快速排序方法的流程图;
图2是根据一示例性实施例提供的java集合快速排序方法的另一流程图;
图3是根据一示例性实施例提供的设备的原理图。
具体实施方式
为使本发明的目的、技术方案和优点更加清楚,下面将对本发明的技术方案进行详细的描述。显然,所描述的实施例仅仅是本发明一部分实施例,而不是全部的实施例。基于本发明中的实施例,本领域普通技术人员在没有做出创造性劳动的前提下所得到的所有其它实施方式,都属于本发明所保护的范围。
参照图1所示,本发明的实施例提供了一种java集合快速排序方法,具体包括以下步骤:
101、获取待排序java数据集合;
java数据集合是java中的集合类库可以帮助工程人员在程序设计中实现传统的数据结构。java的集合类是一个用来存放对象的容器,具有java集合只能存放对象。加入添加了一个基本数据类型,会被自动装箱后存入集合;集合存放的是多个对象的引用,对象本身是在堆内存中的;集合可以存放不同类型,不限数量的数据类型等特点。
102、构建预设排序方法,预设排序方法包括待排序java数据集合的排序方法;
在java中的常用的排序方法有冒泡排序、选择排序、插入排序和快速排序,可将这些排序的程序封装在预先设置的排序方法中。
103、获取待排序java数据集合的排序参数,基于排序参数调用预设排序方法对待排序java数据集合进行排序。
在具体使用时,通过将待排序的java数据集合的参数输入预先设置的排序方法中,通过调用的方式进行排序,从而节省时间,提升工作效率,直接调用本发明提供的方法,方法内部封装好了各种排序方法,通过将排序代码封装到方法内部从而降低了排序的难度。
作为上述实施例可行的实现方式待排序java数据集合包括:
Set、Map和List三种java集合类型。
构建预设排序方法包括:
将所述Set、Map和List三种java集合类型的集合的排序方法封装到预设排序方法中。
预设排序方法包括order()方法。
获取待排序java数据集合的排序参数,基于排序参数调用预设排序方法对待排序java数据集合进行排序包括:
获取待排序java数据集合的类型参数和排序类型参数,order()方法基于类型参数和排序类型参数对待排序java数据集合进行排序。
排序类型参数包括升序和降序。
例如,输入参数Map map=Util.order(map,desc),就是将map集合的数据进行降序,然后在返回对应的map集合。
又如Util.order(list,asc)就是将list集合的数据进行降序。
其中list是一个数据集类型,跟数组差不多,但是list可以存储对象等,list<double>是泛型,其中的double代表你声明的list对象只能存储double类型的数据,如果类型不double类型的,系统将编译出错
比如说,在一个数据库中满足条件的数据有很多行,可以用LIST来存储这些数据对象,然后跟数组一样遍历出这些对象,然后通过对象来调用数据。
order()方法的封装具体可包括:
Figure BDA0003130323900000041
Figure BDA0003130323900000051
*对数据集合进行排序
用户可根据实际的需要根据排序数据结合类型的不同,从而调用不同的排序方式进行排序即可。
参照图2所示,在本发明的一些具体实施例中还包括:
201、获取待排序java数据集合;
202、构建预设排序方法,预设排序方法包括待排序java数据集合的排序方法;
203、获取待排序java数据集合的排序参数,基于排序参数调用预设排序方法对待排序java数据集合进行排序。
204、将排序后结果返回待排序java数据集合完成排序。
基于同样的设计思路参照图3所示,本发明的实施例还提供了一种设备,包括:
处理器,以及与处理器相连接的存储器;
存储器用于存储计算机程序,计算机程序至少用于执行如上实施例所述的java集合快速排序方法;
处理器用于调用并执行存储器中的所述计算机程序。
本发明上述实施例所提供的java集合快速排序方法和设备,可直接调用本专利提供的方法,方法内部封装好了各种排序方法,节省时间,提升工作效率,同时将排序代码封装到方法内部从而降低了排序的难度。
本技术领域的普通技术人员可以理解实现上述实施例方法携带的全部或部分步骤是可以通过程序来指令相关的硬件完成,所述的程序可以存储于一种计算机可读存储介质中,该程序在执行时,包括方法实施例的步骤之一或其组合。
此外,在本发明各个实施例中的各功能单元可以集成在一个处理模块中,也可以是各个单元单独物理存在,也可以两个或两个以上单元集成在一个模块中。上述集成的模块既可以采用硬件的形式实现,也可以采用软件功能模块的形式实现。所述集成的模块如果以软件功能模块的形式实现并作为独立的产品销售或使用时,也可以存储在一个计算机可读取存储介质中。
上述提到的存储介质可以是只读存储器,磁盘或光盘等。
在本说明书的描述中,参考术语“一个实施例”、“一些实施例”、“示例”、“具体示例”、或“一些示例”等的描述意指结合该实施例或示例描述的具体特征、结构、材料或者特点包含于本发明的至少一个实施例或示例中。在本说明书中,对上述术语的示意性表述不一定指的是相同的实施例或示例。而且,描述的具体特征、结构、材料或者特点可以在任何的一个或多个实施例或示例中以合适的方式结合。
上文的描述包括一个或多个实施例的举例。当然,为了描述上述实施例而描述部件或方法的所有可能的结合是不可能的,但是本领域普通技术人员应该认识到,各个实施例可以做进一步的组合和排列。因此,本文中描述的实施例旨在涵盖落入所附权利要求书的保护范围内的所有这样的改变、修改和变型。此外,就说明书或权利要求书中使用的术语“包含”,该词的涵盖方式类似于术语“包括”,就如同“包括”在权利要求中用作衔接词所解释的那样。此外,使用在权利要求书的说明书中的任何一个术语“或者”是要表示“非排它性的或者”。
以上所述,仅为本发明的具体实施方式,但本发明的保护范围并不局限于此,任何熟悉本技术领域的技术人员在本发明揭露的技术范围内,可轻易想到变化或替换,都应涵盖在本发明的保护范围之内。因此,本发明的保护范围应以所述权利要求的保护范围为准。

Claims (8)

1.一种java集合快速排序方法,其特征在于,包括:
获取待排序java数据集合;
构建预设排序方法,所述预设排序方法包括所述待排序java数据集合的排序方法;
获取所述待排序java数据集合的排序参数,基于所述排序参数调用所述预设排序方法对所述待排序java数据集合进行排序。
2.根据权利要求1所述的java集合快速排序方法,其特征在于,所述待排序java数据集合包括:
Set、Map和List三种java集合类型。
3.根据权利要求2所述的java集合快速排序方法,其特征在于,所述构建预设排序方法包括:
将所述Set、Map和List三种java集合类型的集合的排序方法封装到所述预设排序方法中。
4.根据权利要求3所述的java集合快速排序方法,其特征在于,所述预设排序方法包括order()方法。
5.根据权利要求4所述的java集合快速排序方法,其特征在于,所述获取所述待排序java数据集合的排序参数,基于所述排序参数调用所述预设排序方法对所述待排序java数据集合进行排序包括:
获取待排序java数据集合的类型参数和排序类型参数,所述order()方法基于所述类型参数和所述排序类型参数对所述待排序java数据集合进行排序。
6.根据权利要求5所述的java集合快速排序方法,其特征在于,所述排序类型参数包括升序和降序。
7.根据权利要求1至6任一项所述的java集合快速排序方法,其特征在于,还包括:
将排序后结果返回所述待排序java数据集合完成排序。
8.一种设备,其特征在于,包括:
处理器,以及与所述处理器相连接的存储器;
所述存储器用于存储计算机程序,所述计算机程序至少用于执行权利要求1-7任一项所述的java集合快速排序方法;
所述处理器用于调用并执行所述存储器中的所述计算机程序。
CN202110703483.1A 2021-06-24 2021-06-24 一种java集合快速排序方法和设备 Pending CN113419717A (zh)

Priority Applications (1)

Application Number Priority Date Filing Date Title
CN202110703483.1A CN113419717A (zh) 2021-06-24 2021-06-24 一种java集合快速排序方法和设备

Applications Claiming Priority (1)

Application Number Priority Date Filing Date Title
CN202110703483.1A CN113419717A (zh) 2021-06-24 2021-06-24 一种java集合快速排序方法和设备

Publications (1)

Publication Number Publication Date
CN113419717A true CN113419717A (zh) 2021-09-21

Family

ID=77716537

Family Applications (1)

Application Number Title Priority Date Filing Date
CN202110703483.1A Pending CN113419717A (zh) 2021-06-24 2021-06-24 一种java集合快速排序方法和设备

Country Status (1)

Country Link
CN (1) CN113419717A (zh)

Citations (2)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US20100162211A1 (en) * 2008-12-19 2010-06-24 Microsoft Corporation Providing access to a dataset in a type-safe manner
CN109445795A (zh) * 2018-09-14 2019-03-08 厦门天锐科技股份有限公司 多次异步调用同一数据请求时回调函数中的数据处理方法

Patent Citations (2)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US20100162211A1 (en) * 2008-12-19 2010-06-24 Microsoft Corporation Providing access to a dataset in a type-safe manner
CN109445795A (zh) * 2018-09-14 2019-03-08 厦门天锐科技股份有限公司 多次异步调用同一数据请求时回调函数中的数据处理方法

Non-Patent Citations (1)

* Cited by examiner, † Cited by third party
Title
令和时代的柯南: "java 封装的排序方法_Java对象集合万能排序封装", pages 1 - 5, Retrieved from the Internet <URL:https://blog.csdn.net/weixin_29000119/article/details/114725917> *

Similar Documents

Publication Publication Date Title
US5367687A (en) Method and apparatus for optimizing cost-based heuristic instruction scheduling
CN1150451C (zh) 零开销异常处理
US20110138236A1 (en) Apparatus and method for providing visual interface for information of error generated in multithread testing
CN103718159B (zh) 图像处理软件开发方法、图像处理软件开发装置
CN105808227A (zh) 一种美术资源文件检测方法和装置
US6694343B2 (en) Method for solving a large sparse triangular system of linear equations
CN106354536A (zh) 在Windows系统中加载Linux系统ELF文件的方法及装置
CN112861267B (zh) 船舶mbd信息重用方法、系统、介质及终端
CN113419717A (zh) 一种java集合快速排序方法和设备
JP4563558B2 (ja) データのコンパイル方法、および、コンパイル方法を記憶した記憶媒体
CN112860412A (zh) 业务数据处理方法、装置、电子设备及存储介质
CN110659393B (zh) 一种xml代码生成方法和系统
US7882114B2 (en) Data processing method and data processing program
CN110287182A (zh) 一种大数据的数据对比方法、装置、设备及终端
JP2003528390A (ja) インタプリタによりコンピュータプログラムを実行する方法、コンピュータシステムならびにコンピュータプログラムプロダクト
CN113516506B (zh) 一种数据处理方法、装置及电子设备
US7895561B2 (en) System and method for text based placement engine for custom circuit design
CN111046472B (zh) 模型构件信息的显示方法、装置、计算机设备和存储介质
CN114691496A (zh) 单元测试方法、装置、计算设备及介质
CN114385864A (zh) 一种图搜索方法、装置、设备及存储介质
CN105677968A (zh) 可编程逻辑器件电路图绘制方法及装置
CN110928253A (zh) 自动制造系统的动态加权启发式调度方法
CN112506944B (zh) 业务系统间的数据标准转换取数方法、装置、设备和介质
CN116340270B (zh) 并发遍历枚举方法、装置、设备及存储介质
CN117610505B (zh) 一种基于标准模型的数据处理方法及装置

Legal Events

Date Code Title Description
PB01 Publication
PB01 Publication
SE01 Entry into force of request for substantive examination
SE01 Entry into force of request for substantive examination