不解释,直接上代码: 

由于Iteye代码贴四个字节的UTF-8字符出错,特能图的方式发布几个特殊字符: 



  1. public class Byte4Check {
  2. public static void main(String args[]) throws UnsupportedEncodingException {
  3. String nickName = "12葫";
  4. , 1).getBytes("UTF-8");
  5. for (byte tt : t) {
  6. System.out.println(tt);
  7. }
  8. System.out.println("====================");
  9. byte[] t1 = nickName.getBytes("UTF-8");
  10. ; i < t1.length;) {
  11. byte tt = t1[i];
  12. if (CharUtils.isAscii((char) tt)) {
  13. ];
  14. ] = tt;
  15. i++;
  16. String result = new String(ba);
  17. System.out.println("1个字节的字符");
  18. System.out.println("字符为:" + result);
  19. }
  20. if ((tt & 0xE0) == 0xC0) {
  21. ];
  22. ] = tt;
  23. ] = t1[i+1];
  24. i++;
  25. i++;
  26. String result = new String(ba);
  27. System.out.println("2个字节的字符");
  28. System.out.println("字符为:" + result);
  29. }
  30. if ((tt & 0xF0) == 0xE0) {
  31. ];
  32. ] = tt;
  33. ] = t1[i+1];
  34. ] = t1[i+2];
  35. i++;
  36. i++;
  37. i++;
  38. String result = new String(ba);
  39. System.out.println("3个字节的字符");
  40. System.out.println("字符为:" + result);
  41. }
  42. if ((tt & 0xF8) == 0xF0) {
  43. ];
  44. ] = tt;
  45. ] = t1[i+1];
  46. ] = t1[i+2];
  47. ] = t1[i+3];
  48. i++;
  49. i++;
  50. i++;
  51. i++;
  52. String result = new String(ba);
  53. System.out.println("4个字节的字符");
  54. System.out.println("字符为:" + result);
  55. }
  56. }
  57. }
  58. }

参考文献: 

http://www.yunmx.com/archives/2011/138.htm 

http://zh.wikipedia.org/wiki/UTF-8

Java字符串找出4个字节长度的字符的更多相关文章

  1. js比较两个String字符串找出不同,并将不同处高亮显示

    根据java代码改写成js,下边js文件代码: function StringBuffer() { this.__strings__ = []; }; StringBuffer.prototype.a ...

  2. java字符串转义,把&lt;&gt;转换成<>等字符【原】

    java字符串转义,把<>转换成<>等字符 使用的是commons-lang3-3.4 中的StringEscapeUtils类 package test; import ja ...

  3. 用JAVA实现找出输入字符串中的出现次数最多的字符及其次数;

    //通过Map 类实现,通过键值对的方式,可以将输入的字符串的每一个字符,作为键,每个字符出现的次数作为值:如下: public class Find { public static void mai ...

  4. java语言 找出文章中出现次数最多的单词

    package english; import java.io.File; import java.util.Scanner; import java.io.FileNotFoundException ...

  5. Java/sql找出oracle数据库有空格的列

    1.java方式 String table_sql = "select table_name from user_tables";//所有用户表 List<String> ...

  6. java 的 数字、汉字 和 字母 的所占字节长度 与 字符长度 (邮件限制50个汉字)

    public static void main(String[] args) {  String a = "餿餿餿餿餿z";  byte[] bytes = a.getBytes( ...

  7. Java实现找出数组中重复次数最多的元素以及个数

    /**数组中元素重复最多的数 * @param array * @author shaobn * @param array */ public static void getMethod_4(int[ ...

  8. JAVA 练习 找出素数

    package com.zhang.hello; public class Task { /** * 1. 输出打印九九乘法表 * */ public void NO1(){ for(int i=1; ...

  9. OMG,12 个精致的 Java 字符串操作小技巧,学它

    字符串可以说是 Java 中最具有代表性的类了,似乎没有之一哈,这就好像直播界的李佳琪,脱口秀中的李诞,一等一的大哥地位.不得不承认,最近吐槽大会刷多了,脑子里全是那些段子,写文章都有点不由自主,真的 ...

随机推荐

  1. java jstack dump 线程 介绍 解释

    最近抽时间把JVM运行过程中产生的一些线程进行了整理,主要是围绕着我们系统jstack生成的文件为参照依据.  前段时间因为系统代码问题,造成性能到了天花板,于是就dump了一份stack出来进行分析 ...

  2. hdu3483之二项式展开+矩阵快速幂

    A Very Simple Problem Time Limit: 4000/2000 MS (Java/Others)    Memory Limit: 65536/32768 K (Java/Ot ...

  3. 达内TTS6.0课件basic_day05

  4. XML(三)

     使用 XSLT 显示 XML -------------------------------------------------------------------------------- 通 ...

  5. BZOJ 1854: [Scoi2010]游戏( 二分图最大匹配 )

    匈牙利算法..从1~10000依次找增广路, 找不到就停止, 输出答案. --------------------------------------------------------------- ...

  6. 实战 iTextSharp

    原文 实战 iTextSharp iTextSharp 是用来生成  PDF 的一个组件,在 1998 年夏天的时候,Bruno Lowagie ,iText 的创作者,参与了学校的一个项目,当时使用 ...

  7. JVM调优总结(三)-基本垃圾回收算法

    可以从不同的的角度去划分垃圾回收算法: 按照基本回收策略分 引用计数(Reference Counting): 比较古老的回收算法.原理是此对象有一个引用,即增加一个计数,删除一个引用则减少一个计数. ...

  8. Ext的异步请求(二级级联动态加载下拉列表)

    页面: <tr> <td class="label" width="300" >作业计划项模板</td> <td> ...

  9. 基于Andoird 4.2.2的Account Manager源代码分析学习:AccountManagerService系统服务的添加

    从启动说起 Android系统加载时,首先启动init进程,该进程会启动Zygote进程.Zygote进程执行/system/bin/app_process程序.app_process程序在执行中,通 ...

  10. STL--G - For Fans of Statistics(两个推断条件-二分)

    G - For Fans of Statistics Time Limit:1000MS     Memory Limit:65536KB     64bit IO Format:%I64d & ...