java 将二进制转化为汉字?
将二进制转化为汉字?
1. 从原理上讲,二进制可以通过先将二进制转换为十六进制,再利用十六进制与汉字的对应关系来转换为汉字。2C版本的代码如下:private string binarytochinese(string input){StringBuilder sb=new StringBuilder()//create string int numobytes=输入长度/8//计算尾数byte[]bytes=新字节[numofbytes]//二进制(int i=0 inumobytes i){字节[i]=转换为字节( 输入子字符串(8*I,8),2) //将字符串转换为相应的二进制}返回系统文本编码. Unicode.GetString(bytes)//解码获取汉字}
Java中如何把图片转换成二进制流?
使用Java IO流读取二进制图片
示例:将图片作为二进制流读取并写入其他图片
static void testcopyimage(){T/tfile source=new file(“E:share wallpaper布利斯.jpg“” 文件台=新建文件(“d:images”) if(!desk.exists存在()){ desk.mkdir文件() } try{ FileInputStream inputStream=new FileInputStream(源) FileOutputStream outputStream=new FileOutputStream(新文件(”d:/images/布利斯.jpg“”) 颜色=inputStream.read文件() 时间(ch!=-1){ outputStream.write文件(信道) ch=inputStream.read文件() } inputStream.关闭() outputStream.close文件() 系统输出打印(图片复制成功!“” }catch(FileNotFoundException e){ 系统输出打印(”文件不存在:”e.getmessage())T/T}catch(IOException e){T/T} 系统输出打印(“文件读取错误:”e.getmessage())T/T}T/T}
编码GBK(“GB2312”)时,一个汉字对应两个字节,编码uft8时(“UTF-8”),编码uft8时,一个汉字对应三个字节:Qstring STR=“middle”qtextcodec*code=qtextcodec::codeforname(“UTF-8”)//uft8编码qbytearray Ba=code->fromucode(STR)for(int i=0I)<ba.计数()i){=“”unsigned=“”char=“”temp=“”temp=”文学学士(i) “qdebug()$amp=”“}=”打印出“middle”的三个代码:文学学士(i) =“228”228=“”转换为二进制:11100100=“”184=“”转换为二进制:10111000=“”173=“”转换为二进制时:10101101=”>
GBK(“GB2312”)编码,一个汉字对应两个字节,uft8(“UTF-8”)编码,一个汉字对应三个字节,uft8编码:qstringstr=“middle”qtextcodec*code=qtextcodec::codeforname(“UTF-8”)//uft8编码qbytearrayba=code->fromunicode(STR)for(inti=0I)<ba.计数()i){无符号ChartEmptEmp=文学学士(i) Qdebug()$amp}打印出“middle”的三个代码,如下所示:文学学士(i) =228文学学士(i) =184文学学士(i) =173228至二进制:11100100184到二进制:10111000173到二进制:10101101
1。InputStream和OutputStream是为字节流设计的,主要用于处理字节或二进制对象。Reader和Two用于字符流(一个字符占用两个字节),主要用于处理字符或字符串。
字符流处理单元为两字节Unicode字符,分别操作字符、字符数组或字符串,字节流处理单元为一字节,操作字节和字节数组。因此,字符流是由Java虚拟机将字节转换成2字节Unicode字符形成的,因此它对多国语言有更好的支持!对于音频文件、图片和歌曲,最好使用字节流。如果与中文(文本)相关,最好使用字符流
所有文件都以字节为单位存储。磁盘上保留的不是文件的字符,而是字符被编码成字节,然后这些字节被存储在磁盘上。当读取文件(尤其是文本文件)时,它也是逐字节读取,形成字节序列
1。字节流可以用于任何类型的对象,包括二进制对象,而字符流只能处理字符或字符串
版权声明:本文内容由互联网用户自发贡献,本站不承担相关法律责任.如有侵权/违法内容,本站将立刻删除。