当前位置: 首页 > news >正文

如何建立自己的商城网站搜索引擎的四个组成部分及作用

如何建立自己的商城网站,搜索引擎的四个组成部分及作用,网站建设 环保素材,wordpress mnews目录 前言TreeMap实现的接口内部类常用方法 TreeSet实现的接口常用方法 前言 Map和set是一种专门用来进行搜索的容器或者数据结构,其搜索的效率与其具体的实例化子类有关。 一般把搜索的数据称为关键字(Key), 和关键字对应的称为…

目录

  • 前言
  • TreeMap
    • 实现的接口
    • 内部类
    • 常用方法
  • TreeSet
    • 实现的接口
    • 常用方法

前言

Map和set是一种专门用来进行搜索的容器或者数据结构,其搜索的效率与其具体的实例化子类有关。

一般把搜索的数据称为关键字(Key),
和关键字对应的称为值(Value),
将其称之为Key-value的键值对。

所以搜索有两种模型:

  • 纯key模型:
  • key-value 模型

Map中存储的就是key-value的键值对,并且key必须是唯一的,
Set中只存储了Key。

TreeMap

使用TreeMap必须导包import java.util.TreeMap;,底层是一棵红黑树。

实现的接口

  • 实现了SortedMap表示TreeMap可以排序,
  • 没有实现Collection接口,但是value的类型是Collection。

内部类

内部类Entry,相当于我们前面实现的二叉搜索树中的TreeNode节点,
其中提供了getKey,getValue,setValue方法,
也重写了equals,hashCode,toString方法。
但是Map.Entry<K,V>并没有提供设置Key的方法

方法解释
K getKey()返回 entry 中的 key
V getValue()返回 entry 中的 value
V setValue(V value)将键值对中的value替换为指定value

常用方法

方法解释
V get(Object key)返回 key 对应的 value
V getOrDefault(Object key, V defaultValue)返回 key 对应的 value,key 不存在,返回默认值defaultValue
V put(K key, V value)设置 key 对应的 value
V remove(Object key)删除 key 对应的映射关系
Set keySet()返回所有 key 的不重复集合
Collection values()返回所有 value 的可重复集合
Set<Map.Entry<K, V>> entrySet()返回所有的 key-value 映射关系
boolean containsKey(Object key)判断是否包含 key
boolean containsValue(Object value)判断是否包含 value

注意事项:

  • Map中存放键值对的Key是唯一的,value是可以重复的;
  • 在TreeMap中插入键值对时,key不能为空,否则就会抛NullPointerException异常,value可以为空;
  • Map中的Key可以全部分离出来,存储到Set中来进行访问(因为Key不能重复);
  • Map中的value可以全部分离出来,存储在Collection的任何一个子集合中(value可能有重复);
  • Map中键值对的Key不能直接修改,value可以修改,如果要修改key,只能先将该key删除掉,然后再来进行重新插入。

TreeSet

其实TreeSet的底层就是TreeMap,只不过在初始化时给的value值都是一个固定值。

实现的接口

  • TreeSet也是可以排序的,实现了sortedSet,带Tree的set和map其实可以排序的,
  • 实现了Collection,
  • 也实现了Iterable接口,所以可以使用迭代器遍历,如果要使用迭代器遍历TreeMap,必须先调用entrySet方法得到Set才行。

常用方法

方法解释
boolean add(E e)添加元素,但重复元素不会被添加成功
void clear()清空集合
boolean contains(Object o)判断 o 是否在集合中
Iterator iterator()返回迭代器
boolean remove(Object o)删除集合中的 o
int size()返回set中元素的个数
boolean isEmpty()检测set是否为空,空返回true,否则返回false
Object[] toArray()将set中的元素转换为数组返回
boolean containsAll(Collection<?> c)集合c中的元素是否在set中全部存在,是返回true,否则返回
false
boolean addAll(Collection<? extends E> c)将集合c中的元素添加到set中,可以达到去重的效果

注意事项:

  • Set中只存储了key,并且要求key一定要唯一;
  • TreeSet的底层是使用Map来实现的,其使用key与Object的一个默认对象作为键值对插入到Map中的;
  • Set最大的功能就是对集合中的元素进行去重;
  • 实现Set接口的常用类有TreeSet和HashSet,还有一个LinkedHashSet,LinkedHashSet是在HashSet的基础上维护了一个双向链表来记录元素的插入次序;
  • Set中的Key不能修改,如果要修改,先将原来的删除掉,然后再重新插入;
  • TreeSet中不能插入null的key。
http://www.dinnco.com/news/54823.html

相关文章:

  • 公司网站开发费用济南兴田德润简介图片郑州网络推广哪家口碑好
  • 中央广播电视总台山东总站国际网站平台有哪些
  • 郑州的兼职网站建设百度小程序入口官网
  • 网站开发协议书织梦seo排名优化教程
  • 美女直接做的网站口碑营销策略有哪些
  • 有没有专做推广小说的网站免费收录网站
  • 制作网页站点的具体流程案例1688官网
  • 涡阳哪里有做网站的seo标题优化关键词
  • 长春网站如何制作今日关键词
  • 铁岭市网站建设什么是seo文章
  • 代办注册公司流程和费用多少优化关键词的正确方法
  • 灯具设计网站推荐广州seo站内优化
  • 岛国萝莉做的电影网站如何注册网站
  • 房产网上过户怎么操作长沙网站优化培训
  • 网站建设服务那家好站长工具怎么关掉
  • vi企业形象设计全套案例百家号关键词排名优化
  • 做短视频网站收益seo网络营销外包
  • 深圳高端画册设计公司抖音seo推广外包公司好做吗
  • 网站建设协议微信上如何投放广告
  • 成都手机网站互联网公司排名2021
  • 做网站备案不少天win7一键优化工具
  • 藤虎网络广州网站建设seo整站优化方案案例
  • 重庆阳光投诉平台深圳优化公司哪家好
  • 深圳市网站哪家做的好优化搜狗排名
  • h5企业网站只做免费做推广的网站
  • Wix网站开发 工作室西安百度公司官网
  • 专门做喷涂设备的网站营业推广怎么写
  • 公司做网站都咨询哪些问题东莞建设企业网站
  • 网站开发用的是什么语言针对百度关键词策划和seo的优化
  • 西安市政道桥建设公司网站5118站长工具箱