关注
一、Redis 数据类型
1. 字符串(string):可以存储任何类型的字符串,如文本、数字等。可以进行自增自减等操作。
2. 哈希(hash):类似于 Python 的字典,存储键值对集合。适合存储对象信息。
3. 列表(list):按照插入顺序排序的字符串元素集合。可以进行从两端的插入和弹出操作。
4. 集合(set):无序的、不重复的字符串元素集合。支持交集、并集、差集等操作。
5. 有序集合(sorted set):每个元素都关联一个分数,可以按照分数进行排序。常用于排行榜等场景。
二、Redis 跳表
Redis 的有序集合(sorted set)是通过跳表实现的。跳表是一种可以替代平衡树的数据结构,具有以下特点:
1. 插入、删除、查找操作的时间复杂度均为 O(log n),与平衡树相当。
2. 实现相对简单,比起平衡树更易于理解和实现。
3. 可以在不同层次进行快速的遍历和查找,提高了查找效率。
三、抽象类和接口类区别
1. 定义:
- 抽象类是用 abstract 关键字修饰的类,可以包含抽象方法和具体方法。
- 接口是用 interface 关键字定义的,只包含抽象方法和常量。
2. 继承:
- 类只能单继承抽象类,但可以实现多个接口。
3. 方法实现:
- 抽象类可以有部分方法的具体实现,子类可以继承这些实现或者重写它们。
- 接口中的方法都是抽象的,实现接口的类必须实现所有的方法。
4. 变量:
- 抽象类可以包含成员变量,既可以是普通变量也可以是静态变量。
- 接口中只能定义静态常量。
四、重载和重写,子类能否对父类重载重写
1. 重载(Overload):是在同一个类中,方法名相同,但参数列表不同(参数类型、参数个数、参数顺序不同)。子类不能对父类进行重载,因为重载是在同一个类中的概念。
2. 重写(Override):子类继承父类,子类中的方法与父类中的方法具有相同的方法名、参数列表和返回类型,并且子类方法的访问权限不能小于父类方法的访问权限。子类可以对父类进行重写。
查看原帖
3 评论
相关推荐
点赞 评论 收藏
分享
牛客热帖
更多
正在热议
更多
# 我的求职进度条 #
985485次浏览 6544人参与
# 携程笔试 #
153609次浏览 890人参与
# 厦门银行科技岗值不值得投 #
18978次浏览 422人参与
# 米哈游工作体验 #
29925次浏览 145人参与
# 拼多多集团-PDD笔试 #
64496次浏览 486人参与
# 哪些公司一直卡在简历筛选 #
105847次浏览 361人参与
# 中国电信笔试 #
40790次浏览 399人参与
# 拿到offer之后,可以做些什么 #
104811次浏览 511人参与
# 入职第一天,你准备什么时候下班 #
118256次浏览 516人参与
# Agent面试会问什么? #
38846次浏览 1424人参与
# 一人分享一个skill #
10024次浏览 243人参与
# 说说你知道的学历厂 #
401651次浏览 1433人参与
# 春招至今,你收到几个面试了? #
101542次浏览 1261人参与
# 选实习,你更看重哪方面? #
76816次浏览 505人参与
# 拼多多工作体验 #
55394次浏览 389人参与
# 记录实习开销 #
214542次浏览 1747人参与
# 你觉得专业和学校哪个对薪资影响最大 #
104550次浏览 620人参与
# 给工作过的公司写一条大众点评,你会怎么写? #
12544次浏览 144人参与
# TCL求职进展汇总 #
152329次浏览 665人参与
# 通信/硬件的薪资开多少,才值得去? #
76797次浏览 407人参与
# 面试体验最好和最差的公司 #
25633次浏览 171人参与
