《转》 Java中byte类型变量做 0xff运算的理解

2024-01-02 16:32

本文主要是介绍《转》 Java中byte类型变量做 0xff运算的理解,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

=Java中byte类型变量做& 0xff运算的理解 
在IO字符操作或加密计算时经常会见到byte值与0xff做与运算,这种写法首次看到会有些不解,其实也比较容易理解。

下面说下我个人的理解

首先要明白,字符编码中没有负值表示一个字符的,至少我没有遇到过,可以看下ascii编码,全部都是使用正值表示字符的,例如65 
表示A。

其次要明白byte & 0xff 的位运算的意义 
在Java中byte类型变量的表示范围是: -128 ~ 127 ,是带符号的,即最高位的1表示负数,0表示正数。byte变量与0xff执行&运算后,就将byte的低8位数值截取出来了,其实byte二进制本来就8位,由于Java中默认是按照int来处理(记得大学时学习有这么一说,没严格确认过),这样运算后的效果简单说就是将符号位当作一般数字位来看待了。 
例如 -124用二进制表示就是”10000100”,如果将最高位的1看作一般数字位,那么数值就是132,这与int类型数值为132的二进制表示的低8位是一致的。

为什么要执行byte & 0xff? 
其实如果byte类型数字转int,long等类型,是不需要这样操作的,Java中会自动转换,做这种操作的情况,我认为有两种情况:

  1. 有符号数当作无符号数来看待;
  2. 要用十六进制表示的地方,如计算好哈希值后,将byte数组转换为十六进制的字符串。

为什么Java中用十六进制的地方可能会有byte & 0xff形式的运算呢? 
我认为Java中没有直接将二进制字符串表示为十六进制字符串的方法,导致大家要利用Integer.toHexString()这个方法来实现转换,很显然这个方法是Int变量才能用的,所以需要先转换为无符号的数值向上自动转型的int类型,即进行byte & 0xff运算。

下面的代码是将一个byte数组转为十六进制的字符串,提示一下如果byte的二进制表示的高4位是”0000”,就用”0”来填充,从数值上来说就是大于0小于16。

/*** 将byte数组转为十六进制字符串* @param byteArray* @return*/
public static String byteArrayToHexStr(byte[] byteArray){StringBuilder sb = new StringBuilder();for(byte b : byteArray){if(b >= 0 && b < 16){sb.append('0');}sb.append(Integer.toHexString(b & 0xff));}return sb.toString();
}

这篇关于《转》 Java中byte类型变量做 0xff运算的理解的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/563015

相关文章

JVM 的类初始化机制

前言 当你在 Java 程序中new对象时,有没有考虑过 JVM 是如何把静态的字节码(byte code)转化为运行时对象的呢,这个问题看似简单,但清楚的同学相信也不会太多,这篇文章首先介绍 JVM 类初始化的机制,然后给出几个易出错的实例来分析,帮助大家更好理解这个知识点。 JVM 将字节码转化为运行时对象分为三个阶段,分别是:loading 、Linking、initialization

Spring Security 基于表达式的权限控制

前言 spring security 3.0已经可以使用spring el表达式来控制授权,允许在表达式中使用复杂的布尔逻辑来控制访问的权限。 常见的表达式 Spring Security可用表达式对象的基类是SecurityExpressionRoot。 表达式描述hasRole([role])用户拥有制定的角色时返回true (Spring security默认会带有ROLE_前缀),去

浅析Spring Security认证过程

类图 为了方便理解Spring Security认证流程,特意画了如下的类图,包含相关的核心认证类 概述 核心验证器 AuthenticationManager 该对象提供了认证方法的入口,接收一个Authentiaton对象作为参数; public interface AuthenticationManager {Authentication authenticate(Authenti

Spring Security--Architecture Overview

1 核心组件 这一节主要介绍一些在Spring Security中常见且核心的Java类,它们之间的依赖,构建起了整个框架。想要理解整个架构,最起码得对这些类眼熟。 1.1 SecurityContextHolder SecurityContextHolder用于存储安全上下文(security context)的信息。当前操作的用户是谁,该用户是否已经被认证,他拥有哪些角色权限…这些都被保

Spring Security基于数据库验证流程详解

Spring Security 校验流程图 相关解释说明(认真看哦) AbstractAuthenticationProcessingFilter 抽象类 /*** 调用 #requiresAuthentication(HttpServletRequest, HttpServletResponse) 决定是否需要进行验证操作。* 如果需要验证,则会调用 #attemptAuthentica

Spring Security 从入门到进阶系列教程

Spring Security 入门系列 《保护 Web 应用的安全》 《Spring-Security-入门(一):登录与退出》 《Spring-Security-入门(二):基于数据库验证》 《Spring-Security-入门(三):密码加密》 《Spring-Security-入门(四):自定义-Filter》 《Spring-Security-入门(五):在 Sprin

Java架构师知识体认识

源码分析 常用设计模式 Proxy代理模式Factory工厂模式Singleton单例模式Delegate委派模式Strategy策略模式Prototype原型模式Template模板模式 Spring5 beans 接口实例化代理Bean操作 Context Ioc容器设计原理及高级特性Aop设计原理Factorybean与Beanfactory Transaction 声明式事物

Java进阶13讲__第12讲_1/2

多线程、线程池 1.  线程概念 1.1  什么是线程 1.2  线程的好处 2.   创建线程的三种方式 注意事项 2.1  继承Thread类 2.1.1 认识  2.1.2  编码实现  package cn.hdc.oop10.Thread;import org.slf4j.Logger;import org.slf4j.LoggerFactory

认识、理解、分类——acm之搜索

普通搜索方法有两种:1、广度优先搜索;2、深度优先搜索; 更多搜索方法: 3、双向广度优先搜索; 4、启发式搜索(包括A*算法等); 搜索通常会用到的知识点:状态压缩(位压缩,利用hash思想压缩)。

变量与命名

引言         在前两个课时中,我们已经了解了 Python 程序的基本结构,学习了如何正确地使用缩进来组织代码,并且知道了注释的重要性。现在我们将进一步深入到 Python 编程的核心——变量与命名。变量是我们存储数据的主要方式,而合理的命名则有助于提高代码的可读性和可维护性。 变量的概念与使用         在 Python 中,变量是一种用来存储数据值的标识符。创建变量很简单,