基本功能
Long 类在对象中包装了基本类型 long 的值
每个 Long 类型的对象都包含一个 long 类型的字段

static long MAX_VALUE long 8个字节
最大值2^63-1
十六进制:  0x8000000000000000L
static long MIN_VALUE 最小值-2^63
十六进制:
0x7fffffffffffffffL
static int SIZE
二进制补码形式表示值时的位数
@Native public static final int SIZE = 64; 8个字节就是64位

static Class<Long> TYPE 表示基本类型 long 的 Class 实例


方法分类

实例方法

构造方法
可以通过long或者String构造

字符串参数形式的方法,  内部调用parseLong
java.lang.Long.Long(long)
java.lang.Long.Long(String)
获取指定类型的值
直接返回强转形式

比如:
(byte)value   (short)value   ......
java.lang.Long.byteValue()
java.lang.Long.shortValue()
java.lang.Long.intValue()
java.lang.Long.longValue()
java.lang.Long.floatValue()
java.lang.Long.doubleValue()
对象常规方法
toString依赖静态方法 static String toString(long i)
hashCode 依赖静态方法 hashCode static int hashCode(long value)
equals 比较内部值是否相同

compareTo 依赖静态方法static int compare(long x, long y)
java.lang.Long.toString()
java.lang.Long.hashCode()
java.lang.Long.equals(Object)
java.lang.Long.compareTo(Long)
此系列都是获取指定系统属性的long值相关

第一个参数是通过 System.getProperty(java.lang.String) 方法可以访问到的系统属性的名称
以 long 值的形式解释此属性的字符串值,并返回表示此值的 Long 对象
也就是说参数String为一个系统属性的字符串名称
如果指定名称没有属性,或者指定名称为空或 null,抑或属性不具有正确的数字格式时,则返回 null

并不是转换解析字符串为Long,并不是转换解析字符串为Long,并不是转换解析字符串为Long,

java.lang.Long.getLong(String)
java.lang.Long.getLong(String, long)
java.lang.Long.getLong(String, Long)


由上面实例方法的依赖性也可以看得出来,Long类本身静态方法的强大

静态工具方法
toXXXString就是转换为String形式
具体的XXX是什么就是转换为 什么
toString(long, int)转换为指定进制表示的字符串形式,toString(long)为简化版默认十进制
toString(long)
toString(long, int)
toUnsignedString(long, int)转换为指定进制表示的无符号整数的字符串形式
toUnsignedString(long)为简化版默认十进制
toUnsignedString(long, int)
toUnsignedString(long)
以十六进制无符号整数形式返回 long 参数的字符串表示形式
以八进制无符号整数形式返回 long 参数的字符串表示形式
以二进制无符号整数形式返回 long 参数的字符串表示形式
toHexString(long)
toOctalString(long)
toBinaryString(long)
parseLong 都是将字符串解析为long,  基本类型!
parseLong(String, int)将 string 参数解析为第二个参数指定进制形式的有符号的 long
parseLong(String)为简化形式,默认十进制
parseUnsignedLong是parseLong的无符号形式
类似,双参数指定基数进制,单参数默认十进制
使用时需要注意,对应基数(进制)的转换,需要对应的字符,比如十进制你就不能出现十六进制的A
parseLong(String, int)
parseLong(String)
parseUnsignedLong(String, int)
parseUnsignedLong(String)
valueOf都是将字符串解析为Long,  包装类型
但是,在-128~127之间会使用缓存的值,不在范围内的创建新对象
所以,除非有必要特意创建对象,否则应该使用这个来获取Long对象
valueOf(String, int) 转换指定基数的字符串为Long,  valueOf(String)为他的十进制形式
valueOf(String, int)
valueOf(String)
valueOf(long)
hashCode(long)
对于基本类型long的求和 和 大小比较,返回符合条件的long
sum(long, long)
max(long, long)
min(long, long)

可以直接将指定形式的字符串进行解析 根据字符串的前缀进行自动匹配
然后,返回一个Long
decode(String)
比较大小与无符号比较大小

