全部产品
存储与CDN 数据库 域名与网站(万网) 应用服务 数加·人工智能 数加·大数据基础服务 互联网中间件 视频服务 开发者工具 解决方案 物联网 钉钉智能硬件
云数据库 Redis 版

游戏玩家积分排行榜

更新时间:2017-06-07 13:26:11

场景介绍

云数据库 Redis 版在功能上与 Redis 基本一致,因此很容易用它来实现一个在线游戏中的积分排行榜功能。

代码示例

  1. import java.util.ArrayList;
  2. import java.util.List;
  3. import java.util.Set;
  4. import java.util.UUID;
  5. import redis.clients.jedis.Jedis;
  6. import redis.clients.jedis.Tuple;
  7. public class GameRankSample {
  8. static int TOTAL_SIZE = 20;
  9. public static void main(String[] args)
  10. {
  11. //连接信息,从控制台可以获得
  12. String host = "xxxxxxxxxx.m.cnhz1.kvstore.aliyuncs.com";
  13. int port = 6379;
  14. Jedis jedis = new Jedis(host, port);
  15. try {
  16. //实例密码
  17. String authString = jedis.auth("password");//password
  18. if (!authString.equals("OK"))
  19. {
  20. System.err.println("AUTH Failed: " + authString);
  21. return;
  22. }
  23. //Key(键)
  24. String key = "游戏名:奔跑吧,阿里!";
  25. //清除可能的已有数据
  26. jedis.del(key);
  27. //模拟生成若干个游戏玩家
  28. List<String> playerList = new ArrayList<String>();
  29. for (int i = 0; i < TOTAL_SIZE; ++i)
  30. {
  31. //随机生成每个玩家的ID
  32. playerList.add(UUID.randomUUID().toString());
  33. }
  34. System.out.println("输入所有玩家 ");
  35. //记录每个玩家的得分
  36. for (int i = 0; i < playerList.size(); i++)
  37. {
  38. //随机生成数字,模拟玩家的游戏得分
  39. int score = (int)(Math.random()*5000);
  40. String member = playerList.get(i);
  41. System.out.println("玩家ID:" + member + ", 玩家得分: " + score);
  42. //将玩家的ID和得分,都加到对应key的SortedSet中去
  43. jedis.zadd(key, score, member);
  44. }
  45. //输出打印全部玩家排行榜
  46. System.out.println();
  47. System.out.println(" "+key);
  48. System.out.println(" 全部玩家排行榜 ");
  49. //从对应key的SortedSet中获取已经排好序的玩家列表
  50. Set<Tuple> scoreList = jedis.zrevrangeWithScores(key, 0, -1);
  51. for (Tuple item : scoreList) {
  52. System.out.println("玩家ID:"+item.getElement()+", 玩家得分:"+Double.valueOf(item.getScore()).intValue());
  53. }
  54. //输出打印Top5玩家排行榜
  55. System.out.println();
  56. System.out.println(" "+key);
  57. System.out.println(" Top 玩家");
  58. scoreList = jedis.zrevrangeWithScores(key, 0, 4);
  59. for (Tuple item : scoreList) {
  60. System.out.println("玩家ID:"+item.getElement()+", 玩家得分:"+Double.valueOf(item.getScore()).intValue());
  61. }
  62. //输出打印特定玩家列表
  63. System.out.println();
  64. System.out.println(" "+key);
  65. System.out.println(" 积分在1000至2000的玩家");
  66. //从对应key的SortedSet中获取已经积分在1000至2000的玩家列表
  67. scoreList = jedis.zrangeByScoreWithScores(key, 1000, 2000);
  68. for (Tuple item : scoreList) {
  69. System.out.println("玩家ID:"+item.getElement()+", 玩家得分:"+Double.valueOf(item.getScore()).intValue());
  70. }
  71. } catch (Exception e) {
  72. e.printStackTrace();
  73. }finally{
  74. jedis.quit();
  75. jedis.close();
  76. }
  77. }
  78. }

运行结果

