系统运维系列之java中需要转义的特殊字符(代码片段)

琅晓琳 琅晓琳     2023-03-24     555

关键词:

在Java中,不管是String.split(),还是正则表达式,有一些特殊字符需要转义,这些字符是:

(    [         /    ^    -    $     ¦        ]    )    ?    *    +    . 

转义方法为字符前面加上"\\",这样在split、replaceAll时则不会报错;

//replace和replaceAll区别:
//replace的参数是char和CharSequence,既可以支持字符替换,也可以支持字符串替换;
//replaceall参数是regex, replacement,regex表示是正则表达式。
//如:
String str = "123ABC";
String str1 = str.replace("A", "a");
//将数字替换成a
String str2 = str.replaceAll("\\\\d", "a");

//java中的正则表达式
//java.util.regex 包主要包括以下三个类
//	Pattern 类:
//		pattern 对象是一个正则表达式的编译表示;
//		Pattern 类没有公共构造方法;
//		要创建一个 Pattern 对象,必须首先调用其公共静态编译方法,它返回一个 Pattern 对象;该方法接受一个正则表达式作为它的第一个参数。
//	Matcher 类:
//		Matcher 对象是对输入字符串进行解释和匹配操作的引擎;
//		与Pattern 类一样,Matcher 也没有公共构造方法;
//		需要调用 Pattern 对象的 matcher 方法来获得一个 Matcher 对象。
//	PatternSyntaxException:
//		PatternSyntaxException 是一个非强制异常类,它表示一个正则表达式模式中的语法错误。

import java.util.regex.*;
class RegexExample1
   public static void main(String[] args)
      String content = "I am noob " +
        "from runoob.com.";
      String pattern = ".*runoob.*";
      boolean isMatch = Pattern.matches(pattern, content);
      System.out.println("字符串中是否包含了 'runoob' 子字符串? " + isMatch);
   

//如:
\\d			数字字符匹配。等效于 [0-9]。
\\D			非数字字符匹配。等效于 [^0-9]。
\\f			换页符匹配。等效于 \\x0c 和 \\cL。
\\n			换行符匹配。等效于 \\x0a 和 \\cJ。
\\s			匹配任何空白字符,包括空格、制表符、换页符等。与 [ \\f\\n\\r\\t\\v] 等效。
\\S			匹配任何非空白字符。与 [^ \\f\\n\\r\\t\\v] 等效。
\\t			制表符匹配。与 \\x09 和 \\cI 等效。
\\v			垂直制表符匹配。与 \\x0b 和 \\cK 等效。

不过要注意,String.contains()方法不需要转义。

//contains()方法参数是CharSequence,而split()方法参数是String,需要手动转义。
String.contains(CharSequence s);
String.split(String regex);

参考资料:
https://www.cnblogs.com/interdrp/p/11979707.html java中需要转义的特殊字符
https://www.runoob.com/java/java-regular-expressions.html Java 正则表达式
https://blog.csdn.net/couragehope/article/details/86589646 Java String的contains()和split()方法区别:参数字符是否要转义

系统运维系列之linux系统下常用查找命令整理(代码片段)

1前言网上关于linux命令大多写的很细很全,但是真正使用起来需要根据自己的场景进行拼接,本博客建立在实际场景下,在实际问题中使用linux查找命令。2grep命令使用场景:查找日志中的关键词,并且限定时... 查看详情

系统运维系列之堆栈理解(java应用)(代码片段)

1概述java虚拟机内存分为:堆(heap)、栈(stack)、方法区(methodarea)等,整体来说:堆:new出来的数组或者对象;栈:存储局部变量;方法区:代码区;寄存器࿱ 查看详情

系统运维系列之kafka手动设置offset(经典方法总结)(代码片段)

1问题背景在使用Kafka消费数据过程中,消费程序可能出现运行问题,导致消费不及时,消息堆积很多;尤其是消息消费后需要进行一列后处理,这种情况下就需要考虑一些方法来进行消费参数的设置。2举例测... 查看详情

系统运维系列之socket和serversocket的简单介绍(java应用)

Socket类代表一个客户端套接字,即任何时候连接到一个远程服务器应用时构建所需的socket。现在,要实现一个服务器应用,需要不同的做法。服务器需随时待命,因为不知道客户端什么时候会发来请求,此时&#... 查看详情

系统运维系列之java中实现多线程的方式补充

1介绍接本专题博客之系统运维系列之java中实现多线程的方式上篇博客提到多线程使用的4种方式,分别是:实现方式1:继承Thread类,重写该类的run方法;实现方式2:实现Runnable接口,并重写该接口的run... 查看详情