无符号的先转换下,然后调用compare
compare(long, long)
compareUnsigned(long, long)
无符号的商与求余
divideUnsigned(long, long)
remainderUnsigned(long, long)
返回符号
如果指定值为负,则返回值 -1
如果指定值为零,则返回 0
如果指定值为正,则返回 1
signum(long)
reverse表示翻转,翻转就是从前往后颠倒过来
逐个比特进行翻转 或者逐个字节(也就是8位为一个单位)进行翻转

看下图就很容易理解 
188的二进制 1011  1100
reverse(long)
reverseBytes(long)
rotate表示循环移位
循环左移和循环右移
移位负数距离等同于另一个方向的移位

rotateLeft(long, int)
rotateRight(long, int)
api解释比较抽象,直白的说就是二进制补码序列中
选择从左边开始数(高位)第一个1  或者从右边开始数(低位)第一个1
其余的位置全都写0
所以,对于highestOneBit
如果是0 返回0 ,因为没有一个1
如果是负数,返回的就是最左边一位是1 其余全都是0 也就是Long的最小值
如果是正数,第一位就是原来的最高位,但是抹掉了所有的零头,就是小于等于这个数的第一个2的N次方
对于highestOneBit 
如果是0 返回0
否则返回的将是2的N次方   形如1 ....n个零
highestOneBit(long)
lowestOneBit(long)
与highestOneBit  和 lowestOneBit,本质是互通的,找到了1的位置也就知道了0的个数
知道了0的个数,也就找到了1的位置
返回的是这两个位置的地方,左边和右边的零的个数

numberOfLeadingZeros(long)
numberOfTrailingZeros(long)
返回二进制补码形式下1的个数
bitCount(long)


特别注意:

value of 与new Long
valueOf就是根据指定的long或者String 返回一个Long对象

java.lang.Long.valueOf(long)是根本方法
可以看得出来,他会使用LongCache缓存256个对象(0~255)
静态内部类,使用的时候,static块中初始化

java.lang.Long.valueOf(String, int)是借助于parseLong进行转换
java.lang.Long.valueOf(String)是他的默认的十进制形式的

简言之就是最核心是valueOf(long),在指定范围内他是有缓存的,不在指定范围内,那么将会创建对象
所以,如果可以,尽量不要使用new Long

parseLong
从valueOf看得出来,带参数的借助的都是parseLong
parseLong是返回的long 基本数据类型,valueOf相当于他的装箱形式(当然,valueOf还有使用缓存数据的功能)

decode(String nm)

decode将字符串转换为Long,听起来好像跟valueOf 差不多
都是根据字符串转变为Long对象
但是ValueOf要么指定基数要么就是默认十进制,而且不认识0X.#这种形式
decode不需要指定基数,可以根据字符串的前缀进行自己判断基数,用起来比valueOf更加灵活


getLong
getLong根本就不是看起来的样子
java.lang.Long.getLong(String)
java.lang.Long.getLong(String, long)
java.lang.Long.getLong(String, Long)
他只是valueOf的一个非常小的子集,仅仅是字符串为系统属性的某个变量名时,才是可以用的 ,才是可以解析的
你传入getLong("16"),根本不行
 




