java变量 本质_Java基础-运行原理及变量(01)

java运行原理

手动编写java文件由编译器编译成.class文件,再由解释器翻译class文件成机器语言运行.

a4249a0cb0f5fd79544785b005bdd1ba.png

Java中注释分类

单行注释

格式: //注释文字

多行注释

格式: /* 注释文字 */

文档注释

格式:/** 注释文字 */

注释的作用

解释说明程序,提高程序的阅读性

常量分类

字符串常量 用双引号括起来的内容(“HelloWorld”)

整数常量所有整数(12,-23)

小数常量所有小数(12.34)

字符常量用单引号括起来的内容(‘a’,’A’,’0’)

布尔常量较为特有,只有true和false

空常量null(数组部分讲解)

变量概述

在程序执行的过程中,在某个范围内其值可以发生改变的量

从本质上讲,变量其实是内存中的一小块区域

变量定义格式

数据类型 变量名 = 初始化值; //定义变量就是在内存中分配一块区域用来存放值,数据类型就是规定这块内存区域只能存放指定类型的值

2d51633dd42a46be4bbb515be18e139b.png

数据类型

基本数据类型(四类八种)

引用数据类型(类,接口,数组)

014557225a0d8073eeb8093a8594ca34.png

基本数据类型(四类八种)

c79adbda337c3df27efcab6313674027.png

浮点类型原理:

float和double的范围是由指数的位数来决定的。

float的指数位有8位,而double的指数位有11位,分布如下:

float:

aa498eca3bdb6d4d2e7a947e993391c5.gif

1bit(符号位) 8bits(指数位) 23bits(尾数位)

double:

534a8de0eea2efec5c9cb5b1c6693136.gif

1bit(符号位) 11bits(指数位) 52bits(尾数位)

V=(-1)^符号位 * 尾数位 * 2^指数位

所以,float的指数范围为-128~+127(-2^7~2^7-1),而double的指数范围为-1024~+1023(-2^10~2^10-1),并且指数位是按补码的形式来划分的。

其中负指数决定了浮点数所能表达的绝对值最小的非零数;而正指数决定了浮点数所能表达的绝对值最大的数,也即决定了浮点数的取值范围。

float的范围为-2^128 ~ +2^127,也即-3.40E+38 ~ +3.40E+38;double的范围为-2^1024 ~ +2^1023,也即-1.79E+308 ~ +1.79E+308。

float和double的精度是由尾数的位数来决定的。尾数的取值范围为取值范围为[1,2)或[0,1)。浮点数在内存中是按科学计数法来存储的,其整数部分始终是一个隐含着的“1”,由于它是不变的,故不能对精度造成影响。

float:2^23 = 8388608,一共七位,由于最左为1的一位省略了,这意味着最多能表示8位数: 2*8388608 = 16777216 。有8位有效数字,但绝对能保证的为7位,也即float的精度为7~8位有效数字;

double:2^52 = 4503599627370496,一共16位,同理,double的精度为16~17位。之所以不能用f1==f2来判断两个数相等,是因为虽然f1和f2在可能是两个不同的数字,但是受到浮点数表示精度的限制,有可能会错误的判断两个数相等!

注意事项:

整数默认是int类型,浮点数默认是double类型.

定义long数据类型的时候,要加l或者L,建议加L.    long i = 10000000000;  会报超出整数过大,因为没加L默认为int类型的值

定义float数据类型的时候,要加f或者F,建议加F    float j = 12.34;    会报可能损失精度,因为12.34默认为double类型,把double类型的值放入float中会损失精度

标识符

作用:给包,类,方法,变量等起名字

组成规则:由字符,下划线_,美元符$组成

这里的字符采用的是unicode字符集,所以包括英文大小写字母,中文字符(不推荐使用),数字字符等。

注意事项:不能以数字开头;不能是Java中的关键字

命名规则

a.包(本质是文件夹,用于对类的管理)

全部小写,多级用.隔开

b.类

每个单词首字母大写

c.方法和变量

一个单词首字母小写

多个单词组成从第二个单词开始每个单词的首字母大写

变量定义的注意事项

a.变量未赋值,不能直接使用(就是内存块中要先存值才能取,不然会报变量未初始化错误)

b.变量只在它的所属的范围内有效(所属的一对大括号)

c.一行上可以定义多个变量,但是不建议(因为不直观,建议一行定义一个变量并且赋初值)

类型转换

a.强制转换(目标类型 变量名 = (目标类型)(被转换的数据);)

b.隐式转换(byte,short,char -- int -- long -- float -- double)

a10ebbafeb9ae4be170fa116d6b51811.png

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值