Java基础篇--字符串处理(StringBuffer)
字符串处理
在Java中最常将字符串作为String类型对象来处理。同时String中也提供了很多操作字符串的函数(可自行查阅资料),而本篇将介绍StringBuffer如何操作字符串。
StringBuffer是使用缓冲区的,本身也是操作字符串的,但与String类不同,String类中的内容一旦声明之后不可改变,改变的只是其内存地址的指向,而StringBuffer中的内容是可以改变的,
对于StringBuffer而言,本身是一个具体的操作类,所以不能像String那样采用直接赋值的方式进行对象实例化,必须通过构造方法完成。
StringBuffer连接字符操作
- 当一个字符串的内容需要被经常改变时就要使用StringBuffer
- 在StringBuffer中使用append()方法,完成字符串的连接操作
实例操作一:字符串连接操作(append)
代码:
package 字符串处理;
public class StringBufferDemo01{
public static void main(String args[]){
StringBuffer buf = new StringBuffer() ; // 声明StringBuffer对象
buf.append("Hello ") ; // 向StringBuffer中添加内容
buf.append("World").append("!!!") ; // 可以连续调用append()方法
buf.append("\n") ; // 添加一个转义字符
buf.append("数字 = ").append(1).append("\n") ; // 添加数字
buf.append("字符 = ").append('C').append("\n"); // 添加字符
buf.append("布尔 = ").append(true) ; // 添加布尔值
System.out.println(buf) ; // 直接输出对象,调用toString()
}
};
打印结果:
Hello World!!!
数字 = 1
字符 = C
布尔 = true
实例操作二:字符串添加内容(insert)
public class StringBufferDemo03{
public static void main(String args[]){
StringBuffer buf = new StringBuffer() ; // 声明StringBuffer对象
buf.append("World!!") ; // 添加内容
buf.insert(0,"Hello ") ; // 在第一个内容之前添加内容
System.out.println(buf) ;
buf.insert(buf.length(),"偶my耶~") ; // 在最后添加内容
System.out.println(buf) ;
}
};
打印内容
Hello World!!
Hello World!!偶my耶~
实例操作三:字符串反转(reverse)
package 字符串处理;
public class StringBufferDemo04{
public static void main(String args[]){
StringBuffer buf = new StringBuffer() ; // 声明StringBuffer对象
buf.append("World!!") ; // 添加内容
buf.insert(0,"Hello ") ; // 在第一个内容之前添加内容
String str = buf.reverse().toString() ; // 将内容反转后变为String类型
System.out.println(str) ; // 将内容输出
}
};
打印内容:
!!dlroW olleH
实例操作四:替换字符串指定内容(replace)
public class StringBufferDemo05{
public static void main(String args[]){
StringBuffer buf = new StringBuffer() ; // 声明StringBuffer对象
buf.append("Hello ").append("World!!") ; // 向StringBuffer添加内容
buf.replace(6,11,"偶my耶") ; // 将world的内容替换
System.out.println("内容替换之后的结果:" + buf) ; // 输出内容
}
};
打印内容:
内容替换之后的结果:Hello 偶my耶!!
实例操作五:字符串截取(substring,delete)
package 字符串处理;
public class StringBufferDemo06{
public static void main(String args[]){
StringBuffer buf = new StringBuffer() ; // 声明StringBuffer对象
buf.append("Hello ").append("World!!") ; // 向StringBuffer添加内容
buf.replace(6,11,"偶my耶") ; // 将world的内容替换
String str = buf.substring(6,11) ; // 截取指定范围的内容
// String str = buf.delete(6,11).toString() ;// 删除指定范围中的内容
System.out.println(buf);
System.out.println("内容替换之后的结果:" + str) ; // 输出内容
}
};
打印结果
Hello 偶my耶!!
内容替换之后的结果:偶my耶!
实例操作六:查找指定内容(indexOf)
package 字符串处理;
public class StringBufferDemo08{
public static void main(String args[]){
StringBuffer buf = new StringBuffer() ; // 声明StringBuffer对象
buf.append("Hello ").append("World!!") ; // 向StringBuffer添加内容
if(buf.indexOf("Hello")==-1){
System.out.println("没有查找到指定的内容") ;
}else{ // 不为01表示查找到内容
System.out.println("可以查找到指定的内容") ;
}
}
};
打印内容
可以查找到指定的内容
在StringBuffer中还有许多的函数就不一一介绍了!想要更深去了解可查阅相关资料,
下面介绍一个使用String和StringBuffer来操作字符串的案列
案列之小写金额变大写金额
package com.lh.bean; import java.io.BufferedReader;
import java.io.IOException;
import java.io.InputStreamReader; public class StringUtil {
private String money; //转换之前的数字金额
private String submoneyCN[]={"","拾","佰","仟"}; //表示数字位数的数组
private String numberCNN[]={"零","壹","贰","叁","肆","伍","陆","柒","捌","玖"}; //大写数字的数组
private String je="零壹贰叁肆伍陆柒捌玖"; //大写的数字(0-9)
private String cdw="万仟佰拾亿仟佰拾万仟佰拾元角分"; //金额单位
public StringUtil(){} //默认的构造方法
public void setMoney(String money){
this.money=money;
}
public String getMoney(){
return convert(this.money); }
/**
* 转换数字金额为大写金额
* @return 返回转换后的大写金额
*/
public String convert(String money){
String formatCN="";
int point=money.indexOf("."); //判断字符串是否包含小数点
if(point!=-1){
String money1=money.substring(0,point); //小数点之前的部分
String money1_1=(new StringBuffer(money1).reverse()).toString();//字符串倒序
String money2=money.substring(point+1); //小数点之后的部分
if(money2.length()<2){ //如果小数点后的部分少于两位,用"0"补齐
if(money2.length()==0)
money2="00";
else
money2+="0";
}
else //如果小数点后的位数大于2位,则只前2位
money2=money.substring(point+1,point+3);
int len = money1_1.length(); //字符串反转之后,小数点之前的字符位数
int pos=len-1;
String sigle="";
boolean allhavenum=false;
boolean havenum=false;
boolean mark=false; //设置一个开关变量,若当前数为"0",将该值设为true;不为"0"时设为false
/**以下代码为读出小数点左面的部分*/
while(pos>=0){
sigle=money1_1.substring(pos,pos+1);//截取1位数字,比如数字1234.56,将左侧的字符串反转,值为4321,则截取的值为1 /**读取“亿单元”的代码。
* 假设读取10024531042.34。
* 小数点左面反转后为:24013542001
* pos的初始值为10
* mark的初始值为false
* havenum的初始值为false
* */
if(pos>=8&&pos<12){
if(!sigle.equals("0")){ //如果当前值不为"0"
if(!mark){ //如果当前值的前一位数不为"0"
formatCN+=numberCNN[Integer.parseInt(sigle)]+submoneyCN[pos%4];
}
else{ //如果当前值不为"0",但该值的前一位数为"0"
if(allhavenum){ //如果在当前值之前有不为"0"的数字出现。该条件用来处理用户输入的如:0012.34的数值
formatCN+="零";
}
formatCN+=numberCNN[Integer.parseInt(sigle)]+submoneyCN[pos%4];
mark=false;
}
havenum=true;
allhavenum=true; //变量allhavenum表示小数点左面的数中是否有不为"0"的数字;true表示有,false表示无
}
else{ //如果当前值为"0"
mark=true;
}
if(pos%4==0&&havenum){ //如果当前数字为该单元的最后一位,并且该单元中有不为"0"的数字出现
formatCN+="亿";
havenum=false;
}
}
/**读取“万单元”的代码*/
if(pos>=4&&pos<8){
if(!sigle.equals("0")){
if(!mark)
formatCN+=numberCNN[Integer.parseInt(sigle)]+submoneyCN[pos%4];
else{
if(allhavenum){
formatCN+="零";
}
formatCN+=numberCNN[Integer.parseInt(sigle)]+submoneyCN[pos%4];
mark=false;
}
havenum=true;
allhavenum=true;
}
else{
mark=true;
}
if(pos%4==0&&havenum){
formatCN+="万";
havenum=false;
}
}
/**读取“个、十、百、千”的代码*/
if(pos>=0&&pos<4){
if(!sigle.equals("0")){
if(!mark)
formatCN+=numberCNN[Integer.parseInt(sigle)]+submoneyCN[pos%4];
else{
if(allhavenum){
formatCN+="零";
}
formatCN+=numberCNN[Integer.parseInt(sigle)]+submoneyCN[pos%4];
mark=false;
}
havenum=true;
allhavenum=true;
}
else{
mark=true;
}
}
pos--;
}
/**碰到小数点时的读法*/
if(allhavenum) //如:00.34就不能读为:元3角4分.变量allhavenum表示小数点左面的内容中是否有数字出现
formatCN+="元";
else //如果小数点左面的部分都为0如:00.34应读为:零元3角4分
formatCN="零元";
/**以下代码为读出小数点右面的部分 */
if(money2.equals("00"))
formatCN+="整";
else{
/**读出角,如120.34读为:1佰2拾元零3角4分;123.04读为:1佰2拾3元零4分*/
if(money2.startsWith("0")||(allhavenum&&money1.endsWith("0"))){
formatCN+="零";
}
if(!money2.startsWith("0")){
formatCN+=numberCNN[Integer.parseInt(money2.substring(0,1))]+"角";
}
//读出分,如:12.30读1拾2元3角零分
formatCN+=numberCNN[Integer.parseInt(money2.substring(1))]+"分";
}
}
else{
formatCN="输入的格式不正确!格式:888.00";
}
return formatCN;
}
public static void main(String[] args) throws IOException {
System.out.println("输入要转换的金钱:");
BufferedReader br=new BufferedReader(new InputStreamReader(System.in));
String money = br.readLine();
StringUtil SU= new StringUtil();
System.out.println(SU.convert(money));
}
}
Java基础篇--字符串处理(StringBuffer)的更多相关文章
- JAVA基础篇—String和StringBuffer
区别: (1)String类对象为不可变对象,一旦你修改了String对象的值,隐性重新创建了一个新的对象,释放原String对象,StringBuffer类对象为可修改对象,可以通过append() ...
- 小白—职场之Java基础篇
java基础篇 java基础 目录 1.java是一种什么语言,jdk,jre,jvm三者的区别 2.java 1.5之后的三大版本 3.java跨平台及其原理 4.java 语言的特点 5.什么是字 ...
- java基础篇---I/O技术
java基础篇---I/O技术 对于任何程序设计语言而言,输入输出(I/O)系统都是比较复杂的而且还是比较核心的.在java.io.包中提供了相关的API. java中流的概念划分 流的方向: 输 ...
- java基础篇---I/O技术(三)
接上一篇java基础篇---I/O技术(二) Java对象的序列化和反序列化 什么叫对象的序列化和反序列化 要想完成对象的输入或输出,还必须依靠对象输出流(ObjectOutputStream)和对象 ...
- Java基础之String、StringBuffer、StringBuilder浅析
Java基础之String.StringBuffer.StringBuilder浅析 一.前言: 位于java.lang包下的String.StringBuilder.StringBuffer一般都是 ...
- java基础篇1
JAVA基础篇1 注释 单行注释 //这是一个单行注释,由两个斜杠组成,不能嵌套多行注释 多行注释 /*这是一个 多行注释 ,//里面不能嵌套多行注释, 但是可以嵌套单行注释*/ 文档注释 /**ja ...
- Java基础篇(JVM)——字节码详解
这是Java基础篇(JVM)的第一篇文章,本来想先说说Java类加载机制的,后来想想,JVM的作用是加载编译器编译好的字节码,并解释成机器码,那么首先应该了解字节码,然后再谈加载字节码的类加载机制似乎 ...
- 金三银四跳槽季,BAT美团滴滴java面试大纲(带答案版)之一:Java基础篇
Java基础篇: 题记:本系列文章,会尽量模拟面试现场对话情景, 用口语而非书面语 ,采用问答形式来展现.另外每一个问题都附上“延伸”,这部分内容是帮助小伙伴们更深的理解一些底层细节的补充,在面试中可 ...
- java基础篇---HTTP协议
java基础篇---HTTP协议 HTTP协议一直是自己的薄弱点,也没抽太多时间去看这方面的内容,今天兴致来了就在网上搜了下关于http协议,发现有园友写了一篇非常好的博文,博文地址:(http: ...
随机推荐
- jstree中文github文档
jstree Bala...bala...这段就不翻译了. jstree就是个基于JQUERY的树形控件. 1 2 jsTree is jquery plugin, that provides int ...
- php mysql procedure获取多个结果集
protected function getRs($id) { $db = new mysqli(C("DB_HOST"), C("DB_USER"), C(& ...
- cucumber_java从入门到精通(5)使用maven创建cucumber_java项目
cucumber java从入门到精通(5)使用maven创建cucumber java项目 前几节我们已经在感性上认识了cucumber的基本功能以及BDD测试的基本流程,我们渐进重构,一步一步的向 ...
- apache Tomcat配置SSL(https)步骤
Tomcat配置https 1 生成Server端安全证书 要实现通信加密,首先要在本地准备一份符合X.509标准的Server端安全证书.如果有条件的话,可以向权威CA申请一份经过认证的安 ...
- 转: springboot2.0下hystrix.stream 404
springboot2.0下hystrix dashboard Unable to connect to Command Metric Stream解决办法https://blog.csdn.net/ ...
- nginx 读取文件 permission denied
nginx 是在root用户下安装的,静态网页的目录/var/www/html/ 目录下的内容所有者也是root 用户,按照 nginx配置文件中location说明 配置静态文件访问地址. 使用网址 ...
- Android App开发技能图谱(转载)
操作系统 Windows/MacOSX/Linux 编程语言 Java HTML/JS (Hybrid/Web App) C/C++ (NDK) SQL (DB) Kotlin 开发工具 IDE An ...
- Android adb 命令速查表
常用命令 devices # 查看已连接的设备 start-server # 启动 adb server kill-server # 停止 adb server logcat # 查看日志 insta ...
- 绑定sql server数据库的用户与登录名
服务器重装系统,重新安装上sql server,附加上以前的数据库, 然后以前是每个数据库都有一个登录用于操作该数据库,其他数据库不能操作的, 附加上数据库后该数据库安全性里的用户能看到以前建立好的用 ...
- CSS中字体响应式的设置
在进行页面响应式设计中,往往需要根据屏幕分辨率来显示不同大小的字体.通常的做法是通过media queries给不同的分辨率指定不同的字体样式,例如: body { font-size: 22px; ...