系统运维系列之clickhouse数据类型整理

Clickhouse支持的数据类型在system.data_type_families表中检查数据类型名称以及是否区分大小写,这个表中存储了ClickHouse支持的所有数据类型。select*fromsystem.data_type_familieslimit10;Int说明ClickHouse中整形分为Int8、Int16、Int32、Int64来表示... 查看详情

自动化运维系列之ansible命令应用基础(模块的应用)持续更新中···(代码片段)

自动化运维系列之Ansible命令应用基础(模块的应用)模块简介Ansible可以使用命令行方式进行自动化管理,基本语法如下:ansible<host-pattern>[-mmodule_name][-aargs]<host-pattern>对哪些主机生效[-mmodule_name]需要使用的模块[-aargs]模块... 查看详情

系统运维系列之mysql部分学习整理1

1前言本部分对于MySQL数据库工作机制及其语法做一个整理,用于之后重点内容的查询和交流。2包含内容数据库工作机制、语法基础、重要内容整理、语句优化、效率提升等。3MySQL的字段约束3.1其中AUTO_INCREMENT必须和PRIMARYKEY一... 查看详情

自动化运维系列之ansible的简介与安装持续更新···(代码片段)

自动化运维系列之Ansible的简介与安装自动化运维工具简介由于互联网的快速发展导致产品更新换代的速度逐渐加快,这就导致运维人员的日常工作会大大增加,如果还是按照传统方式进行维护工作会使工作效率低下。此时,就... 查看详情

系统运维系列之mysql部分学习整理5(代码片段)

1应用场景在mysql数据库中查找数据,要求是数据为日期不连续数据,输入一个日期查询日期所在周指定周几的数据和上几周对应时间段数据(一个月内)。关于此问题网上资料未曾有明确的解决方案,本篇博... 查看详情

系统运维系列之ip地址和子网划分介绍(代码片段)

1简介接上一篇博客:关于A类,B类,C类IP地址的网段和主机数的计算方法2详细内容(1)子网掩码IP地址是以网络号和主机号来标示网络上的主机的,我们把网络号相同的主机称之为本地网络,网络号不相同的主... 查看详情

系统运维系列之mysql联合索引的使用分析(代码片段)

1前言日常优化中可能会遇到相同的数据在本地执行很快但是在服务器上执行很慢的问题,或者无论是在本地还是在服务器上都执行的很慢,可以分为两个方面排查2第一部分本地执行速度>服务器执行速度一般这种情况... 查看详情

系统运维系列之异常抛出后代码执行问题(java应用)

1问题描述thrownewExcpetion()之后,程序并没有向下继续运行,抛出异常后直接跳出,后面的功能不再执行。//抛出异常:Exceptioninthread"main"java.lang.NumberFormatException//不会执行后面的输出语句publicstaticvoidmain(String[]args) S... 查看详情

系统运维系列之list实现深拷贝(java应用)

浅拷贝调用方法:遍历循环复制:List<String>destList=newArrayList<String>(srcList.size());for(Stringp:srcList)destList.add(p);使用list.addAll()方法:List<String>destList=newAr 查看详情

系统运维系列之mysql部分学习整理2

1字符函数使用举例:CONCAT_WS相比于CONCAT可以简化语句SELECTCONCAT(id,’-’,age)ASpathFROMuser;SELECTCONCAT_WS(’-’,id,age)ASpathFROMuser;SELECTFORMAT(id,3)ASnumFROMuser;SELECTLEFT(‘abcdef’,2);—>ab举例:SELECT 查看详情

系统运维系列之mysql部分学习整理3

1存储过程语法结构:举例:无参CREATEPROCEDUREsql()SELECTVERSION();调用:CALLsql();有参IN:DELIMITER//(更改执行符号的命令)参数与语句中的字段不要重复,不要重复!如果p_id改成id,则会全部删除࿰... 查看详情

系统运维系列之csv文件读取时内容中包含逗号的处理方法(代码片段)

问题描述:CSV文件默认逗号分隔,但是如果在内容中包含逗号,则会导致分隔失败或者数组下标匹配越界的问题。处理方法:(1)正则表达式//(?=pattern)//非获取匹配,正向肯定预查,在任何匹配... 查看详情

系统运维系列之csv文件读取时内容中包含逗号的处理方法(代码片段)

问题描述:CSV文件默认逗号分隔,但是如果在内容中包含逗号,则会导致分隔失败或者数组下标匹配越界的问题。处理方法:(1)正则表达式//(?=pattern)//非获取匹配,正向肯定预查,在任何匹配... 查看详情