常用Java API

1 字符串处理

1.1 String 类

String 类是 Java 中不可变的字符序列。它提供了以下常用方法:

  • length():返回字符串的长度。

  • charAt(index):返回指定索引处的字符。

  • substring(startIndex, endIndex):返回从 startIndex 到 endIndex-1 处的子字符串。

  • indexOf(char):返回字符在字符串中首次出现的索引,如果没有找到则返回 -1。

示例代码:

String str = "Hello World";// 获取字符串长度
int length = str.length();// 获取指定索引处的字符
char ch = str.charAt(0);// 获取子字符串
String substring = str.substring(0, 5);// 查找字符在字符串中首次出现的索引
int index = str.indexOf('o');

1.2 StringBuilder 类

StringBuilder 类是一个可变的字符序列,用于高效地构造和修改字符串。它提供了以下常用方法:

  • append(string):将字符串追加到 StringBuilder 的末尾。

  • insert(index, string):在指定索引处插入字符串。

  • reverse():反转 StringBuilder 中的字符顺序。

示例代码:

StringBuilder sb = new StringBuilder();// 追加字符串
sb.append("Hello ");
sb.append("World");// 插入字符串
sb.insert(5, "Java ");// 反转字符串
sb.reverse();

2 集合框架

2.1 List 接口

List 接口表示一个有序的元素集合。它提供了以下常见的实现:

  • ArrayList:基于数组实现,支持元素的随机访问和动态增长。

  • LinkedList:基于链表实现,支持高效的插入和删除操作。

示例代码(ArrayList):

List<String> list = new ArrayList<>();// 添加元素
list.add("Hello");
list.add("World");// 获取元素
String element = list.get(0);// 移除元素
list.remove(1);

示例代码(LinkedList):

List<String> list = new LinkedList<>();// 添加元素
list.add("Hello");
list.add("World");// 获取元素
String element = list.getFirst();// 移除元素
list.removeFirst();

2.2 Set 接口

Set 接口表示一个不包含重复元素的集合。它提供了以下常见的实现:

  • HashSet:基于哈希表实现,不允许重复元素。

  • TreeSet:基于红黑树实现,元素按自然顺序排序。

示例代码(HashSet):

Set<String> set = new HashSet<>();// 添加元素
set.add("Hello");
set.add("World");// 检查元素是否存在
boolean contains = set.contains("Hello");// 移除元素
set.remove("World");

示例代码(TreeSet):

Set<String> set = new TreeSet<>();// 添加元素
set.add("Hello");
set.add("World");// 获取第一个元素
String first = set.first();// 移除第一个元素
set.remove(first);

2.3 Map 接口

Map 接口表示一个键值对集合。它提供了以下常见的实现:

  • HashMap:基于哈希表实现,键值对之间的映射不保证顺序。

  • TreeMap:基于红黑树实现,键值对按键的自然顺序排序。

示例代码(HashMap):

Map<String, Integer> map = new HashMap<>();// 添加键值对
map.put("Hello", 1);
map.put("World", 2);// 获取值
int value = map.get("Hello");// 移除键值对
map.remove("World");

示例代码(TreeMap):

Map<String, Integer> map = new TreeMap<>();// 添加键值对
map.put("Hello", 1);
map.put("World", 2);// 获取第一个键
String firstKey = map.firstKey();// 移除第一个键值对
map.remove(firstKey);

2.4 遍历方式

1). 使用迭代器(Iterator)

// 创建一个 ArrayList
List<String> list = new ArrayList<>();
list.add("Hello");
list.add("World");
list.add("Java");// 使用迭代器遍历 ArrayList
Iterator<String> iterator = list.iterator();
while (iterator.hasNext()) {String element = iterator.next();System.out.println(element);
}

2). 使用增强 for 循环

// 创建一个 HashSet
Set<String> set = new HashSet<>();
set.add("Hello");
set.add("World");
set.add("Java");// 使用增强 for 循环遍历 HashSet
for (String element : set) {System.out.println(element);
}

3). 使用流(Stream)

// 创建一个 HashMap
Map<String, Integer> map = new HashMap<>();
map.put("Hello", 1);
map.put("World", 2);
map.put("Java", 3);// 使用流遍历 HashMap
map.keySet().stream().forEach(key -> System.out.println(key + ": " + map.get(key)));

4). 使用 lambda 表达式

// 创建一个 ArrayList
List<String> list = new ArrayList<>();
list.add("Hello");
list.add("World");
list.add("Java");// 使用 lambda 表达式遍历 ArrayList
list.forEach(element -> System.out.println(element));

5). 使用并行流(Parallel Stream)

// 创建一个 ArrayList
List<String> list = new ArrayList<>();
list.add("Hello");
list.add("World");
list.add("Java");// 使用并行流遍历 ArrayList
list.parallelStream().forEach(element -> System.out.println(element));