JavaSE之Long 详解 Long的方法简介以及用法的更多相关文章

  1. 【初级】linux rm 命令详解及使用方法实战

    rm:删除命令 前言: windows中的删除命令大家都不陌生,linux中的删除命令和windows中有一个共同特点,那就是危险,前两篇linux mkdir 命令详解及使用方法实战[初级]中我们就 ...

  2. 【初级】linux pwd 命令详解及使用方法实战

    pwd:查看当前工作目录 前言: Linux中用 pwd 命令来查看”当前工作目录“的完整路径,就是经常提及的所在目录,多用在生产环境多级目录中查看当前所在路径,使用此命令能给运维人员/操作人员带来很 ...

  3. 【初级】linux mkdir 命令详解及使用方法实战

    mkdir命令详解及使用方法实战 名称 MKDIR 是 make directories 的缩写 使用方法 mkdir [选项(如-p)] ...目录名称(及子目录注意用分隔符隔开)...    如使 ...

  4. ThinkPHP函数详解:session方法

    ThinkPHP函数详解:session方法 Session方法用于Session 设置.获取.删除和管理操作. Session 用于Session 设置.获取.删除和管理操作 用法    sessi ...

  5. PHP开发中常见的安全问题详解和解决方法(如Sql注入、CSRF、Xss、CC等

    页面导航: 首页 → 网络编程 → PHP编程 → php技巧 → 正文内容 PHP安全 PHP开发中常见的安全问题详解和解决方法(如Sql注入.CSRF.Xss.CC等) 作者: 字体:[增加 减小 ...

  6. 转:JAVAWEB开发之权限管理(二)——shiro入门详解以及使用方法、shiro认证与shiro授权

    原文地址:JAVAWEB开发之权限管理(二)——shiro入门详解以及使用方法.shiro认证与shiro授权 以下是部分内容,具体见原文. shiro介绍 什么是shiro shiro是Apache ...

  7. tomcat常用配置详解和优化方法

    tomcat常用配置详解和优化方法 参考: http://blog.csdn.net/zj52hm/article/details/51980194 http://blog.csdn.net/wuli ...

  8. RabbitMQ详解(一)------简介与安装(Docker)

    RABBITMQ详解(一)------简介与安装(DOCKER) 刚刚进入实习,在学习过程中没有接触过MQ,RabbitMQ 这个消息中间件,正好公司最近的项目中有用到,学习了解一下. 首先什么是MQ ...

  9. 官网实例详解-目录和实例简介-keras学习笔记四

    官网实例详解-目录和实例简介-keras学习笔记四 2018-06-11 10:36:18 wyx100 阅读数 4193更多 分类专栏: 人工智能 python 深度学习 keras   版权声明: ...

随机推荐

  1. 利用jquery-barcode.js实现生成条形码

    jquery-barcode官网 js下载地址-github 代码示范(官网上也有) <!DOCTYPE html> <html> <head> <meta ...

  2. JQuery模拟常见的拖拽验证

    css部分 <style> #drag{ position: relative; background-color: #e8e8e8; width: 300px; height: 34px ...

  3. using Sysyem.Net.Http命名空间引用不了的解决方案

    1.查看.Net Framework的框架是否是在4.5之上,如果不是要下载4.5之上的目标框架. 2.在引用器里面添加using System.Net.Http命名空间 选择项目列表中的“引用”-- ...

  4. Tensor基本操作

    Tensor(张量) 1.Tensor,又名张量,从工程角度来说,可简单地认为它就是一个数组,且支持高效的科学计算.它可以是一个数(标量).一维数组(向量).二维数组(矩阵)或更高维的数组(高阶数组) ...

  5. mysql学习2

    1.视图 视图是一个虚拟表(非真实存在),其本质是[根据sql语句获取动态的数据集,并为其命名],用户使用时只需要使用[名称]即可获取结果集,并可以将其当作表来使用. 搜索临时表 SELECT * F ...

  6. c++实验二

    1.函数重载编程练习编写重载函数add(),实现对int型,double型,Complex型数据的加法 #include<iostream> using namespace std; st ...

  7. html+css手机端自动适应

    <meta name="viewport" content="width=device-width, initial-scale=1.0, minimum-scal ...

  8. 将本地jar包打包到本地仓库和上传到私服

    1.本地jar打包到本地仓库 mvn install:install-file -Dfile=jar包完整地址或相对地址 -DgroupId=自定义的groupID -DartifactId=自定义的 ...

  9. EF Oracle:错误 175

    错误 1 错误 175: 具有固定名称“Oracle.DataAccess.Client”的 ADO.NET 提供程序未在计算机或应用程序配置文件中注册或无法加载.有关详细信息,请参阅内部异常. 安装 ...

  10. 源码级调试的XNU内核

    i春秋翻译小组-FWorldCodeZ 源码级调试的XNU内核 无论你是在开发内核扩展,进行漏洞研究,还是还有其他需要进入macOS / iOS内核,XNU,有时你需要附加调试器.当你这样做时,使用源 ...