Java面试常用函数

news2024/11/24 17:15:34

1. charAt() 方法用于返回字符串指定索引处的字符。索引范围为从 0 到 length() - 1。

map.getOrDefault(num, 0) :如果map存在num这个key,则返回num对应的value,否则返回0.

 Arrays.sort(nums); 数组排序

Arrays.asList("a","b","c");;该方法是将数组转化成List集合的方法。

s.toCharArray();将字符串中的字符转换为字符数组. 

new String(ch)  将数组转化为字符串。

str.trim().split(" ");//将字符串先去掉头尾的空格,再按照“ ”分割。

Arrays.toString(strIn) 数组转字符串

2. 求字符串长度   s.length();

求数组长度:s.length;

集合长度:size()

3.集合

1.总体结构:

接口:Collection/List/Set/Map

实现类:Arraylist/LinkedList/HashSet/TreeSet/HashMap/TreeMap

2.Collection 集合

3.List集合

  • List集合的概述

    • 有序集合,这里的有序指的是存取顺序

    • 用户可以精确控制列表中每个元素的插入位置,用户可以通过整数索引访问元素,并搜索列表中的元素

    • 与Set集合不同,列表通常允许重复的元素

  • List集合的特点

    • 存取有序

    • 可以重复

    • 有索引

List集合的实现类

  • ArrayList集合

    底层是数组结构实现,查询快、增删慢

  • LinkedList集合

    底层是链表结构实现,查询慢、增删快

  • LinkedList集合的特有功能

3.创建hashset(集合):

Set<Integer> set1 = new HashSet<>()
set1.add(i)//添加元素
if (set1.contains(i)) //判断是否包含i
set.size() #hashset的大小

4.创建比较

//List
List<String> list = new ArrayList<>();
//二维数组
List<List<Integer>> result = new ArrayList<>();

//二维数组添加元素
result.add(Arrays.asList(nums[i], nums[left], nums[right]))


//LinkedList
LinkedList<String> list = new LinkedList<>();

//Set
Set<String> set = new TreeSet<>();
//TreeSet
TreeSet<Integer> ts = new TreeSet<Integer>();
//HashSet
HashSet<String> set = new HashSet<String>();

//Map
Map<String,String> map = new HashMap<String,String>();
//HashMap
HashMap<Student, String> hm = new HashMap<Student, String>()
//TreeMap
TreeMap<Student,String> tm = new TreeMap<>();

5.遍历比较

List
普通for循环
//size方法跟get方法还有循环结合的方式,利用索引获取到集合中的每一个元素
for (int i = 0; i < list.size(); i++) { 
         String s = list.get(i);
         System.out.println(s);
        }

