您的位置 首页 > 数码极客

〔short类型〕short类型怎么赋值

点击上方 "程序员小乐"关注, 星标或置顶一起成长

第一时间与你相约

每日英文

Sometimes, the hardest things to say are those that come straight from the heart.

有时候,内心最直接的感受,往往是最难说出口的。


每日掏心话

生命中总有那么一段时光,充满不安,可除了勇敢面对,我们别无选择。


来自:CSDN | 作者:Jeremy Grifski | 译者:弯月 | 责编:乐乐


程序员小乐(ID:study_tech)第 710 次推文 图片来自网络


往日回顾:Java网络编程总结,看了都说好!


正文



自从Java发布以来,基本数据类型就是Java语言中重要的一部分,本文就来详细介绍下每种基本类型的具体使用方法和限制。



以下为译文:


几年前,我开始编写了一系列有关Java入门的文章,我觉得有必要将其中一些非常细节的内容单独拿出来写成文章。这样,那些入门内容就更容易理解了。首先,我来介绍一下有关Java 8中的基本类型。


如题所述,Java语言本身有8种基本类型。在下面几节中,就让我们一起来看看这8种基本类型。我将针对每种基本类型,介绍具体的使用方法和限制。


一、int基本类型


首先,Java的整数是32位有符号(即包括正值和负值)整数,由int关键字表示:


int someNumber = 10;


当然,像所有基本类型一样,整型有自己的限制。由于它只有32位,所以其取值范围为-2147483648到2147483647。这数字很大嘛!当然,我们可以在DrJava的交互面板中用下述技巧来确认:


In // Prints 2,147,483,647
In // Prints -2,147,483,648


自然地,对于简单的计算而言,int是最常用的整数类型。如果你需要更大的数字范围,请参照下面的long。


二、double基本类型


与int不同,Java的双精度类型是64位浮点数,由double关键字表示:


double someNumber = 110.55;


需要提醒的是,浮点数实际上就是实数。换句话说,双精度浮点数中包含小数点。


由于双精度类型是64位,它能表示的数字要比整型多很多。同样,我们可以利用交互面板来确认双精度类型的范围:


Double.MAX_VALUE // Prints 1.7976931348623157E308
Double.MIN_VALUE // Prints 4.9E-324


需要注意的是,负的指数表示的是非常小的数字,而不是非常大的负数。所以这里的取值范围跟整数不是完全一样。


一般而言,double是在Java中使用浮点数的默认选择。另一个选择是float。


三、char基本类型


我们已经看到,Java的字符类型表示16位字符,由char关键字表示:


char someCharacter = 'f';


Java中所有的字符都用单引号表示。同时,双引号用来表示字符串。我们稍后会讨论字符串。


与往常一样,我们可以通过下面的代码找出字符的范围:


C // Prints '???'
C // Prints ''


为了让这个范围有意义,我们可以将结果转换成整数(稍后会更多地介绍):


(int) C // Prints 65535
(int) C // Prints 0


可见,char类型是Java中唯一的无符号类型。换句话说,字符的取值范围为0到65535,每个值映射到特定的字符。如果需要创建该范围之外的字符,可以将一对字符组合起来。参见“在Java中反转字符串”()这篇文章中的例子。


四、Byte基本类型


当我们讨论二进制时,我们讨论的实际上是比特的概念。而8个比特组成一个字节,字节是Java支持的基本类型之一。本质上,byte类型只不过是取值范围为-128到127的8位整数。可以猜到,字节由byte关键字表示:


byte someByte = 20;


同样,可以利用下面的代码片段来确认byte类型的取值范围:


By // Prints 127
By // Prints -128


根据我的经验,byte类型在读取和处理原始数据时非常有用。但是一般而言,我们不会使用它,因为取值范围太小了。


五、Short基本类型


short是另一种整数类型,但它占用的空间要比int类型更小。实际上,它的占用空间正好是int类型的一半,为16位,由short关键字表示:


short someNumber = 11;


short类型的取值范围也只有整数的一半,我们可以用下述代码确认:


S // Prints 32767
S // Prints -32768


在实际应用中,short只有65546个可能的值。在内存空间和磁盘空间受限的情况下,我们会使用byte和short。但在其他情况下,在定义整数时默认使用int更为安全。


六、long基本类型


与short相反的是long基本类型,即长整数。该类型用来表示比int类型还要大的非常大的数。long类型是64位有符号整数,其取值范围超过了10的18次方。


通常,长整数用long关键字表示:


long someBigNumber = 10L;


下面的代码可以查看64位值究竟有多大:


Long.MAX_VALUE // Prints 9,223,372,036,854,775,807
Long.MIN_VALUE // Prints -9,223,372,036,854,775,808


也许,long可以用来计算光在一定时间内走过的距离。光在一秒内大约传播30万千米。如果编写一个程序来跟踪光走过的距离,那么7秒后int类型就超出范围类,而long类型能够计算大约975年。不相信吗?可以看看这个gist()中的计算。


七、float基本类型


虽然我们通常使用64位浮点数类型double,但Java还支持另一种浮点数类型,叫做float。但与int类似,Java默认情况下使用double表示浮点数。不管怎样,我们可以用float来表示32位浮点数类型:


float someNumber = 11.4f;


float类型的范围如下:


Float.MAX_VALUE // Prints 3.4028235E38
Float.MIN_VALUE // Prints 1.4E-45


可见,32位浮点数的范围和精度都要小得多。如果不需要double的精度,同时节省一半的空间,那么可以选择float类型。


八、boolean基本类型


最后我们来讨论一下boolean类型。定义布尔类型可以使用boolean关键字:


boolean isBool = true;


布尔类型有些特殊,不像其他基本类型那样,它们表示的不是数字值。实际上,之前使用的MAX_VALUE和MIN_VALUE技巧在这里不能使用。相反,它表示的是true或false,即真和假。


在此,我不打算详细介绍布尔类型,因为在Java中做任何事情都会涉及到布尔类型。尽管如此,我们通常不会明确地声明布尔类型。相反,许多代码逻辑中的比较操作的结果都是布尔类型。


原文:dev.to/renegadecoder94/the-8-primitive-types-in-java-10cl


欢迎在留言区留下你的观点,一起讨论提高。如果今天的文章让你有新的启发,学习能力的提升上有新的认识,欢迎转发分享给更多人。


猜你还想看


阿里、腾讯、百度、华为、京东最新面试题汇集

Java 设计模式之责任链模式实现的三种方式

Java finally语句到底是在return之前还是之后执行?

Java 中的 SPI 机制是到底是什么?高级 Java 必须掌握!


关注「程序员小乐」,收看更多精彩内容
嘿,你在看吗?


责任编辑: 鲁达

1.内容基于多重复合算法人工智能语言模型创作,旨在以深度学习研究为目的传播信息知识,内容观点与本网站无关,反馈举报请
2.仅供读者参考,本网站未对该内容进行证实,对其原创性、真实性、完整性、及时性不作任何保证;
3.本站属于非营利性站点无毒无广告,请读者放心使用!

“short类型,short类型怎么赋值,short类型占几个字节,short类型取值范围,short类型数据”边界阅读