在输入了正确的云数据库 Redis 版实例访问地址和密码之后,运行以上 Java 程序,输出结果如下:

  1. 输入所有玩家
  2. 玩家ID9193e26f-6a71-4c76-8666-eaf8ee97ac86 玩家得分: 3860
  3. 玩家IDdb03520b-75a3-48e5-850a-071722ff7afb 玩家得分: 4853
  4. 玩家IDd302d24d-d380-4e15-a4d6-84f71313f27a 玩家得分: 2931
  5. 玩家IDbee46f9d-4b05-425e-8451-8aa6d48858e6 玩家得分: 1796
  6. 玩家IDec24fb9e-366e-4b89-a0d5-0be151a8cad0 玩家得分: 2263
  7. 玩家IDe11ecc2c-cd51-4339-8412-c711142ca7aa 玩家得分: 1848
  8. 玩家ID4c396f67-da7c-4b99-a783-25919d52d756 玩家得分: 958
  9. 玩家IDa6299dd2-4f38-4528-bb5a-aa2d48a9f94a 玩家得分: 2428
  10. 玩家ID2e4ec631-1e4e-4ef0-914f-7bf1745f7d65 玩家得分: 4478
  11. 玩家ID24235a85-85b9-476e-8b96-39f294f57aa7 玩家得分: 1655
  12. 玩家IDe3e8e1fa-6aac-4a0c-af80-4c4a1e126cd1 玩家得分: 4064
  13. 玩家ID99bc5b4f-e32a-4295-bc3a-0324887bb77e 玩家得分: 4852
  14. 玩家ID19e2aa6b-a2d8-4e56-bdf7-8b59f64bd8e0 玩家得分: 3394
  15. 玩家IDcb62bb24-1318-4af2-9d9b-fbff7280dbec 玩家得分: 3405
  16. 玩家IDec0f06da-91ee-447b-b935-7ca935dc7968 玩家得分: 4391
  17. 玩家ID2c814a6f-3706-4280-9085-5fe5fd56b71c 玩家得分: 2510
  18. 玩家ID9ee2ed6d-08b8-4e7f-b52c-9adfe1e32dda 玩家得分: 63
  19. 玩家ID0293b43a-1554-4157-a95b-b78de9edf6dd 玩家得分: 1008
  20. 玩家ID674bbdd1-2023-46ae-bbe6-dfcd8e372430 玩家得分: 2265
  21. 玩家ID34574e3e-9cc5-43ed-ba15-9f5405312692 玩家得分: 3734
  22. 游戏名:奔跑吧,阿里!
  23. 全部玩家排行榜
  24. 玩家IDdb03520b-75a3-48e5-850a-071722ff7afb 玩家得分:4853
  25. 玩家ID99bc5b4f-e32a-4295-bc3a-0324887bb77e 玩家得分:4852
  26. 玩家ID2e4ec631-1e4e-4ef0-914f-7bf1745f7d65 玩家得分:4478
  27. 玩家IDec0f06da-91ee-447b-b935-7ca935dc7968 玩家得分:4391
  28. 玩家IDe3e8e1fa-6aac-4a0c-af80-4c4a1e126cd1 玩家得分:4064
  29. 玩家ID9193e26f-6a71-4c76-8666-eaf8ee97ac86 玩家得分:3860
  30. 玩家ID34574e3e-9cc5-43ed-ba15-9f5405312692 玩家得分:3734
  31. 玩家IDcb62bb24-1318-4af2-9d9b-fbff7280dbec 玩家得分:3405
  32. 玩家ID19e2aa6b-a2d8-4e56-bdf7-8b59f64bd8e0 玩家得分:3394
  33. 玩家IDd302d24d-d380-4e15-a4d6-84f71313f27a 玩家得分:2931
  34. 玩家ID2c814a6f-3706-4280-9085-5fe5fd56b71c 玩家得分:2510
  35. 玩家IDa6299dd2-4f38-4528-bb5a-aa2d48a9f94a 玩家得分:2428
  36. 玩家ID674bbdd1-2023-46ae-bbe6-dfcd8e372430 玩家得分:2265
  37. 玩家IDec24fb9e-366e-4b89-a0d5-0be151a8cad0 玩家得分:2263
  38. 玩家IDe11ecc2c-cd51-4339-8412-c711142ca7aa 玩家得分:1848
  39. 玩家IDbee46f9d-4b05-425e-8451-8aa6d48858e6 玩家得分:1796
  40. 玩家ID24235a85-85b9-476e-8b96-39f294f57aa7 玩家得分:1655
  41. 玩家ID0293b43a-1554-4157-a95b-b78de9edf6dd 玩家得分:1008
  42. 玩家ID4c396f67-da7c-4b99-a783-25919d52d756 玩家得分:958
  43. 玩家ID9ee2ed6d-08b8-4e7f-b52c-9adfe1e32dda 玩家得分:63
  44. 游戏名:奔跑吧,阿里!
  45. Top 玩家
  46. 玩家IDdb03520b-75a3-48e5-850a-071722ff7afb 玩家得分:4853
  47. 玩家ID99bc5b4f-e32a-4295-bc3a-0324887bb77e 玩家得分:4852
  48. 玩家ID2e4ec631-1e4e-4ef0-914f-7bf1745f7d65 玩家得分:4478
  49. 玩家IDec0f06da-91ee-447b-b935-7ca935dc7968 玩家得分:4391
  50. 玩家IDe3e8e1fa-6aac-4a0c-af80-4c4a1e126cd1 玩家得分:4064
  51. 游戏名:奔跑吧,阿里!
  52. 积分在10002000的玩家
  53. 玩家ID0293b43a-1554-4157-a95b-b78de9edf6dd 玩家得分:1008
  54. 玩家ID24235a85-85b9-476e-8b96-39f294f57aa7 玩家得分:1655
  55. 玩家IDbee46f9d-4b05-425e-8451-8aa6d48858e6 玩家得分:1796
  56. 玩家IDe11ecc2c-cd51-4339-8412-c711142ca7aa 玩家得分:1848
本文导读目录