Java开发知识之Java字符串类
Java开发知识之Java字符串类
一丶简介
任何语言中.字符串都是很重要的.都涉及到字符串的处理. 例如C++中. 字符串使用内存. 并提供相应的函数进行处理 strcmp strcat strcpy....等等
Java中也有字符串处理.不过Java是面相对象的.也就是说字符串是一个对象. 我们需要的字符串都是以类来进行管理的.
二丶String类
Java中的字符串管理类是String类.
1.声明一个字符串
类型 标识符;
String str;
String是一个字符串类型 str是一个变量.由标识符组成.
2.创建一个字符串.
String是一个类.有自己的构造方法. 我们说过.字符串是类进行管理的.所有有自己的构造方法. 至于什么是构造.我们暂且
可以理解为类中的一个方法.
2.1构造创建字符串
char a[] = {'a','b'}; //定义一个字符串数组.里面存储ab
String str = new String(a); new创建对象的意思. 创建一个对象.填写a. 则
str就是 "ab"
等价于:
String str = new String("ab");
2.2 类中方法.截取字符串创建.
什么是截取. 就是说我从哪里开始构造这个字符串
String的一个构造方法 String (char a[],int offset,int length);
参数1: 一个字符串数组
参数2: 传入一个偏移位置;
参数3: 截取数据多大.
使用:
char a[] = {'H','E','L','','L','O'};
String str = new String(a,2,4);
str 的值就是 LLO 因为我们从第二项开始.总大小为4个. 0-4个.就是5个.涉及到数组知识
注意: 下标从0开始.学数组就知道了.否则这里容易搞蒙.明明是2. 应该从E开始 等价写法:
String str = new String("LLO");
2.3直接字符串赋值,字符串常量赋值
String str1,str2;
str1 = "We are Students";
str2 = "We are Students";
如果是C++中的话.我们的=就要进行运算符重载了.运算符重载里面使用strcat来拼接. 所幸Java没有运算符重载了.
所以我们直接使用即可.
此时Str1 与 Str2引用了相同的字符串常量.

