用Java实现按字节长度截取字符串的方法

简介: 本文为原创,如需转载,请注明作者和出处,谢谢!   Web应用程序在浏览器中显示字符串时,由于显示长度的限制,常常需要将字符串截取后再进行显示。
本文为原创,如需转载,请注明作者和出处,谢谢!

  Web应用程序在浏览器中显示字符串时,由于显示长度的限制,常常需要将字符串截取后再进行显示。但目前很多流行的语言,如C#、Java内部采用的都是 Unicode 16(UCS2)编码,在这种编码中所有的字符都是两个字符,因此,如果要截取的字符串是中、英文、数字混合的,就会产生问题,如下面的字符串:

String s  =   " a加b等于c,如果a等1、b等于2,那么c等3 " ;

  上面的字符串既有汉字,又有英文字符和数字。如果要截取前6个字节的字符,应该是”a加b等",但如果用substring方法截取前6个字符就成了"a 加b等于c"。产生这个问题的原因是将substring方法将双字节的汉字当成一个字节的字符(UCS2字符)处理了。 要解决这个问题的方法是首先得到该字符串的UCS2编码的字节数组,如下面的代码如下:

byte [] bytes  =  s.getBytes( " Unicode " );

    由于上面生成的字节数组中前两个字节是标志位,bytes[0] = -2,bytes[1] = -1,因此,要从第三个字节开始扫描,对于一个英文或数字字符,UCS2编码的第二个字节是相应的ASCII,第一个字节是0,如a的UCS2编码是0  97,而汉字两个字节都不为0,因此,可以利于UCS2编码的这个规则来计算实际的字节数,该方法的实现代码如下:

     public   static  String bSubstring(String s,  int  length)  throws  Exception
    {

        
byte [] bytes  =  s.getBytes( " Unicode " );
        
int  n  =   0 //  表示当前的字节数
         int  i  =   2 //  要截取的字节数 ,从第3个字节开始
         for  (; i  <  bytes.length  &&  n  <  length; i ++ )
        {
            
//  奇数位置,如3、5、7等,为UCS2编码中两个字节的第二个字节
             if  (i  %   2   ==   1 )
            {
                n
++ //  在UCS2第二个字节时n加1
            }
            
else
            {
                
//  当UCS2编码的第一个字节不等于0时,该UCS2字符为汉字,一个汉字算两个字节
                 if  (bytes[i]  !=   0 )
                {
                    n
++ ;
                }
            }
        }
        
//  如果i为奇数时,处理成偶数
         if  (i  %   2   ==   1 )

        {
            
//  该UCS2字符是汉字时,去掉这个截一半的汉字
             if  (bytes[i - 1]  !=   0 )
                i 
=  i  -   1 ;
            
//  该UCS2字符是字母或数字,则保留该字符
             else
                i 
=  i  +   1 ;
        }

        
return   new  String(bytes,  0 , i,  " Unicode " );
    }

    下面代码使用了bSubstring方法:

String s  =   " a加b等于c,如果a等1、b等于2,那么c等3 " ;
System.out.println(bSubstring(s,
6 ));

    上面的代码截取的字符串是 "a加b等 "


国内最棒的Google Android技术社区(eoeandroid),欢迎访问!

《银河系列原创教程》发布

《Java Web开发速学宝典》出版,欢迎定购

目录
相关文章
|
22小时前
|
Java 编译器 C语言
【一步一步了解Java系列】:Java中的方法对标C语言中的函数
【一步一步了解Java系列】:Java中的方法对标C语言中的函数
10 3
|
21小时前
|
Java 编译器
在Java中,关于final、static关键字与方法的重写和继承【易错点】
在Java中,关于final、static关键字与方法的重写和继承【易错点】
14 5
|
21小时前
|
Java
JAVA易错点详解(数据类型转换、字符串与运算符)
JAVA易错点详解(数据类型转换、字符串与运算符)
10 4
|
1天前
|
Java 开发者
Java“类 Y 中的方法 X 不能应用于给定类型”解决
在Java中遇到“类Y中的方法X无法应用于给定类型”的错误时,通常是因为方法调用时的参数类型与定义不符。解决此问题需检查方法签名,确保传递的参数类型正确无误,或使用显式类型转换以匹配方法所需的参数类型。这种错误提示帮助开发者及时修正类型不匹配的问题。
|
1天前
|
Java 编译器
Java“无效的方法声明;需求返回类型”怎解决
要解决Java中的“无效的方法声明;需要返回类型”错误,需为方法指定正确的返回类型。检查方法签名,添加如`void`、`int`、`String`等类型,并确保方法体内正确使用`return`语句。这能帮助Java编译器理解和验证方法的行为。遵守这些规则,可以避免语法错误并确保程序正常运行。
|
5月前
|
存储 XML 缓存
Java字符串内幕:String、StringBuffer和StringBuilder的奥秘
Java字符串内幕:String、StringBuffer和StringBuilder的奥秘
59 0
|
2月前
|
安全 Java API
【Java字符串操作秘籍】StringBuffer与StringBuilder的终极对决!
【8月更文挑战第25天】在Java中处理字符串时,经常需要修改字符串,但由于`String`对象的不可变性,频繁修改会导致内存浪费和性能下降。为此,Java提供了`StringBuffer`和`StringBuilder`两个类来操作可变字符串序列。`StringBuffer`是线程安全的,适用于多线程环境,但性能略低;`StringBuilder`非线程安全,但在单线程环境中性能更优。两者基本用法相似,通过`append`等方法构建和修改字符串。
48 1
|
2月前
|
API C# 开发者
WPF图形绘制大师指南:GDI+与Direct2D完美融合,带你玩转高性能图形处理秘籍!
【8月更文挑战第31天】GDI+与Direct2D的结合为WPF图形绘制提供了强大的工具集。通过合理地使用这两种技术,开发者可以创造出性能优异且视觉效果丰富的WPF应用程序。在实际应用中,开发者应根据项目需求和技术背景,权衡利弊,选择最合适的技术方案。
62 0
|
2月前
|
存储 Java
|
5月前
|
存储 Java
Java基础复习(DayThree):字符串基础与StringBuffer、StringBuilder源码研究
Java基础复习(DayThree):字符串基础与StringBuffer、StringBuilder源码研究
Java基础复习(DayThree):字符串基础与StringBuffer、StringBuilder源码研究