Java学习笔记(第3章 P35-P62 )(第4章 P63-P103)
第3章 变量
- 变量是程序的基本组成单位
- 不论是使用哪种高级程序语言编写程序,变量都是其程序的基本组成单位,变量有三个基本要素(类型+名称+值)
- 概念:变量相当于内存中一个数据存储空间的表示,你可以把变量看做是一个房间的门牌号,通过门牌号我们可以找到房间,而通过变量名可以访问到变量(值)。
- 变量使用的基本步骤:(1)声明变量(2)赋值
变量的使用注意事项
- 变量表示内存中的一个存储区域【不同的变量,类型不同,占用的空间大小不同,比如:int4个字节,double就是8个字节】
- 该区域有自己的名称【变量名】和类型【数据类型】
- 变量必须先声明,后使用,既有顺序
- 该区域的数据可以在同一类型范围内不断变化
- 变量在同一作用域内不能重名
- 变量 = 变量名+值+数据类型
程序中 + 号的使用
- 当左右两边都是数值型时,则做加法运算
- 当左右两边有一方为字符串,则做拼接运算
- 运算顺序,是从左到右
- 测试
System.out.println(100 + 98); //198
System.out.println("100" + 98); //10098
System.out.println(100 + 3 + "hello"); //103hello
System.out.println("hello" + 100 + 3); //hello1003
数据类型
- 每一种数据都定义了明确的数据类型,在内存中分配了不同大小的内存空间(字节)。
整数类型
Java的整数类型就是用于存放整数值的
- Java各整数类型有固定的范围和字段长度,不受具体OS【操作系统】的影响,以保证java程序的可移植性
- Java的整型常数默认为int型,声明long型常数须后加’l’或’L’
- java程序中常量声明为int型,除非不足以表示大数,才使用long
- bit:计算机中的最小存储单位。byte:计算机中基本存储单元,1byte = 8 bit。【举例byte3和short3】
浮点类型
- 基本介绍
Java的浮点类型可以表示一个小数 - 浮点型的分类
- 说明一下
- 关于浮点数在机器中存放形式的简单说明,浮点数 = 符号位 + 指数位 + 尾数位
- 尾数部分可能丢失,造成精度损失(小数都是近似值)。
- 浮点数使用细节
- 与整数类型类似,Java浮点类型也有固定的范围和字段长度,不受具体OS的影响。【float4个字节double是8个字节】
- Java的浮点型常量默认为double型,声明float型常量,须后加’f’或’F’
- 浮点型常量有两种表示形式
十进制数形式如:
5.12 512.0f .512(必须有小数点)
科学计数法形式如:5.12e2[5.12*10的2次方] 5.12E-2[5.12/10的2次方]
- 通常情况下,应该使用double型,因为它比float型更精确。
例子:
double num9 = 2.1234567851;
float num10 = 2.1234567851f;
- 浮点数使用陷阱:2.7和8.1 / 3比较【8.1 / 3 为接近2.7的数并非2.7】
- 重点:当我们对运算结果是小数的进行相等判断时,应该是以两个数的差值的绝对值,在某个精度范围内判断
字符类型(char)
- 基本介绍
字符类型可以表示单个字符,字符类型是char,char是两个字节(可以存放汉字),多个字符我们用字符串String - 字符类型使用细节
- 字符常量是用单引号(’’)括起来的单个字符。例如:
char c1 = 'a'; char c2 = '中'; char c3 = '9';
- Java中还允许使用转义字符’'来将其后的字符转变为特殊字符型常量。例如:
char c3 = '\n'; //'\n'表示换行符
- 在java中,char的本质是一个整数,在输出时,是unicode码对应的字符。http://tool.chinaz.com/tools/unicode.aspx
- 可以直接给char赋一个整数,然后输出时,会按照对应的unicode字符输出[97->a]
- char类型是可以进行运算的,相当于一个整数,因为它都对应有Unicode码
- 字符类型本质探讨
- 字符型存储到计算机中,需要将字符对应的码值(整数)找出来,比如’a’
存储:‘a’ => 码值97 => 二进制 (110 0001)=> 存储
读取:二进制 =>97 =>‘a’ =>显示 - 字符和码值的对应关系是通过字符编码表决定的(是规定好)
- 介绍一下字符编码表[sublime(软件)测试]
- ASCII(ASCII编码表一个字节表示,一个128个字符,实际上一个字节可以表示256个字符,只用了128个)
- Unicode(Unicode 编码表 固定大小的编码 使用两个字符来表示字符,字母和汉字统一都是占用两个字节,这样浪费空间)
- utf-8(编码表,大小可变的编码字母使用1个字节,汉字使用3个字节)
- gbk(可以表示汉字,而且范围广,字母使用1个字节,汉字2个字节)
- gb2312(可以表示汉字,gb2312< gbk)
- big5码(繁体中文,台湾,香港)
布尔类型:boolean
- 基本介绍
- 布尔类型也叫boolean类型,boolean类型数据只允许取值true和false,不能为null
- boolean类型占1个字节。
- boolean类型适于逻辑运算,一般用于程序流程控制:
①if条件控制语句
②while循环控制语句
③do - while循环控制语句
④for循环控制语句
- 使用细节说明
- 不可以0或非0的整数替代false和true,这边和c语言不同
ASCII码介绍(了解)
- ASCII码:上个世纪60年代,美国制定了一套字符编码(使用一个字节),对英语字符与二进制之间的关系,做了统一规定。这被称为ASCII码。ASCII码一共规定了128个字符的编码,只占用了一个字节的后面7位,最前面的1位统一规定为0。
特别提示:一个字节可以表示256个字符,ASCII码只用了128个字符。 - 缺点:不能表示所有字符。
Unicode编码介绍(了解)
- Unicode的好处:一种编码,将世界上所有的符号都纳入其中。每一个符号都给予一个独一无二的编码,使用Unicode没有乱码的问题。
- Unicode的缺点:一个英文字母和一个汉字都占用2个字节,这对于存储空间来说是浪费。
- 2的16次方是65536,所以最多编码是65536个字符。
- 编码0-127的字符是与ASCII的编码一样,比如’a’在ASCII是0x61,在unicode码是0x0061,都对应97.因此Unicode码兼容ASCII码。
UTF-8编码介绍(了解)
- UTF-8是在互联网上使用最广的一种Unicode的