2.5 区别

  • 数据结构: ArrayList 使用数组,LinkedList 使用链表,HashSet 使用哈希表。

  • 元素顺序: ArrayList 和 LinkedList 保持插入顺序,而 HashSet 无序。

  • 是否允许重复: ArrayList 和 LinkedList 允许重复元素,而 HashSet 不允许。

  • 时间复杂度: ArrayList 和 HashSet 的查找、插入和删除操作的平均时间复杂度为 O(1),而 LinkedList 的查找操作为 O(n),插入和删除操作为 O(1)。

  • 线程安全性: ArrayList、LinkedList 和 HashSet 都是非线程安全的。

3 Java文件操作

3.1 读取文件

要读取文件,可以使用 FileReader 和 BufferedReader 类:

FileReader fr = new FileReader("file.txt");
BufferedReader br = new BufferedReader(fr);
String line;
while ((line = br.readLine()) != null) {// 处理每一行
}
br.close();
fr.close();

3.2 写入文件

要写入文件,可以使用 FileWriter 和 BufferedWriter 类:

FileWriter fw = new FileWriter("file.txt");
BufferedWriter bw = new BufferedWriter(fw);
bw.write("内容");
bw.close();
fw.close();

结语:以上就是关于Java的常用API的学习,也是学习Java基础必须要掌握的,非常之重要,感谢各位看官的观看,谢谢,下期见! 

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/879284.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

物联网之PWM呼吸灯、脉冲、LEDC

MENU 前言原理硬件电路设计软件程序设计analogWrite()函数实现呼吸灯效果LEDC输出PWM信号 前言 学习制作呼吸灯&#xff0c;通过LED灯的亮度变化来验证PWM不同电压的输出。呼吸灯是指灯光在单片机的控制之下完成由亮到暗的逐渐变化&#xff0c;感觉好像是人在呼吸。 原理 脉冲宽…

【中秋月饼系列】2024年立体月饼新鲜出炉----python画月饼(1)附完整代码

【中秋月饼系列】2024年立体月饼新鲜出炉 ----python画月饼&#xff08;1&#xff09;附完整代码 本文目录&#xff1a; 零、时光宝盒 一、2024年中秋节立体逼真月饼&#xff08;效果展示&#xff09; 二、Python 海龟画图主要方法 &#xff08;1&#xff09;海龟画图的主…

学习大数据DAY56 业务理解和第一次接入

作业1 1 了解行业名词 ERP CRM OA MES WMS RPA SAAS 了解每个系统的功能和应用 ERP 系统&#xff0c;&#xff08;Enterprise Resource Planning&#xff0c;企业资源计划系统&#xff09;&#xff1a;ERP 系统 是一种用于管理企业各类资源的软件系统&#xff0c;包括生产管理…

攻防世界 ics-05

ics-05 隐藏的变量传参&#xff0c;php弱类型比较 只有设备维护中心可以点击进去 查看源码&#xff0c;发现有个隐藏的超链接变量传参 看到变量传参&#xff0c;有可能存在文件包含漏洞读取源码&#xff0c;这个站是php的站&#xff0c;所以可以使用php伪协议读取源码 index.p…

软件测试工程师面试整理-测试类型

软件测试类型多种多样,涵盖了从功能验证到性能评估的不同方面。了解各种测试类型有助于在软件开发生命周期的不同阶段选择合适的测试方法,确保软件的质量和可靠性。以下是常见的软件测试类型: 1. 功能测试(Functional Testing) ● 目标:验证软件功能是否按照需求文档正确…

2024年9月HarmonyOS鸿蒙应用开发者高级认证全新题库(覆盖99%考题)

一个小时通过鸿蒙高级认证 1、在开发 Harmony0S 应用工程时&#xff0c; 随着业务的发展&#xff0c;现在需要创建一个模块&#xff0c; 关于在 DevEco Studio 中创建 Module &#xff0c; 下列选项哪种方式是错误的? 必对 在 hvigor 目录下&#xff0c;单击鼠标右键&#xf…

Docker Swarm管理(Docker技术集群与应用)

如上图所示&#xff0c; 三台主机&#xff1a;恢复到docker的快照&#xff1b; 然后上传到三台服务器所需的镜像&#xff1b; 同步会话。执行导入脚本将镜像导入到系统中&#xff1b; 然后取消会话的同步&#xff0c;设置各个主机的主机名&#xff1b; 然后同步会话修改hosts…

Java JUC(一) 线程概念与常用方法

Java JUC&#xff08;一&#xff09; 线程概念与常用方法 一. JUC 基本概念 Java JUC&#xff08;Java Util Concurrent&#xff09; 是Java平台提供的一个并发编程工具包&#xff08;java.util.concurrent&#xff09;&#xff0c;全称为Java Concurrency Utilities。这个工具…

深入剖析 MQTT 协议:物联网通信的核心力量

