【JAVA进阶篇】与数据结构结合?这些知识你应该知道

编程入门 行业动态 更新时间:2024-10-22 08:04:40

【JAVA进阶篇】与<a href=https://www.elefans.com/category/jswz/34/1769880.html style=数据结构结合?这些知识你应该知道"/>

【JAVA进阶篇】与数据结构结合?这些知识你应该知道


个人主页:【😊个人主页】
系列专栏:【❤️JAVA进阶】


文章目录

  • 前言
  • 关与JAVA中的数据结构
    • Java中的数据结构
  • 枚举
  • 位集合
    • 创建一个初始大小的位集合
    • 设置特定的位
    • 从另一个位集合中复制位
    • 迭代位集合中设置为1的位
    • 将位集合转换为字节数组
    • 将字节数组转换为位集合
  • 字典
  • 结尾


前言

从今天起我们将进入一个全新的章节,关于JAVA我们也将有一个更深的认识,话不多说,让我们开始吧!

关与JAVA中的数据结构

关于数据结构相信很多小伙伴并不陌生,在之前的数据结构与算法中我们有大致的学习过,不了解的同学可以点击区看看。这里我们就不过多的赘叙了,但是在Java工具包中提供了强大的数据结构。

Java中的数据结构

  • 枚举(Enumeration)
  • 位集合(BitSet)
  • 向量(Vector)
  • 栈(Stack)
  • 字典(Dictionary)
  • 哈希表(Hashtable)
  • 属性(Properties)
    在Java2中引入了一种新的框架-集合框架(Collection)

枚举

枚举类型在Java中是通过enum关键字定义的。

enum DayOfWeek {MONDAY, TUESDAY, WEDNESDAY, THURSDAY, FRIDAY, SATURDAY, SUNDAY
}

上面的代码定义了一个名为DayOfWeek的枚举类型,它包含一组表示星期几的常量。这些常量是MONDAYTUESDAYWEDNESDAYTHURSDAYFRIDAYSATURDAYSUNDAY
可以通过以下方式使用枚举类型:

DayOfWeek day = DayOfWeek.MONDAY;
if (day == DayOfWeek.MONDAY) {System.out.println("Today is Monday");
}

枚举类型可以包含方法和字段,就像普通的Java类一样。枚举类型还可以实现接口。枚举类型通常用于表示固定的、有限的常量集合,例如颜色、方向、状态等。

位集合

位集合(BitSet)是一个可调整大小的位向量,每个位的值只能是0或1。它是Java集合框架中的一部分,位集合可以高效地表示大量的布尔值,因为它们使用的是位操作而不是字节操作。

创建一个初始大小的位集合

BitSet bitset = new BitSet();

设置特定的位

bitset.set(3); // 将索引为3的位设置为1

从另一个位集合中复制位

BitSet other = new BitSet();
other.set(2);
other.set(4);
bitset.or(other); // 将other中的位复制到bitset中

迭代位集合中设置为1的位

for (int i = bitset.nextSetBit(0); i >= 0; i = bitset.nextSetBit(i+1)) {// 处理索引为i的位
}

将位集合转换为字节数组

byte[] bytes = bitset.toByteArray();

将字节数组转换为位集合

bitset = BitSet.valueOf(bytes);

字典

在Java中,字典通常指的是键值对的结构,也称为映射。Java中的字典有多种实现方式,包括:

  • HashMap:基于哈希表实现,具有快速的查找和插入操作,但是对于迭代操作不太友好。
  • TreeMap:基于红黑树实现,具有自动排序的功能,适合需要有序的字典。
  • LinkedHashMap:基于哈希表和双向链表实现,具有顺序访问的特性,可以保留元素插入的顺序。
  • Hashtable:类似于HashMap,但是线程安全,性能较差,现在很少使用。
//创建一个HashMap字典
Map<String, Integer> map = new HashMap<>();//向字典中插入新元素
map.put("apple", 10);
map.put("orange", 5);
map.put("banana", 15);//从字典中获取元素
int count = map.get("apple");//遍历字典中的所有元素
for (Map.Entry<String, Integer> entry : map.entrySet()) {String key = entry.getKey();int value = entry.getValue();System.out.println("key:" + key + ",value:" + value);
}//判断字典中是否包含某个键
boolean containsKey = map.containsKey("pear");//获取字典中键的集合
Set<String> keySet = map.keySet();//获取字典中值的集合
Collection<Integer> values = map.values();//从字典中删除元素
map.remove("banana");//清空字典中的所有元素
map.clear();

结尾

因为篇幅有限,还有一些数据结构有机会我会为大家详细讲解,我们下次再见

更多推荐

【JAVA进阶篇】与数据结构结合?这些知识你应该知道

本文发布于:2023-11-15 06:09:40,感谢您对本站的认可!
本文链接:https://www.elefans.com/category/jswz/34/1595015.html
版权声明:本站内容均来自互联网,仅供演示用,请勿用于商业和其他非法用途。如果侵犯了您的权益请与我们联系,我们将在24小时内删除。
本文标签:数据结构   你应该知道   知识   进阶篇   JAVA

发布评论

评论列表 (有 0 条评论)
草根站长

>www.elefans.com

编程频道|电子爱好者 - 技术资讯及电子产品介绍!