Set
//Set集合是没有索引的,所以不能使用通过索引获取元素的方法
不能用for (int i = 0; i < set.size(); i++) {
//            
//        }

        for (String s : set) {
            System.out.println(s);
        }


TreeSet
        for(Integer i : ts) {
            System.out.println(i);
        }

HashSet
        for(String s : set) {
            System.out.println(s);
        }


Map
方法一:
        //获取所有键的集合。用keySet()方法实现
        Set<String> keySet = map.keySet();
        //遍历键的集合,获取到每一个键。用增强for实现
        for (String key : keySet) {
            //根据键去找值。用get(Object key)方法实现
            String value = map.get(key);
            System.out.println(key + "," + value);
        }

方法二:
        //获取所有键值对对象的集合
        Set<Map.Entry<String, String>> entrySet = map.entrySet();
        //遍历键值对对象的集合,得到每一个键值对对象
        for (Map.Entry<String, String> me : entrySet) {
            //根据键值对对象获取键和值
            String key = me.getKey();
            String value = me.getValue();
            System.out.println(key + "," + value);
        }

HashMap
        //遍历集合
        Set<Student> keySet = hm.keySet();
        for (Student key : keySet) {
            String value = hm.get(key);
            System.out.println(key.getName() + "," + key.getAge() + "," + value);
        }




6.字符串操作

  • s.erase(pos,n);
    删除从pos开始的n个字符,比如erase(0,1)就是删除第一个字符

  • 字符串长度   s.length();

  • 1char charAt(int index)
    返回指定索引处的 char 值。
    2int compareTo(Object o)
    把这个字符串和另一个对象比较。
    3int compareTo(String anotherString)
    按字典顺序比较两个字符串。
    4int compareToIgnoreCase(String str)
    按字典顺序比较两个字符串,不考虑大小写。
    5String concat(String str)
    将指定字符串连接到此字符串的结尾。
    6boolean contentEquals(StringBuffer sb)
    当且仅当字符串与指定的StringBuffer有相同顺序的字符时候返回真。
    7static String copyValueOf(char[] data)
    返回指定数组中表示该字符序列的 String。
    8static String copyValueOf(char[] data, int offset, int count)
    返回指定数组中表示该字符序列的 String。
    9boolean endsWith(String suffix)
    测试此字符串是否以指定的后缀结束。
    10boolean equals(Object anObject)
    将此字符串与指定的对象比较。
    11boolean equalsIgnoreCase(String anotherString)
    将此 String 与另一个 String 比较,不考虑大小写。
    12byte[] getBytes()
     使用平台的默认字符集将此 String 编码为 byte 序列,并将结果存储到一个新的 byte 数组中。
    13byte[] getBytes(String charsetName)
    使用指定的字符集将此 String 编码为 byte 序列,并将结果存储到一个新的 byte 数组中。
    14void getChars(int srcBegin, int srcEnd, char[] dst, int dstBegin)
    将字符从此字符串复制到目标字符数组。
    15int hashCode()
    返回此字符串的哈希码。
    16int indexOf(int ch)
    返回指定字符在此字符串中第一次出现处的索引。
    17int indexOf(int ch, int fromIndex)
    返回在此字符串中第一次出现指定字符处的索引,从指定的索引开始搜索。
    18int indexOf(String str)
     返回指定子字符串在此字符串中第一次出现处的索引。
    19int indexOf(String str, int fromIndex)
    返回指定子字符串在此字符串中第一次出现处的索引,从指定的索引开始。
    20String intern()
     返回字符串对象的规范化表示形式。
    21int lastIndexOf(int ch)
     返回指定字符在此字符串中最后一次出现处的索引。
    22int lastIndexOf(int ch, int fromIndex)
    返回指定字符在此字符串中最后一次出现处的索引,从指定的索引处开始进行反向搜索。
    23int lastIndexOf(String str)
    返回指定子字符串在此字符串中最右边出现处的索引。
    24int lastIndexOf(String str, int fromIndex)
     返回指定子字符串在此字符串中最后一次出现处的索引,从指定的索引开始反向搜索。
    25int length()
    返回此字符串的长度。
    26boolean matches(String regex)
    告知此字符串是否匹配给定的正则表达式。
    27boolean regionMatches(boolean ignoreCase, int toffset, String other, int ooffset, int len)
    测试两个字符串区域是否相等。
    28boolean regionMatches(int toffset, String other, int ooffset, int len)
    测试两个字符串区域是否相等。
    29String replace(char oldChar, char newChar)
    返回一个新的字符串,它是通过用 newChar 替换此字符串中出现的所有 oldChar 得到的。
    30String replaceAll(String regex, String replacement)
    使用给定的 replacement 替换此字符串所有匹配给定的正则表达式的子字符串。
    31String replaceFirst(String regex, String replacement)
     使用给定的 replacement 替换此字符串匹配给定的正则表达式的第一个子字符串。
    32String[] split(String regex)
    根据给定正则表达式的匹配拆分此字符串。
    33String[] split(String regex, int limit)
    根据匹配给定的正则表达式来拆分此字符串。
    34boolean startsWith(String prefix)
    测试此字符串是否以指定的前缀开始。
    35boolean startsWith(String prefix, int toffset)
    测试此字符串从指定索引开始的子字符串是否以指定前缀开始。
    36CharSequence subSequence(int beginIndex, int endIndex)
     返回一个新的字符序列,它是此序列的一个子序列。
    37String substring(int beginIndex)
    返回一个新的字符串,它是此字符串的一个子字符串。
    38String substring(int beginIndex, int endIndex)
    返回一个新字符串,它是此字符串的一个子字符串。
    39char[] toCharArray()
    将此字符串转换为一个新的字符数组。
    40String toLowerCase()
    使用默认语言环境的规则将此 String 中的所有字符都转换为小写。
    41String toLowerCase(Locale locale)
     使用给定 Locale 的规则将此 String 中的所有字符都转换为小写。
    42String toString()
     返回此对象本身(它已经是一个字符串!)。
    43String toUpperCase()
    使用默认语言环境的规则将此 String 中的所有字符都转换为大写。
    44String toUpperCase(Locale locale)
    使用给定 Locale 的规则将此 String 中的所有字符都转换为大写。
    45String trim()
    返回字符串的副本,忽略前导空白和尾部空白。
    46static String valueOf(primitive data type x)
    返回给定data type类型x参数的字符串表示形式。
    47contains(CharSequence chars)
    判断是否包含指定的字符系列。
    48isEmpty()
    判断字符串是否为空。

6.类型转换

万能法则

import java.util.Scanner;

public class myScanner {
    Scanner sc = new Scanner(System.in);
    public static void main(String[] args) {
        int a=1;
        String b;
        char c;

        b=String.valueOf(a);//int转字符串
        a=Integer.valueOf(b);//字符串转int
        c=b.charAt(0);//字符串转字符
        b=String.valueOf(c);//字符转字符串
        
//字符和int的转换 只需要用过字符串即可。
        
        
    }
}

6.1数字、字符串相互转换

// 数字转字符串 method1
		int number = 5;
		String str = String.valueOf(number);
		System.out.println(str);

// 数字转字符串 method2
		int number = 5;
		Integer itr = number;  //int装箱为对象,再调用对象的toString方法
		String str = itr.toString(); //或者直接 String str = Integer.toString(number);
		System.out.println(str);

// 数字转字符串 method3
		int number = 5;
		String str = number + "";
		System.out.println(str);
// 字符串转数字
		String str = "123";
		int number = Integer.parseInt(str);		
		System.out.println(number);

6.2 字符、字符串相互转换

//字符转字符串 method 1
		char ch = '5';
		String str = String.valueOf(ch);
		System.out.println(str);

//字符转字符串 method 2
		char ch = '5';
		String str = ch + "";
		System.out.println(str);	
// 字符串转字符
		// 其实这里也算不上转换了,只是获取对应位置上字符
		String str = "123";
		char ch = str.charAt(0); //这里获取到的字符为1
		System.out.println(ch);

6.3 数字、字符相互转换

// 数字转字符
		// 不能直接转换,如下图。因此需借助数字转字符串。
		// 首先将数字转为字符串,再获取字符
		int number = 5; //注意这里数字只能是个位数并且不能为负
		String temp = Integer.toString(number);
		char ch = temp.charAt(0);
		System.out.println("数字转字符:"+ch);
// 字符转数字
		// 先把字符转为字符串,再转换为数字
		char ch = '5';
		String temp = String.valueOf(ch);
		int a = Integer.parseInt(temp);
		System.out.println(a);
		//或者
		int a = ch - '0';


6.4 字符数组转字符串

String newStr = new String(charArray, 0, charArray.length);

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

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

相关文章

SpringMVC中的JSR303与拦截器的使用

一&#xff0c;JSR303的概念 JSR303是Java中的一个标准&#xff0c;用于验证和校验JavaBean对象的属性的合法性。它提供了一组用于定义验证规则的注解&#xff0c;如NotNull、Min、Max等。在Spring MVC中&#xff0c;可以使用JSR303注解对请求参数进行校验。 1.2 为什么要使用J…

2023年墨西哥 SP/BMV IPC 研究报告

第一章 指数概况 1.1 指数基本情况 墨西哥 S&P/BMV IPC 指数衡量在墨西哥证券交易所 (Bolsa Mexicana de Valores, BMV)上市&#xff0c;规模最大、流动性最高的股票表现。提供一个覆盖墨西哥股市的广泛、具有代表性且可轻易复制的指数。根据多元化要求&#xff0c;按市值…

Redis哨兵Cluster群集 搭建

Redis群集 Redis群集有三种模式 主从同步/复制哨兵模式Cluster群集 主从同步/复制 概念 主从复制是高可用Redis的基础&#xff0c;哨兵和集群都是在主从复制基础上实现高可用的。主从复制主要实现了数据的多机备份&#xff0c;以及对于读操作的负载均衡和简单的故障恢复缺陷…

ENVI_IDL: 基础语法详解

01 题目 02 代码说明 题目本身很简单&#xff0c;但是我自己加了一些东西进去增加难度。主要包括print函数的封装、格式化字符串&#xff0c;但是不影响代码的阅读。&#xff08;注&#xff1a;对于没有语言基础的人而言相对阅读困难&#xff0c;但是由于IDL是解释型语言&…

文字点选验证码识别(下)-训练一个孪生神经网络模型

声明 本文以教学为基准、本文提供的可操作性不得用于任何商业用途和违法违规场景。 本人对任何原因在使用本人中提供的代码和策略时可能对用户自己或他人造成的任何形式的损失和伤害不承担责任。 如有侵权,请联系我进行删除。 文章中没有代码,只有过程思路,请大家谨慎订阅。…

Windows下的Elasticsearch-head安装

Windows下的Elasticsearch-head安装 参考&#xff1a;https://gitcode.net/mirrors/mobz/elasticsearch-head 需要用到 npm 命令&#xff0c;这里可以提前下载安装下Node.js 即可自动安装npm&#xff1b; Node.js 下载安装地址&#xff1a;https://nodejs.org/en/download # 进…

【Unity每日一记】音频,麦克风,粒子和拖尾渲染器

&#x1f468;‍&#x1f4bb;个人主页&#xff1a;元宇宙-秩沅 &#x1f468;‍&#x1f4bb; hallo 欢迎 点赞&#x1f44d; 收藏⭐ 留言&#x1f4dd; 加关注✅! &#x1f468;‍&#x1f4bb; 本文由 秩沅 原创 &#x1f468;‍&#x1f4bb; 收录于专栏&#xff1a;Uni…

LCD1602液晶显示屏介绍和程序开发

1.LCD1602概述 LCD1602&#xff08;Liquid Crystal Display&#xff09;是一种工业字符型液晶&#xff0c;能够同时显示 1602 即 32 字符(16列两行) 引脚说明第 1 脚: VSS 为电源地第 2 脚: VDD 接 5V 正电源第 3 脚: VL 为液晶显示器对比度调整端,接正电源时对比度最弱&…

华为云云耀云服务器L实例评测| ultralytics最先进模型YOLOv8深度学习AI训练

目录 前言 登录服务器 安装pyhton 部署yolov8 安装Pytorch 下载权重文件 训练模型 前言 前几期我们在云耀云服务器L实例上分别使用docker和直接在centos上部署了yolov5识别API&#xff0c;前端项目vue&#xff0c;后端项目.net Core Web Api,但是从监控图上来看&#…

联网汽车和网络犯罪:入门

正在权衡如何投资预算的原始设备供应商 ( OEM ) 及其供应商可能倾向于放慢应对网络威胁的投资。迄今为止&#xff0c;他们遇到的攻击仍然相对简单&#xff0c;危害性也不是特别大。 然而&#xff0c;对地下犯罪信息交换中的聊天记录的分析表明&#xff0c;这些碎片的存在是为了…

html5学习笔记22-JavaScript 简略学习

https://www.runoob.com/js/js-tutorial.html JavaScript 是 Web 的编程语言。与java无关。 案例&#xff1a;https://c.runoob.com/examples/ JavaScript 是一种轻量级的编程语言、可插入 HTML 页面的编程代码、脚本语言。 ECMA-262 是 JavaScript 标准的官方名称。 HTML 中的…

房地产小程序 | 小程序赋能,房地产业务数字化升级

随着科技的不断发展&#xff0c;房地产行业正逐渐向数字化转型。在这个过程中&#xff0c;房地产小程序成为了一种重要的工具&#xff0c;可以帮助房地产企业提供更好的购房体验、增加销售额&#xff0c;并实现管理的便捷化。 优点 便捷购房体验&#xff1a;房地产小程序为用户…

vite + react + typescript + uni-app + node 开发一个生态系统

简介 使用 vite react typescript uni-app node 来开发一个简易的生态系统案例&#xff0c;包含 APP&#xff0c;H5&#xff0c;微信小程序&#xff0c;控制台&#xff0c;服务端 开发 admin 技术栈&#xff1a;vite react typescript初始化控制台项目选择自定义预设…

快速傅里叶变化

引言 目标 傅里叶变化&#xff08;Fourier transform&#xff09;是一种信号处理技术&#xff0c;它可以将时间信号转换为频率信号&#xff0c;即将一组具有相同数量频率的正弦波叠加在一起&#xff0c;形成一组新的正弦波。如果我们把时间信号从频域转换到时域&#xff0c;那么…

手搭手入门MybaitsX

Mybatis-Plus介绍 为简化开发而生 MyBatis-Plus(opens new window)&#xff08;简称 MP&#xff09;是一个 MyBatis(opens new window) 的增强工具&#xff0c;在 MyBatis 的基础上只做增强不做改变&#xff0c;为简化开发、提高效率而生。 特性 无侵入&#xff1a;只做增强…

2022年全国研究生数学建模竞赛华为杯C题汽车制造涂装-总装缓存调序区调度优化问题求解全过程文档及程序

2022年全国研究生数学建模竞赛华为杯 C题 汽车制造涂装-总装缓存调序区调度优化问题 原题再现&#xff1a; 背景介绍   汽车制造厂主要由焊装车间、涂装车间、总装车间构成&#xff0c;每个车间有不同的生产偏好&#xff0c;如&#xff1a;焊装车间由于车身夹具的限制偏向最…

【C语言】指针的“最后一站”【进阶版】

欢迎各位看官^_^ 目录 1、字符指针 2、指针数组 3、数组指针 3.1数组指针的定义 3.2数组指针的使用 4、数组指针和指针数组的区别 5、数组参数&#xff0c;指针参数 5.1数组参数定义 5.2指针参数定义 5.3一维数组传参 5.4二维数组传参 5.5一级指针传参 5.6二级指…

Matlab图像处理-彩色图像基础

光谱 在17世纪60年代&#xff0c;人们普遍认为白光是一种没有其他颜色的纯色光&#xff0c;而彩色光是有某种缘故发生变化的光。为了验证这个假设&#xff0c;牛顿让一束阳光通过一面三棱镜&#xff0c;光线在墙上被分解成了八种不同的颜色&#xff0c;即&#xff1a;红、橙、…

Unity SteamVR 开发教程:SteamVR Input 输入系统(2.x 以上版本)

文章目录 &#x1f4d5;前言&#x1f4d5;教程说明&#x1f4d5;导入 SteamVR 插件&#x1f4d5;SteamVR Input 窗口⭐action.json 文件⭐窗口面板⭐SteamVR_Input 目录 &#x1f4d5;SteamVR 动作的类型⭐Boolean⭐Single⭐Vector2⭐Vector3⭐Pose⭐Skeleton⭐Vibration &…

postgresql -数据库事务与并发控制

postgresql -数据库事务与并发控制 数据库事务事务控制语句并发与隔离数据库事务 事务控制语句 -- serial 自增 CREATE TABLE accounts(id serial PRIMARY KEY,user_name varchar(50),balance numeric