摘要&#xff1a; 本文全面深入地探讨了 MQTT&#xff08;Message Queuing Telemetry Transport&#xff09;协议。详细阐述了 MQTT 协议的起源与发展背景&#xff0c;介绍其基本概念、特点及工作原理。深入分析了 MQTT 的架构组成&#xff0c;包括客户端、代理服务器及主题的作…

Jenkins部署若依项目

一、配置环境 机器 jenkins机器 用途&#xff1a;自动化部署前端后端&#xff0c;前后端自动化构建需要配置发送SSH的秘钥和公钥&#xff0c;同时jenkins要有nodejs工具来进行前端打包&#xff0c;maven工具进行后端的打包。 gitlab机器 用途&#xff1a;远程代码仓库拉取和…

《C++初始化列表陷阱:谨慎前行,避免潜在风险》

一 在 C编程中&#xff0c;初始化列表是一个强大的工具&#xff0c;它允许在对象创建时直接初始化成员变量。然而&#xff0c;就像任何强大的工具一样&#xff0c;如果使用不当&#xff0c;初始化列表也可能会带来一些陷阱。在本文中&#xff0c;我们将深入探讨 C中的初始化列表…

研1日记10

1. 日志 6.python接口自动化测试_日志类的封装与使用_哔哩哔哩_bilibili 简单的写法&#xff1a;python日志模块的封装(loguru)_哔哩哔哩_bilibili 2.open()函数 在Python中&#xff0c;使用open()函数打开文件时&#xff0c;第二个参数指定了文件的打开模式。w和a是两种常…

MongoDB 原子操作

MongoDB 原子操作 MongoDB 是一种流行的 NoSQL 数据库,以其灵活的数据模型和强大的查询语言而闻名。在处理数据时,MongoDB 提供了多种原子操作,确保了数据的一致性和安全性。本文将深入探讨 MongoDB 中的原子操作,包括其重要性、使用场景以及如何在实际应用中实现这些操作…

基于Linux的ARMxy工控机IEC61850协议实践

工业自动化水平的不断提高&#xff0c;对设备间高效、可靠通信的需求日益增长。IEC61850标准作为电力系统自动化领域的重要国际标准之一&#xff0c;其应用范围正在从传统的电力行业向更广泛的工业自动化领域扩展。本文将探讨基于ARM架构的工业计算机如何在Linux操作系统环境下…

解码未来:H.265与H.266技术对比及EasyCVR视频汇聚平台编码技术优势

随着视频技术的不断发展&#xff0c;视频编码标准也在不断更新迭代。H.265&#xff08;也称为HEVC&#xff0c;High Efficiency Video Coding&#xff09;和H.266&#xff08;也称为VVC&#xff0c;Versatile Video Coding&#xff09;作为当前和未来的主流视频编码标准&#x…

BrainSegFounder:迈向用于神经影像分割的3D基础模型|文献速递--Transformer架构在医学影像分析中的应用

Title 题目 BrainSegFounder: Towards 3D foundation models for neuroimagesegmentation BrainSegFounder&#xff1a;迈向用于神经影像分割的3D基础模型 01 文献速递介绍 人工智能&#xff08;AI&#xff09;与神经影像分析的融合&#xff0c;特别是多模态磁共振成像&am…

golang学习笔记11——Go 语言的并发与同步实现详解

推荐学习文档 golang应用级os框架&#xff0c;欢迎star基于golang开发的一款超有个性的旅游计划app经历golang实战大纲golang优秀开发常用开源库汇总golang学习笔记01——基本数据类型golang学习笔记02——gin框架及基本原理golang学习笔记03——gin框架的核心数据结构golang学…

[前端][JS]html中js不同位置的区别

里面&#xff0c;写到下面&#xff0c;这三种有什么区别&#xff1f; javascript代码写在<head>里面&#xff1a; 由于这时候网页主体&#xff08;body&#xff09;还未加载&#xff0c;所以这里适合放一些不是立即执行的自定义函数&#xff0c;立即执行的语句则很可能…

【机器学习】马尔可夫随机场的基本概念、和贝叶斯网络的联系与对比以及在python中的实例

引言 马尔可夫随机场&#xff08;Markov Random Field&#xff0c;简称MRF&#xff09;是一种用于描述变量之间依赖关系的概率模型&#xff0c;它在机器学习和图像处理等领域有着广泛的应用 文章目录 引言一、马尔科夫随机场1.1 定义1.2 特点1.3 应用1.4 学习算法1.5 总结 二、…

【数据分析预备】Pandas

Pandas 构建在NumPy之上&#xff0c;继承了NumPy高性能的数组计算功能&#xff0c;同时提供更多复杂精细的数据处理功能 安装 pip install pandas导入 import pandas as pdSeries 键值对列表 # 创建Series s1 pd.Series([5, 17, 3, 26, 31]) s10 5 1 17 2 3 3 26 4 31 dt…