发明内容
本说明书一个或多个实施例的目的是提供一种排名方法及装置,用以实现用户排名的准实时性及准确性。
为解决上述技术问题,本说明书一个或多个实施例是这样实现的:
一方面,本说明书一个或多个实施例提供一种排名方法,包括:
获取由各分区分别发送的、所述各分区在当前单位时长内被分配的待排名用户的数量信息;
确定所述各分区发送所述数量信息的先后顺序;及,根据当前的用户排名记录,确定所述当前单位时长内所述待排名用户的第一初始名次;
根据所述数量信息、所述先后顺序及所述第一初始名次,确定所述各分区分别对应的排名区间;其中,所述各分区分别对应的排名区间内的名次数量与对应分区内的待排名用户的数量相同;
为所述各分区分配对应的排名区间,以使所述各分区根据所述排名区间为所述待排名用户进行排名。
在一个实施例中,所述根据当前的用户排名记录,确定所述当前单位时长内所述待排名用户的第一初始名次,包括:
从所述当前的用户排名记录中,获取记录的在所述当前单位时长之前参与排名的所有用户的第一总名次数量;
将所述第一总名次数量的值加1,得到所述当前单位时长内所述待排名用户的第一初始名次。
在一个实施例中,所述根据所述数量信息、所述先后顺序及所述第一初始名次,确定所述各分区分别对应的排名区间,包括:
按照所述先后顺序,确定所述第一分区对应的排名区间为以所述第一初始名次开始、且名次数量与所述第一分区内的待排名用户的数量相同的区间;
将所述第一分区对应的排名区间的终止名次加1,得到第二区间对应的第二初始名次;及,确定所述第二区间对应的排名区间为以所述第二初始名次开始、且名次数量与所述第二分区内的待排名用户的数量相同的区间;
其中,所述第一分区为所述各分区中最先发送所述待排名用户的数量信息的分区,所述第二分区为位于所述第一分区之后、且与所述第一分区相邻的分区。
在一个实施例中,在获取由各分区分别发送的、所述各分区在当前单位时长内被分配的待排名用户的数量信息之后,还包括:
根据排名配置信息,判断是否立即对所述当前单位时长内被分配的所述待排名用户进行排名;
若是,则立即对所述当前单位时长内被分配的所述待排名用户进行排名;
若否,则将获取到的所述当前单位时长内被分配的待排名用户的数量信息存储在缓存区域中。
在一个实施例中,所述排名配置信息包括排名延迟时长;
相应的,所述根据排名配置信息,判断是否立即对所述当前单位时长内被分配的所述待排名用户进行排名,包括:
若所述排名延迟时长为零,则确定立即对所述当前单位时长内被分配的所述待排名用户进行排名;
若所述排名延迟时长不为零,则确定延迟对所述当前单位时长内被分配的所述待排名用户的排名操作。
在一个实施例中,在将获取到的所述待排名用户的数量信息存储在缓存区域中之后,还包括:
当所述排名延迟时长达到时,从所述缓存区域中获取所述当前单位时长内被分配的待排名用户的数量信息;及,对所述当前单位时长内被分配的所述待排名用户进行排名。
在一个实施例中,在将所述各分区分别对应的排名区间分配至所述各分区之后,还包括:
将所述第一总名次数量与所述各分区分别对应的排名区间内的名次数量相加,得到第二总名次数量;
根据所述第二总名次数量,更新所述当前的用户排名记录。
另一方面,本说明书一个或多个实施例提供一种排名方法,包括:
记录当前单位时长内被分配的待排名用户的参与排名信息;其中,所述参与排名信息包括所述待排名用户的数量信息及各所述待排名用户的参与排名顺序;
将所述待排名用户的数量信息发送至服务器,以使所述服务器根据所述数量信息为各分区分配对应的排名区间;其中,所述排名区间内的名次数量与所述分区内的所述待排名用户的数量相同;
根据所述排名区间及各所述待排名用户的参与排名顺序,为各所述待排名用户进行排名。
在一个实施例中,所述方法还包括:
在所述当前单位时长内,记录参与排名的第一用户的用户信息;及,确定所述第一用户为所述当前单位时长内的所述待排名用户;
其中,所述用户信息包括用户标识、用户参与排名的时间信息、所在分区的分区标识中的至少一项。
在一个实施例中,所述用户信息还包括用户排名信息;
相应的,在为各所述待排名用户进行排名之后,所述方法还包括:
根据排名结果,更新各所述待排名用户的所述用户排名信息。
再一方面,本说明书一个或多个实施例提供一种排名装置,包括:
获取模块,用于获取由各分区分别发送的、所述各分区在当前单位时长内被分配的待排名用户的数量信息;
第一确定模块,用于确定所述各分区发送所述数量信息的先后顺序;及,根据当前的用户排名记录,确定所述当前单位时长内所述待排名用户的第一初始名次;
第二确定模块,用于根据所述数量信息、所述先后顺序及所述第一初始名次,确定所述各分区分别对应的排名区间;其中,所述各分区分别对应的排名区间内的名次数量与对应分区内的待排名用户的数量相同;
分配模块,用于为所述各分区分配对应的排名区间,以使所述各分区根据所述排名区间为所述待排名用户进行排名。
在一个实施例中,所述第一确定模块包括:
获取单元,用于从所述当前的用户排名记录中,获取记录的在所述当前单位时长之前参与排名的所有用户的第一总名次数量;
第一增值单元,用于将所述第一总名次数量的值加1,得到所述当前单位时长内所述待排名用户的第一初始名次。
在一个实施例中,所述第二确定模块包括:
第一确定单元,用于按照所述先后顺序,确定所述第一分区对应的排名区间为以所述第一初始名次开始、且名次数量与所述第一分区内的待排名用户的数量相同的区间;
第二增值单元,用于将所述第一分区对应的排名区间的终止名次加1,得到第二区间对应的第二初始名次;及,确定所述第二区间对应的排名区间为以所述第二初始名次开始、且名次数量与所述第二分区内的待排名用户的数量相同的区间;
其中,所述第一分区为所述各分区中最先发送所述待排名用户的数量信息的分区,所述第二分区为位于所述第一分区之后、且与所述第一分区相邻的分区。
再一方面,本说明书一个或多个实施例提供一种排名装置,包括:
记录模块,用于记录当前单位时长内被分配的待排名用户的参与排名信息;其中,所述参与排名信息包括所述待排名用户的数量信息及各所述待排名用户的参与排名顺序;
发送模块,用于将所述待排名用户的数量信息发送至服务器,以使所述服务器根据所述数量信息为各分区分配对应的排名区间;其中,所述排名区间内的名次数量与所述分区内的所述待排名用户的数量相同;
排名模块,用于根据所述排名区间及各所述待排名用户的参与排名顺序,为各所述待排名用户进行排名。
在一个实施例中,所述装置还包括:
记录及确定模块,用于在所述当前单位时长内,记录参与排名的第一用户的用户信息;及,确定所述第一用户为所述当前单位时长内的所述待排名用户;
其中,所述用户信息包括用户标识、用户参与排名的时间信息、所在分区的分区标识中的至少一项。
在一个实施例中,所述用户信息还包括用户排名信息;
相应的,所述装置还包括:
更新模块,用于在为各所述待排名用户进行排名之后,根据排名结果更新各所述待排名用户的所述用户排名信息。
再一方面,本说明书一个或多个实施例提供一种排名设备,包括:
处理器;以及
被安排成存储计算机可执行指令的存储器,所述可执行指令在被执行时使所述处理器:
获取由各分区分别发送的、所述各分区在当前单位时长内被分配的待排名用户的数量信息;
确定所述各分区发送所述数量信息的先后顺序;及,根据当前的用户排名记录,确定所述当前单位时长内所述待排名用户的第一初始名次;
根据所述数量信息、所述先后顺序及所述第一初始名次,确定所述各分区分别对应的排名区间;其中,所述各分区分别对应的排名区间内的名次数量与对应分区内的待排名用户的数量相同;
为所述各分区分配对应的排名区间,以使所述各分区根据所述排名区间为所述待排名用户进行排名。
再一方面,本说明书一个或多个实施例提供一种排名设备,包括:
处理器;以及
被安排成存储计算机可执行指令的存储器,所述可执行指令在被执行时使所述处理器:
记录当前单位时长内被分配的待排名用户的参与排名信息;其中,所述参与排名信息包括所述待排名用户的数量信息及各所述待排名用户的参与排名顺序;
将所述待排名用户的数量信息发送至服务器,以使所述服务器根据所述数量信息为各分区分配对应的排名区间;其中,所述排名区间内的名次数量与所述分区内的所述待排名用户的数量相同;
根据所述排名区间及各所述待排名用户的参与排名顺序,为各所述待排名用户进行排名。
再一方面,本申请实施例提供一种存储介质,用于存储计算机可执行指令,所述可执行指令在被执行时实现以下流程:
获取由各分区分别发送的、所述各分区在当前单位时长内被分配的待排名用户的数量信息;
确定所述各分区发送所述数量信息的先后顺序;及,根据当前的用户排名记录,确定所述当前单位时长内所述待排名用户的第一初始名次;
根据所述数量信息、所述先后顺序及所述第一初始名次,确定所述各分区分别对应的排名区间;其中,所述各分区分别对应的排名区间内的名次数量与对应分区内的待排名用户的数量相同;
为所述各分区分配对应的排名区间,以使所述各分区根据所述排名区间为所述待排名用户进行排名。
再一方面,本申请实施例提供一种存储介质,用于存储计算机可执行指令,所述可执行指令在被执行时实现以下流程:
记录当前单位时长内被分配的待排名用户的参与排名信息;其中,所述参与排名信息包括所述待排名用户的数量信息及各所述待排名用户的参与排名顺序;
将所述待排名用户的数量信息发送至服务器,以使所述服务器根据所述数量信息为各分区分配对应的排名区间;其中,所述排名区间内的名次数量与所述分区内的所述待排名用户的数量相同;
根据所述排名区间及各所述待排名用户的参与排名顺序,为各所述待排名用户进行排名。
采用本说明书一个或多个实施例的技术方案,通过获取由各分区分别发送的、各分区在当前单位时长内被分配的待排名用户的数量信息,确定各分区发送数量的先后顺序,并根据当前的用户排名记录,确定当前单位时长内待排名用户的第一初始名次,进而根据各分区内待排名用户的数量信息、先后顺序及第一初始名次,确定各分区分别对应的排名区间,并为各分区分配对应的排名区间,以使各分区根据排名区间为待排名用户进行排名。可见,该技术方案对用户进行排名时,并非是按照所有用户的参与时间先后顺序进行排名,而是将所有待排名用户分配至各个区间,并未各区间分配各自对应的排名区间,进而由各区间对各自对应的待排名用户进行排名。显然,这种方式将排名从百万级、甚至亿级用户维度降低到分区维度,从而使单个分区秒级一千的量即可满足全局秒级百万的量级,大大提高用户排名的效率;并且通过服务器向各分区分配对应的排名区间,使得各分区为待排名用户进行排名时能够保证排名全局的唯一性,实现了用户排名的准实时性及准确性。
具体实施方式
本说明书一个或多个实施例提供一种排名方法及装置,用以实现用户排名的准实时性及准确性。
为了使本技术领域的人员更好地理解本说明书一个或多个实施例中的技术方案,下面将结合本说明书一个或多个实施例中的附图,对本说明书一个或多个实施例中的技术方案进行清楚、完整地描述,显然,所描述的实施例仅仅是本说明书一部分实施例,而不是全部的实施例。基于本说明书一个或多个实施例,本领域普通技术人员在没有作出创造性劳动前提下所获得的所有其他实施例,都应当属于本说明书一个或多个实施例保护的范围。
图1是根据本说明书一实施例的一种排名方法的示意性流程图,如图1所示,该方法应用于服务器,包括:
S102,获取由各分区分别发送的、各分区在当前单位时长内被分配的待排名用户的数量信息。
本实施例中,针对当前单位时长内的每个参与排名的用户,均被服务器分配至各分区内作为该分区内的待排名用户。服务器为各分区分配待排名用户的方式可包括多种。例如,随机向各分区分配待排名用户;或者,按照各分区的排列顺序依次向各分区分配待排名用户;再或者,按照各分区内待排名用户的数量平均向各分区分配待排名用户;等等。
单位时长可预先根据需要进行设定。例如设定单位时长为1秒钟,则对当前1秒钟内参与排名的待排名用户进行排名,然后再对下一秒内参与排名的待排名用户进行排名,且下一秒内的待排名用户的初始名次与当前1秒内的待排名用户的终止名次相邻,这将在后续进行详细说明。
S104,确定各分区发送待排名用户的数量信息的先后顺序;及,根据当前的用户排名记录,确定当前单位时长内待排名用户的第一初始名次。
其中,用户排名记录用于记录当前已排名用户的排名信息,包括已排名用户的名次。第一初始名次指为待排名用户进行排名的第一位名次,例如,第一初始名次为1000,那么为待排名用户进行排名时,应从名次1000开始排名,即排名最前的用户的名次为1000。
S106,根据各分区内待排名用户的数量信息、各分区发送待排名用户的数量信息的先后顺序及第一初始名次,确定各分区分别对应的排名区间。
其中,各分区分别对应的排名区间内的名次数量与对应分区内的待排名用户的数量相同。各排名区间内的各相邻名次的间隔为1。例如,分区A内的待排名用户的数量为1000,则该分区A对应的排名区间内的名次数量即为1000,从而确保排名区间内的名次数量能够恰好分配给每一个待排名用户。
S108,为各分区分配对应的排名区间,以使各分区根据排名区间为待排名用户进行排名。
本实施例中,服务器分配给各分区的排名区间具有全局有序性及唯一性,因此,通过为各分区分配对应的排名区间,进而使各分区根据排名区间为待排名用户进行排名,使得各待排名用户最终获得的名次同样具有全局有序性及唯一性。
本实施例中,服务器将当前单位时长内参与排名的用户分配至各分区时,由各分区记录各待排名用户的参与排名时间(即被分配至分区内的时间),当各分区根据排名区间为各待排名用户进行排名时,可根据所记录的各待排名用户的参与排名时间的先后顺序进行排名。
采用本说明书一个或多个实施例的技术方案,通过获取由各分区分别发送的、各分区在当前单位时长内被分配的待排名用户的数量信息,确定各分区发送数量的先后顺序,并根据当前的用户排名记录,确定当前单位时长内待排名用户的第一初始排名,进而根据各分区内待排名用户的数量信息、先后顺序及第一初始排名,确定各分区分别对应的排名区间,并为各分区分配对应的排名区间,以使各分区根据排名区间为待排名用户进行排名。可见,该技术方案对用户进行排名时,并非是按照所有用户的参与时间先后顺序进行排名,而是将所有待排名用户分配至各个区间,并未各区间分配各自对应的排名区间,进而由各区间对各自对应的待排名用户进行排名。显然,这种方式将排名从百万级、甚至亿级用户维度降低到分区维度,从而使单个分区秒级一千的量即可满足全局秒级百万的量级,大大提高用户排名的效率;并且通过服务器向各分区分配对应的排名区间,使得各分区为待排名用户进行排名时能够保证排名全局的唯一性,实现了用户排名的准实时性及准确性。
以下详细说明上述实施例提供的排名方法。
首先,获取由各分区分别发送的、各分区在当前单位时长内被分配的待排名用户的数量信息。
图2示出了本说明书一实施例的一种排名系统的示意性框图。如图2所示,各分区均包括各自的record表(即用户流水表)和count表(即计数表)。其中,record表用于记录各待排名用户的用户标识(如用户ID)、排名标识、参与排名时间、名次(初始状态为空)、分区标识等信息。count表用于记录各待排名用户的用户标识、排名标识、参与排名时间、所属分区的初始名次、终止名次、待排名用户的数量等信息。
其中,服务器每向分区分配一个待排名用户,分区内的record表中就会增加一条记录,用于记录被分配的待排名用户的相关信息,且count表内所记录的待排名用户的数量就会累计加1。
count表中所记录的待排名用户的数量指的是当前单位时长内的待排名用户的数量。在当前单位时长内的待排名用户完成排名后,count表中会重新增加一条新的记录,用于记录下一个单位时长内的待排名用户的数量,且下一个单位时长内的待排名用户的数量值会根据所属分区在下一个单位时长内被分配的用户数量进行更新。
通过record表和count表中所记录的信息,各分区可获知各待排名用户的参与排名时间,以便后续为各待排名用户进行排名。并且,各分区还可获知当前单位时长内的待排名用户的数量信息,并将该数量信息上报至服务器,由服务器根据该数量信息为相应分区分配对应的排名区间。
在一个实施例中,一个分区可管理其他多个子分区(即record表和count表),也就是说,一个分区内可具有多个record表和count表。例如,假设共有1000张record表和count表,而分区仅有5个,那么每个分区内应设置200个record表和count表。当分区向服务器上报待排名用户的数量信息时,应汇总分区内的200个record表和count表所记录的待排名用户的数量信息进行上报。
在获取到由各分区分别发送的、各分区在当前单位时长内被分配的待排名用户的数量信息之后,确定各分区发送待排名用户的数量信息的先后顺序;及,根据当前的用户排名记录,确定当前单位时长内待排名用户的第一初始名次。
该步骤中,各分区发送待排名用户的数量信息时,服务器会记录各分区对待排名用户的数量信息的发送时间,并根据所记录的发送时间确定各分区发送待排名用户的数量信息的先后顺序。
在一个实施例中,服务器根据当前的用户排名记录确定当前单位时长内待排名用户的第一初始排名时,可首先从当前的用户排名记录中,获取记录的在当前单位时长之前参与排名的所有用户的第一总名次数量,进而将第一总名次数量的值加1,得到当前单位时长内待排名用户的第一初始名次。
本实施例中,用户排名记录中用于记录当前单位时长之前参与排名的所有用户的总名次数量,即已排名用户的总名次数量。例如,在当前单位时长之前,参与排名的所有用户的总名次为从1到1000,则说明已排名用户的总名次数量为1000,此时,当前单位时长内待排名用户的第一初始名次即为1000+1,即1001。
在确定当前单位时长内待排名用户的第一初始名次之后,根据各分区内待排名用户的数量信息、各分区发送待排名用户的数量信息的先后顺序及当前单位时长内待排名用户的第一初始名次,确定各分区分别对应的排名区间。其中,各分区分别对应的排名区间内的名次数量与对应分区内的待排名用户的数量相同。
本实施例中,服务器分配给各分区的排名区间具有全局有序性及唯一性,因此,通过为各分区分配对应的排名区间,进而使各分区根据排名区间为待排名用户进行排名,使得各待排名用户最终获得的名次同样具有全局有序性及唯一性。
在一个实施例中,可按照如下步骤确定各分区分别对应的排名区间:
首先,按照各分区发送待排名用户的数量信息的先后顺序,确定第一分区对应的排名区间为以第一初始名次开始、且名次数量与第一分区内的待排名用户的数量相同的区间。
其次,将第一分区对应的排名区间的终止排名加1,得到第二区间对应的第二初始名次;及,确定第二区间对应的排名区间为以第二初始名次开始、且名次数量与第二分区内的待排名用户的数量相同的区间。
其中,各排名区间内的各相邻名次的间隔为1。第一分区为各分区中最先发送待排名用户的数量信息的分区,第二分区为位于第一分区之后、且与第一分区相邻的分区。
例如,假设共有分区A、分区B和分区C三个分区,并且,各分区发送待排名用户的数量信息的先后顺序如下:分区A——分区B——分区C。那么上述所说的第一分区即为分区A。由于分区A最先发送待排名用户的数量信息,因此服务器为分区A分配的排名区间内的初始名次即为第一初始名次,即根据用户排名记录所确定出的当前单位时长内待排名用户的第一初始名次。将分区A对应的排名区间的终止名次加1,即为服务器为分区B分配的排名区间内的初始名次。将分区B对应的排名区间的终止名次加1,即为服务器为分区C分配的排名区间内的初始名次。
具体的,假设分区A内的待排名用户的数量为100,分区B内的待排名用户的数量为200,分区C内的待排名用户的数量为300。根据当前的用户排名记录确定出当前单位时长内待排名用户的第一初始名次为101。那么,分区A对应的排名区间的初始名次即为101,且分区A对应的排名区间内的名次数量为100,终止名次为200。分区B对应的排名区间的初始名次为201,且分区B对应的排名区间内的名次数量为200,终止名次为400。分区C对应的排名区间的初始名次为401,且分区C对应的排名区间内的名次数量为300,终止名次为700。
可见,每个分区均对应全局唯一的排名区间,即各排名区间内的名次是唯一的、有序的、不跳号的。
在确定那个分区分别对应的排名区间之后,服务器为各分区分配对应的排名区间,以使各分区根据各自对应的排名区间为待排名用户进行排名。
在一个实施例中,在获取由各分区分别发送的、各分区在当前单位时长内的待排名用户的数量之后(即执行上述S102之后),可根据排名配置信息判断是否立即对当前单位时长内的待排名用户进行排名。若是,则立即对当前单位时长内的待排名用户进行排名;若否,则将获取到的当前单位时长内的待排名用户的数量信息存储在缓存区域中。
在一个实施例中,排名配置信息包括排名延迟时长。因此,若排名延迟时长为零,则确定立即对当前单位时长内的待排名用户进行排名;若排名延迟时长不为零,则确定延迟对当前单位时长内的待排名用户的排名操作。
在一个实施例中,在将获取到的待排名用户的数量信息存储在缓存区域中之后,可监测缓存时长是否达到排名延迟时长。当缓存时长达到排名延迟时长时,则从缓存区域中获取当前单位时长内的待排名用户的数量信息,并对获取到的当前单位时长内的待排名用户进行排名。
本实施例中,缓存区域中可存储多个单位时长内的待排名用户的数量信息,且各单位时长内的待排名用户的数量信息可对应各自的排名延迟时长。例如,单位时长为1秒,排名延迟时长为10秒。缓存区域中存储了第10秒内的待排名用户的数量信息及第15秒内的待排名用户的数量信息。当第10秒内的待排名用户的数量信息缓存10秒(即排名延迟时长)之后,从缓存区域内获取第10秒内的待排名用户的数量信息,并对获取到的第10秒内的待排名用户进行排名,此时由于第15秒内的待排名用户的数量信息的缓存时长还未达到排名延迟时长,因此暂时不获取第15秒内的待排名用户的数量信息。
在一个实施例中,将各分区分别对应的排名区间分配至各分区之后,可将用户排名记录中记录的在当前单位时长之前参与排名的所有用户的第一总名次数量与各分区分别对应的排名区间内的名次数量相加,得到第二总名次数量,并根据第二总名次数量更新当前的用户排名记录。
图3是根据本说明书一实施例的一种排名方法的示意性流程图,如图3所示,该方法应用于各分区,包括:
S302,记录当前单位时长内被分配的待排名用户的参与排名信息;其中,参与排名信息包括待排名用户的数量信息及各待排名用户的参与排名顺序。
其中,各分区均包括各自的record表(即用户流水表)和count表(即计数表)。其中,record表用于记录各待排名用户的用户标识(如用户ID)、排名标识、参与排名时间、名次(初始状态为空)、分区标识等信息。count表用于记录各待排名用户的用户标识、排名标识、参与排名时间、所属分区的初始名次、终止名次、待排名用户的数量等信息。
服务器每向分区分配一个待排名用户,分区内的record表中就会增加一条记录,用于记录被分配的待排名用户的相关信息,且count表内所记录的待排名用户的数量就会累计加1。
count表中所记录的待排名用户的数量指的是当前单位时长内的待排名用户的数量。在当前单位时长内的待排名用户完成排名后,count表中会重新增加一条新的记录,用于记录下一个单位时长内的待排名用户的数量,且下一个单位时长内的待排名用户的数量值会根据所属分区在下一个单位时长内被分配的用户数量进行更新。
通过record表和count表中所记录的信息,各分区可获知各待排名用户的参与排名时间,以便后续为各待排名用户进行排名。并且,各分区还可获知当前单位时长内的待排名用户的数量信息,并将该数量信息上报至服务器,由服务器根据该数量信息为相应分区分配对应的排名区间。
在一个实施例中,一个分区可管理其他多个子分区(即record表和count表),也就是说,一个分区内可具有多个record表和count表。例如,假设共有1000张record表和count表,而分区仅有5个,那么每个分区内应设置200个record表和count表。当分区向服务器上报待排名用户的数量信息时,应汇总分区内的200个record表和count表所记录的待排名用户的数量信息进行上报。
S304,将待排名用户的数量信息发送至服务器,以使服务器根据该数量信息信息为各分区分配对应的排名区间。
其中,排名区间内的名次数量与分区内的待排名用户的数量相同。服务器为各分区分配对应的排名区间的方法已在上述实施例中详细说明,此处不再赘述。
S306,根据排名区间及各待排名用户的参与排名顺序,为各待排名用户进行排名。
其中,各分区会记录被分配的各待排名用户的参与排名时间(即被分配至分区内的时间),当各分区根据排名区间为各待排名用户进行排名时,可根据所记录的各待排名用户的参与排名时间的先后顺序进行排名。
在一个实施例中,各分区可在当前单位时长内记录参与排名的第一用户的用户信息,并确定第一用户为当前单位时长内的待排名用户。其中,用户信息包括用户标识、用户参与排名的时间信息、所在分区的分区标识等信息。
在一个实施例中,用户信息还包括用户排名信息。因此,在为各待排名用户进行排名之后,可根据排名结果更新各待排名用户的用户排名信息。
综上,已经对本主题的特定实施例进行了描述。其它实施例在所附权利要求书的范围内。在一些情况下,在权利要求书中记载的动作可以按照不同的顺序来执行并且仍然可以实现期望的结果。另外,在附图中描绘的过程不一定要求示出的特定顺序或者连续顺序,以实现期望的结果。在某些实施方式中,多任务处理和并行处理可以是有利的。
以上为本说明书一个或多个实施例提供的排名方法,基于同样的思路,本说明书一个或多个实施例还提供一种排名装置。
图4是根据本说明书一实施例的一种排名装置的示意性框图,如图4所示,排名装置400应用于服务器,包括:
获取模块410,用于获取由各分区分别发送的、各分区在当前单位时长内被分配的待排名用户的数量信息;
第一确定模块420,用于确定各分区发送数量信息的先后顺序;及,根据当前的用户排名记录,确定当前单位时长内待排名用户的第一初始名次;
第二确定模块430,用于根据数量信息、先后顺序及第一初始名次,确定各分区分别对应的排名区间;其中,各分区分别对应的排名区间内的名次数量与对应分区内的待排名用户的数量相同;
分配模块440,用于为各分区分配对应的排名区间,以使各分区根据排名区间为待排名用户进行排名。
在一个实施例中,第一确定模块420包括:
获取单元,用于从当前的用户排名记录中,获取记录的在当前单位时长之前参与排名的所有用户的第一总名次数量;
第一增值单元,用于将第一总名次数量的值加1,得到当前单位时长内待排名用户的第一初始名次。
在一个实施例中,第二确定模块430包括:
第一确定单元,用于按照先后顺序,确定第一分区对应的排名区间为以第一初始名次开始、且名次数量与第一分区内的待排名用户的数量相同的区间;
第二增值单元,用于将第一分区对应的排名区间的终止名次加1,得到第二区间对应的第二初始名次;及,确定第二区间对应的排名区间为以第二初始名次开始、且名次数量与第二分区内的待排名用户的数量相同的区间;
其中,第一分区为各分区中最先发送待排名用户的数量信息的分区,第二分区为位于第一分区之后、且与第一分区相邻的分区。
图5是根据本说明书一实施例的一种排名装置的示意性框图,如图5所示,排名装置500包括:
记录模块510,用于记录当前单位时长内被分配的待排名用户的参与排名信息;其中,参与排名信息包括待排名用户的数量信息及各待排名用户的参与排名顺序;
发送模块520,用于将待排名用户的数量信息发送至服务器,以使服务器根据数量信息为各分区分配对应的排名区间;其中,排名区间内的名次数量与分区内的待排名用户的数量相同;
排名模块530,用于根据排名区间及各待排名用户的参与排名顺序,为各待排名用户进行排名。
在一个实施例中,装置500还包括:
记录及确定模块,用于在当前单位时长内,记录参与排名的第一用户的用户信息;及,确定第一用户为当前单位时长内的待排名用户;
其中,用户信息包括用户标识、用户参与排名的时间信息、所在分区的分区标识中的至少一项。
在一个实施例中,用户信息还包括用户排名信息;
相应的,装置500还包括:
更新模块,用于在为各待排名用户进行排名之后,根据排名结果更新各待排名用户的用户排名信息。
采用本说明书一个或多个实施例的装置,通过获取由各分区分别发送的、各分区在当前单位时长内被分配的待排名用户的数量信息,确定各分区发送数量的先后顺序,并根据当前的用户排名记录,确定当前单位时长内待排名用户的第一初始名次,进而根据各分区内待排名用户的数量信息、先后顺序及第一初始名次,确定各分区分别对应的排名区间,并为各分区分配对应的排名区间,以使各分区根据排名区间为待排名用户进行排名。可见,该技术方案对用户进行排名时,并非是按照所有用户的参与时间先后顺序进行排名,而是将所有待排名用户分配至各个区间,并未各区间分配各自对应的排名区间,进而由各区间对各自对应的待排名用户进行排名。显然,这种方式将排名从百万级、甚至亿级用户维度降低到分区维度,从而使单个分区秒级一千的量即可满足全局秒级百万的量级,大大提高用户排名的效率;并且通过服务器向各分区分配对应的排名区间,使得各分区为待排名用户进行排名时能够保证排名全局的唯一性,实现了用户排名的准实时性及准确性。
本领域的技术人员应可理解,上述排名装置能够用来实现前文所述的排名方法,其中的细节描述应与前文方法部分描述类似,为避免繁琐,此处不另赘述。
基于同样的思路,本说明书一个或多个实施例还提供一种排名设备,如图6所示。排名设备可因配置或性能不同而产生比较大的差异,可以包括一个或一个以上的处理器601和存储器602,存储器602中可以存储有一个或一个以上存储应用程序或数据。其中,存储器602可以是短暂存储或持久存储。存储在存储器602的应用程序可以包括一个或一个以上模块(图示未示出),每个模块可以包括对排名设备中的一系列计算机可执行指令。更进一步地,处理器601可以设置为与存储器602通信,在排名设备上执行存储器602中的一系列计算机可执行指令。排名设备还可以包括一个或一个以上电源603,一个或一个以上有线或无线网络接口604,一个或一个以上输入输出接口605,一个或一个以上键盘606。
具体在本实施例中,排名设备包括有存储器,以及一个或一个以上的程序,其中一个或者一个以上程序存储于存储器中,且一个或者一个以上程序可以包括一个或一个以上模块,且每个模块可以包括对排名设备中的一系列计算机可执行指令,且经配置以由一个或者一个以上处理器执行该一个或者一个以上程序包含用于进行以下计算机可执行指令:
获取由各分区分别发送的、所述各分区在当前单位时长内被分配的待排名用户的数量信息;
确定所述各分区发送所述数量信息的先后顺序;及,根据当前的用户排名记录,确定所述当前单位时长内所述待排名用户的第一初始名次;
根据所述数量信息、所述先后顺序及所述第一初始名次,确定所述各分区分别对应的排名区间;其中,所述各分区分别对应的排名区间内的名次数量与对应分区内的待排名用户的数量相同;
为所述各分区分配对应的排名区间,以使所述各分区根据所述排名区间为所述待排名用户进行排名。
可选地,计算机可执行指令在被执行时,还可以使所述处理器:
从所述当前的用户排名记录中,获取记录的在所述当前单位时长之前参与排名的所有用户的第一总名次数量;
将所述第一总名次数量的值加1,得到所述当前单位时长内所述待排名用户的第一初始名次。
可选地,计算机可执行指令在被执行时,还可以使所述处理器:
按照所述先后顺序,确定所述第一分区对应的排名区间为以所述第一初始名次开始、且名次数量与所述第一分区内的待排名用户的数量相同的区间;
将所述第一分区对应的排名区间的终止名次加1,得到第二区间对应的第二初始名次;及,确定所述第二区间对应的排名区间为以所述第二初始名次开始、且名次数量与所述第二分区内的待排名用户的数量相同的区间;
其中,所述第一分区为所述各分区中最先发送所述待排名用户的数量信息的分区,所述第二分区为位于所述第一分区之后、且与所述第一分区相邻的分区。
可选地,计算机可执行指令在被执行时,还可以使所述处理器:
在获取由各分区分别发送的、所述各分区在当前单位时长内被分配的待排名用户的数量信息之后,根据排名配置信息,判断是否立即对所述当前单位时长内被分配的所述待排名用户进行排名;
若是,则立即对所述当前单位时长内被分配的所述待排名用户进行排名;
若否,则将获取到的所述当前单位时长内被分配的待排名用户的数量信息存储在缓存区域中。
可选地,所述排名配置信息包括排名延迟时长;
相应的,计算机可执行指令在被执行时,还可以使所述处理器:
若所述排名延迟时长为零,则确定立即对所述当前单位时长内被分配的所述待排名用户进行排名;
若所述排名延迟时长不为零,则确定延迟对所述当前单位时长内被分配的所述待排名用户的排名操作。
可选地,计算机可执行指令在被执行时,还可以使所述处理器:
在将获取到的所述待排名用户的数量信息存储在缓存区域中之后,当所述排名延迟时长达到时,从所述缓存区域中获取所述当前单位时长内被分配的待排名用户的数量信息;及,对所述当前单位时长内被分配的所述待排名用户进行排名。
可选地,计算机可执行指令在被执行时,还可以使所述处理器:
在将所述各分区分别对应的排名区间分配至所述各分区之后,将所述第一总名次数量与所述各分区分别对应的排名区间内的名次数量相加,得到第二总名次数量;
根据所述第二总名次数量,更新所述当前的用户排名记录。
基于同样的思路,本说明书一个或多个实施例还提供一种排名设备,如图7所示。排名设备可因配置或性能不同而产生比较大的差异,可以包括一个或一个以上的处理器701和存储器702,存储器702中可以存储有一个或一个以上存储应用程序或数据。其中,存储器702可以是短暂存储或持久存储。存储在存储器702的应用程序可以包括一个或一个以上模块(图示未示出),每个模块可以包括对排名设备中的一系列计算机可执行指令。更进一步地,处理器701可以设置为与存储器702通信,在排名设备上执行存储器702中的一系列计算机可执行指令。排名设备还可以包括一个或一个以上电源703,一个或一个以上有线或无线网络接口704,一个或一个以上输入输出接口705,一个或一个以上键盘706。
具体在本实施例中,排名设备包括有存储器,以及一个或一个以上的程序,其中一个或者一个以上程序存储于存储器中,且一个或者一个以上程序可以包括一个或一个以上模块,且每个模块可以包括对排名设备中的一系列计算机可执行指令,且经配置以由一个或者一个以上处理器执行该一个或者一个以上程序包含用于进行以下计算机可执行指令:
记录当前单位时长内被分配的待排名用户的参与排名信息;其中,所述参与排名信息包括所述待排名用户的数量信息及各所述待排名用户的参与排名顺序;
将所述待排名用户的数量信息发送至服务器,以使所述服务器根据所述数量信息为各分区分配对应的排名区间;其中,所述排名区间内的名次数量与所述分区内的所述待排名用户的数量相同;
根据所述排名区间及各所述待排名用户的参与排名顺序,为各所述待排名用户进行排名。
可选地,计算机可执行指令在被执行时,还可以使所述处理器:
在所述当前单位时长内,记录参与排名的第一用户的用户信息;及,确定所述第一用户为所述当前单位时长内的所述待排名用户;
其中,所述用户信息包括用户标识、用户参与排名的时间信息、所在分区的分区标识中的至少一项。
可选地,所述用户信息还包括用户排名信息;
相应的,计算机可执行指令在被执行时,还可以使所述处理器:
在为各所述待排名用户进行排名之后,根据排名结果,更新各所述待排名用户的所述用户排名信息。
本说明书一个或多个实施例还提出了一种计算机可读存储介质,该计算机可读存储介质存储一个或多个程序,该一个或多个程序包括指令,该指令当被包括多个应用程序的电子设备执行时,能够使该电子设备执行上述排名方法,并具体用于执行:
获取由各分区分别发送的、所述各分区在当前单位时长内被分配的待排名用户的数量信息;
确定所述各分区发送所述数量信息的先后顺序;及,根据当前的用户排名记录,确定所述当前单位时长内所述待排名用户的第一初始名次;
根据所述数量信息、所述先后顺序及所述第一初始名次,确定所述各分区分别对应的排名区间;其中,所述各分区分别对应的排名区间内的名次数量与对应分区内的待排名用户的数量相同;
为所述各分区分配对应的排名区间,以使所述各分区根据所述排名区间为所述待排名用户进行排名。
本说明书一个或多个实施例还提出了一种计算机可读存储介质,该计算机可读存储介质存储一个或多个程序,该一个或多个程序包括指令,该指令当被包括多个应用程序的电子设备执行时,能够使该电子设备执行上述排名方法,并具体用于执行:
记录当前单位时长内被分配的待排名用户的参与排名信息;其中,所述参与排名信息包括所述待排名用户的数量信息及各所述待排名用户的参与排名顺序;
将所述待排名用户的数量信息发送至服务器,以使所述服务器根据所述数量信息为各分区分配对应的排名区间;其中,所述排名区间内的名次数量与所述分区内的所述待排名用户的数量相同;
根据所述排名区间及各所述待排名用户的参与排名顺序,为各所述待排名用户进行排名。
上述实施例阐明的系统、装置、模块或单元,具体可以由计算机芯片或实体实现,或者由具有某种功能的产品来实现。一种典型的实现设备为计算机。具体的,计算机例如可以为个人计算机、膝上型计算机、蜂窝电话、相机电话、智能电话、个人数字助理、媒体播放器、导航设备、电子邮件设备、游戏控制台、平板计算机、可穿戴设备或者这些设备中的任何设备的组合。
为了描述的方便,描述以上装置时以功能分为各种单元分别描述。当然,在实施本说明书一个或多个实施例时可以把各单元的功能在同一个或多个软件和/或硬件中实现。
本领域内的技术人员应明白,本说明书一个或多个实施例可提供为方法、系统、或计算机程序产品。因此,本说明书一个或多个实施例可采用完全硬件实施例、完全软件实施例、或结合软件和硬件方面的实施例的形式。而且,本说明书一个或多个实施例可采用在一个或多个其中包含有计算机可用程序代码的计算机可用存储介质(包括但不限于磁盘存储器、CD-ROM、光学存储器等)上实施的计算机程序产品的形式。
本说明书一个或多个实施例是参照根据本申请实施例的方法、设备(系统)、和计算机程序产品的流程图和/或方框图来描述的。应理解可由计算机程序指令实现流程图和/或方框图中的每一流程和/或方框、以及流程图和/或方框图中的流程和/或方框的结合。可提供这些计算机程序指令到通用计算机、专用计算机、嵌入式处理机或其他可编程数据处理设备的处理器以产生一个机器,使得通过计算机或其他可编程数据处理设备的处理器执行的指令产生用于实现在流程图一个流程或多个流程和/或方框图一个方框或多个方框中指定的功能的装置。
这些计算机程序指令也可存储在能引导计算机或其他可编程数据处理设备以特定方式工作的计算机可读存储器中,使得存储在该计算机可读存储器中的指令产生包括指令装置的制造品,该指令装置实现在流程图一个流程或多个流程和/或方框图一个方框或多个方框中指定的功能。
这些计算机程序指令也可装载到计算机或其他可编程数据处理设备上,使得在计算机或其他可编程设备上执行一系列操作步骤以产生计算机实现的处理,从而在计算机或其他可编程设备上执行的指令提供用于实现在流程图一个流程或多个流程和/或方框图一个方框或多个方框中指定的功能的步骤。
在一个典型的配置中,计算设备包括一个或多个处理器(CPU)、输入/输出接口、网络接口和内存。
内存可能包括计算机可读介质中的非永久性存储器,随机存取存储器(RAM)和/或非易失性内存等形式,如只读存储器(ROM)或闪存(flash RAM)。内存是计算机可读介质的示例。
计算机可读介质包括永久性和非永久性、可移动和非可移动媒体可以由任何方法或技术来实现信息存储。信息可以是计算机可读指令、数据结构、程序的模块或其他数据。计算机的存储介质的例子包括,但不限于相变内存(PRAM)、静态随机存取存储器(SRAM)、动态随机存取存储器(DRAM)、其他类型的随机存取存储器(RAM)、只读存储器(ROM)、电可擦除可编程只读存储器(EEPROM)、快闪记忆体或其他内存技术、只读光盘只读存储器(CD-ROM)、数字多功能光盘(DVD)或其他光学存储、磁盒式磁带,磁带磁磁盘存储或其他磁性存储设备或任何其他非传输介质,可用于存储可以被计算设备访问的信息。按照本文中的界定,计算机可读介质不包括暂存电脑可读媒体(transitory media),如调制的数据信号和载波。
还需要说明的是,术语“包括”、“包含”或者其任何其他变体意在涵盖非排他性的包含,从而使得包括一系列要素的过程、方法、商品或者设备不仅包括那些要素,而且还包括没有明确列出的其他要素,或者是还包括为这种过程、方法、商品或者设备所固有的要素。在没有更多限制的情况下,由语句“包括一个……”限定的要素,并不排除在包括所述要素的过程、方法、商品或者设备中还存在另外的相同要素。
本说明书一个或多个实施例可以在由计算机执行的计算机可执行指令的一般上下文中描述,例如程序模块。一般地,程序模块包括执行特定任务或实现特定抽象数据类型的例程、程序、对象、组件、数据结构等等。也可以在分布式计算环境中实践本申请,在这些分布式计算环境中,由通过通信网络而被连接的远程处理设备来执行任务。在分布式计算环境中,程序模块可以位于包括存储设备在内的本地和远程计算机存储介质中。
本说明书中的各个实施例均采用递进的方式描述,各个实施例之间相同相似的部分互相参见即可,每个实施例重点说明的都是与其他实施例的不同之处。尤其,对于系统实施例而言,由于其基本相似于方法实施例,所以描述的比较简单,相关之处参见方法实施例的部分说明即可。
以上所述仅为本说明书一个或多个实施例而已,并不用于限制本说明书。对于本领域技术人员来说,本说明书一个或多个实施例可以有各种更改和变化。凡在本说明书一个或多个实施例的精神和原理之内所作的任何修改、等同替换、改进等,均应包含在本说明书一个或多个实施例的权利要求范围之内。