打印机打印字符串转字节数组截取半个中文导致的乱码问题

Posted 短暂的火光

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了打印机打印字符串转字节数组截取半个中文导致的乱码问题相关的知识,希望对你有一定的参考价值。

    打印机打印的时候  要求:打印一行文字,但这行文字实际长度 len(单位是:px)是固定的 

  这时候我们的思路是  :GBK编码下汉字占用两个字节,而且这两个字节都是负数,char型字符占用一个字节,

       每个汉字占用的宽度是24px   每个char型占用的宽度是12px    换言之每个字节占用的打印宽度是12px

                             本行所容纳的字节个数 num=len / 12

   这时候我们将字符串转为字节数组  截取num个字节放到字节数组,然后转为字符串就是该行打印的字符串

但是有个问题就是 当我们截取的最后一个字节是汉字的一半(汉字由2个字节组成) 这个时候就会出现乱码,怎么破?

其实很简单  统计这num个字节中值为负数 的个数 如果是偶数说明没有截取半个汉字的情况出现,

    如果是奇数说明有半个汉字的情况出现

 这里有个重点  将字符串转换为字节数组时要转为GBK编码 的字节数组   因为 在GBK编码下汉字占用两个字节,而且都是负数,方便统计

            String str="双节棍爱好友h为太原";
  
            byte[]source=str.getBytes("GBK");                    

 

  public boolean isHasHalfChiness(byte[] source){
        int count=0;
        for (int i = 0; i < source.length; i++) {
            if(source[i]<0){
                count++;
            }
        }
        return count%2 == 0 ? false : true;
    }

遇到有半个汉字的情况就不截取最后一个字节就OK了  然后其他的另起一行打印什么的就不用说了

大家遇到打印机这方面问题的可以找我交流,共同学习进步!

          严禁盗版    

   转载请注明出处:https://www.cnblogs.com/bimingcong/p/9185587.html

 

以上是关于打印机打印字符串转字节数组截取半个中文导致的乱码问题的主要内容,如果未能解决你的问题,请参考以下文章

截取字节数组形式的字符串,串中包含中文

go 字符串乱码和不可打印

docx4j word转PDF的乱码问题怎么解决,求!!

BASE64解码之中文乱码问题

截取字符串

delphi 如何不出乱码的截取字符串?