三丶字符串操作之字符串的连接
字符串的声明以及定义我们已经回了.但是如何让两个字符串合在一起使用那. C++中可以使用strcat命令进行拼接. Java中如何使用?
1.使用 + 运算符进行连接
+运算符模式给我们运算符重载了.可以这样理解.
String str1= new String("Hello");
String Str2 = new String("World");
String Str3 = Str1 + Str2;
小技巧:
Java中的字符串不能分开写.你如果想分为两行.可以使用 + 运算符
System.out.println("Hello
World"); 错误写法.分开行了.
正确写法:
System.out.println("Hello" +
"World");
两个都变成字符串.使用+ 相连
2.字符串与其他数据类型相连接
字符串可以与其它任意数据相连接.连接后变成字符串.
例如:
int nValue = 10;
String str = new String("Hello"):
str = str + 10; System.out.println(str);
输出结果:
Hello10
四丶字符串操作之获取字符串信息
1.获取字符串长度
字符串是一个类.这个类封装了方法.length() 返回字符串的长度
String str = "Hello:
int nLength = str.length();
2.字符串的查找
字符串查找有两种方法.
2.1 Indeof(String s) 返回一个给定的S字符串首次出现的位置.
str.indexOf(字符串)
str 任意字符串对象
字符串: 搜多的字符串. String str = "We are students"
int nSize = str.indexOf("a"); 返回a字符串首次出现的位置.
nSize 结果是3
理解索引位置:
String使用数组来表示的,我们上面赋值的字符串在内存那种就是下图的形式.

2..2 从后往前查找 lastIndexOf(SerchStr)
String str = "We are Students";
int nsize = str.lastIndexOf("t");
nsize = 13; 如果没找到返回字符串长度 跟str.length()返回值一样 indexOf 没找到也返回-1
3.获取指定位置的字符
charAt() 方法.
str.charAt(int index): 传入索引.返回指定索引位置的字符.
五丶字符串跟子字符串
1字字符串获取
有的时候我们需要获取子字符串. 就是一个字符串里面.我们需要获取一段.
String 类中的方法 substring(int BeginIndex):
给定一个索引.截取从指定索引到字符串结尾的字符串.
String str = "HelloWorld";
String str2 = str.substring(4);
str2 的值 是 oWorld
还有一个方法是指定一段
substring(int Beginindex,int endIndex);
给定起始位置跟结束位置.截取其中的字符串.
2.去除空格
String类中的 trim()方法
str.trim();
String str = "Hello World";
String str2 = str.trim();
str2的内容是 "HelloWorld"
3.字符串替换
有的时候我们要替换一下其中的字符. 我们可以用 replace方法
str.replace(char oldChar,char newChar);
String str = "HelloWorld";
String newstr = str.replace("H","h");
将H换成h重新赋值给newstr
4.字符串的开始跟结束判断
我们可以判断字符串的开始是什么.结束是什么.
startsWith(String s); endsWiths(String s);
String str = "Hello";
if (str.startsWith("Hello"))
{
....
}
判断开始字符串是否是Hello. endsWiths相反.
两者的返回值: boolean 真或者假
5.字符串比较.比较字符串是否相等.
5.1 字符串比较
错误的写法:
String str1 = "Hello"'
String str2 = "World";
boolean b = (boolean)(str1 == str2);
因为两个都是对象.如果是C++的话那就就是指针.也就是说.Java是引用跟C++一样.直接比较是比较的地址.两者的地址.并不是字符串比较.
比较有专门的方法.
equals(String 字符串);
正确写法
String str1 = "Hello";
String str2 = "World";
boolean b = str1.equals(str2);
equals比较默认是区分大小写的.
不区分大小写
equalsIgnoreCase(String str)方法.
5.2字典顺序比较
java中有按照字典顺序. 字典顺序就是按照首字母 A-Z排列.
compareTo(String str)
String str1 = "a";
String str2 = "c";
String str3 = "b";
System.out.println(str3.compareTo(str1); str3跟str1比较
结果:
a:1
6.字符串大小写转换
str.toLowerCase();讲字符串转为小写. 返回新的字符串.
str.toUpperCase() 转为大写.返回新的字符串
7.字符串的分割
split(String sign,int Limit)
sign: 分割字符串的分隔符,也可以是正则表达式.
limit: 限制的分割次数.
例子:
String str = "192.168.0.1";
//按照 点 分割
String[] Array = str.split("\\.");
分割结果
Array: 192 168 0 1
8.格式化字符
format(格式化字符串,...可变参数);
String str = "";
String str2 = str.format("%d",10);
符号是%d就是10进制. 10就是将这个数值格式化到字符串当中了.
返回一个新的字符串.
str2的值为 10
常规转换符

Java开发知识之Java字符串类的更多相关文章
- Java开发知识之Java的数字处理类Math类
Java开发知识之Java的数字处理类Math类 一丶Java.text.DecimalFormat类与NumberFormat类 首先 Java.text.DecimalFormat指的是Decim ...
- Java开发知识之Java类的高级特性,内部类.以及包使用.跟常量关键字
Java开发知识之Java类的高级特性,内部类.以及包使用.跟常量关键字 一丶Java中包的机制 首先包其实就是个文件夹.作用就是管理类. Java中每次定义一个类的时候.通过Java编译之后.都会生 ...
- Java开发知识之Java中的Map结构
Java开发知识之Java中的Map结构 一丶Map接口 Map没有实现Collection接口,提供的是Key 到Value的映射. Map中.不能包含相同的Key,每个Key只能映射一个Value ...
- Java开发知识之Java中的集合Set接口以及子类应用
---恢复内容开始--- Java开发知识之Java中的集合Set接口以及子类应用 一丶Set接口以及作用 在上一讲.我们熟悉了接口的实现图.以及自己各有的子类. List接口主要存储的数据是可以重复 ...
- Java开发知识之Java的继承多态跟接口*
Java开发知识之Java的继承多态跟接口 一丶继承 1.继承的写法 在Java中继承的 关键字是 extends 代表一个类继承另一个类. 继承的含义以及作用: 继承就是基于某个父类的扩展.制定出来 ...
- Java开发知识之Java的包装类
Java开发知识之Java的包装类 一丶什么是包装类 包装类的意思就是对基本数据类型封装成一个类.这些类都是Number的子类.区别就是封装数据类型不同.包含的方法基本相同. 具体可以查询JAVA A ...
- Java开发知识之Java面相对象
Java开发知识之Java面相对象上 一丶什么是面相对象 了解什么什么是面相对象.那么首先要了解什么是面相过程. 面相过程的意思就是. 什么事情都亲力亲为. 比如上一讲的排序算法. 我们自己写的. 这 ...
- Java开发知识之Java编程基础
Java开发知识之Java编程基础 一丶Java的基础语法 每个语言都有自己的语法规范.例如C++ 入口点是main. 我们按照特定格式编写即可. Java也不例外. Java程序的语法规范就是 Ja ...
- Java开发知识之Java入门
Java开发知识之Java入门 一丶了解JAVA的版本 JAVA 有三个版本 JAVA SE: 标准版,开发桌面跟商务应用程序 JAVA SE 包括了Java的核心类库,集合,IO 数据库连接 以及网 ...
随机推荐
- [CF1093E]Intersection of Permutations
[CF1093E]Intersection of Permutations 题目大意: 给定两个长度为\(n(n\le2\times10^5)\)的排列\(A,B\).\(m(m\le2\times1 ...
- vue插件官方文档,做个记录
vue的插件,组件都可以按照这种方式添加 官方文档 https://cn.vuejs.org/v2/guide/plugins.html 做个记录用
- 洛谷p3799:妖梦切木棒
题意:任选四段木板拼正三角形 因为是正三角形 所以我们可以想到至少是两个相同的,剩下两个拼成最后一条边 我们只需要枚举边长即可 那么我们对每次读入的x,使他的cnt++ 考虑用一个二重循环 外层枚举边 ...
- 非vue-cli的花括号闪现问题
<div id="app" v-cloak></div>[v-cloak] { display: none;}这种方式可以解决网速较慢,vue.js文件还没 ...
- 【类与对象】--------java基础学习第六天
类与对象 1. 对于面向对象的开发来讲也分为三个过程: OOA(面向对象分析) OOD(面向对象设计) OOP(面向对象编程) 2. 面向对象的基本特征 2.1. 封装:保护内部操作(属性,方法)不被 ...
- docker container(容器)
docker 容器 Docker容器类似于一个轻量级的沙箱,Docker利用容器来运行和隔离应用 容器是从镜像创建的应用运行实例.它可以启动,开始,停止,删除,而这些容器都是彼此相互隔离,互不可见的. ...
- Jenkins在shell脚本运行docker权限报错解决
报错环境 系统信息 Distributor ID: Ubuntu Description: Ubuntu 16.04.1 LTS Release: 16.04 Codename: xenial doc ...
- [Swift]LeetCode86. 分隔链表 | Partition List
Given a linked list and a value x, partition it such that all nodes less than x come before nodes gr ...
- [Swift]LeetCode203. 移除链表元素 | Remove Linked List Elements
Remove all elements from a linked list of integers that have value val. Example: Input: 1->2-> ...
- [Swift]LeetCode1031. 两个非重叠子数组的最大和 | Maximum Sum of Two Non-Overlapping Subarrays
Given an array A of non-negative integers, return the maximum sum of elements in two non-overlapping ...