ch02

目标: 1. 标识符、关键字和类型介绍
2. 如何构建类
---------------------------------
1.注释
作用:使部分内容只为程序员可见,不为编译器所编译、虚拟机所执行
位置:类声明前后、方法声明前后、属性声明前后、方法体中。几乎可以在一个源文件任意位置,但不能在一个关键字字符中插入注释
类型:
1) 单行注释:
//text ——从 // 到本行结束的所有字符均作为注释而被编译器忽略
2) 多行注释:
/*text*/ ——从 /* 到 */ 间的所有字符会被编译器忽略
3) 文档注释:
/**test*/ ——从"/**"到"*/"间的所有字符会被编译器忽略。当这类注释出现在任何声明(如类的声明、类的成员变量的声明或者类的成员方法的声明)之前时,会作为JavaDoc文档的内容;
@author 类的作者
@version · 类的版本
@since 从什么时候开始使用的
@see 另外参照...
@param 方法的参数
@return 方法的返回类型
@throws 方法抛出的异常

例如:
package com.briup.ch02;

/**
* this is my CommentTest Class
*@author briup
*@version 1.0
*@since JDK1.8
* */
public class CommentTest{
//表示这个人的名字
private String name;

/**
*this is a age of person
*
* */
private int age;

/**
*@param name :a name of person
*@exception null
* */
public void setName(String name){
this.name = name;

}
/**
*@return 没有返回类型
* */
public String getName(){
return this.name;

}
public static void main(String[] args){
/*
CommentTest ct = new CommentTest();
ct.setName("tom");
String temp = ct.getName();
System.out.println(temp);
*/
}

}

使用javadoc进行编译:
javadoc -d doc src/CommentTest.java

如果想显示出author和version
javadoc -d doc -author -version src/CommentTest.java
或者:
javadoc -d doc -author -version src/*.java

2.标示符
类、方法和变量的名字
1) 由字母、数字、下划线“_”、美元符号“$”组成,第一个字符不能是数字
2) 不能是java中的关键字
3) 大小写敏感
4) 没有长度限制。

注:java中标示符是可以使用中文的,但是一般不推荐这样做

举例:合法标识符 非法标识符
try1 try#
GROUP_7 7GROUP
openDoor open-door
boolean1 boolean
_int int
$int int

推荐常见的标示符命名规则
1) 类名以大写字母开头;
Hello Person Teacher TypeTest
2) 接口名以大写字母开头;
Eat Fly
3) 方法名以小写字母开头;
say go doSomething
4) 变量名以小写字母开头;
name age myName myAge
5) 常量名全部大写,多个单词以"_"连接;
FILE_TYPE PERSON_TITLE

分号、代码块和空格
1)每个语句短语以分号(;)结束
类的声明最后不需要加;
public class Hello{ .... }
方法的声明最后不需要加;
public class Hello{
public void go(){....}
}
属性的声明最后一定要加;
public class Hello{
int id;
private String name;
public int age;

public void go(){....}
}
2)代码片段用{}括起来
常见的有:
类的声明后加{}
方法的声明后加{}
注意:代码的{}后面都不需要加;
3)空白处
空格、tab键、新行和回车等是无关紧不影响代码执行的。

3.关键字
Java语言的关键字是程序代码中的特殊字符。包括:
类和接口的声明——class, extends, implements, interface
包引入和包声明——import, package
数据类型——boolean, byte, char, double, float, int, long, short
某些数据类型的可选值——false, true, null
流程控制——break, case, continue, default, do, else, for, if, return, switch, while
异常处理——catch, finally, throw, throws, try
修饰符——abstract, final, native, private, protected, public, static, synchronized, transient, volatile
操作符——instanceof
创建对象——new
引用——this, super
方法返回类型——void

Java语言的保留字是指预留的关键字,它们虽然现在没有作为关键字,但在以后的升级版本中有可能作为关键字: goto const

所有关键字都是小写,并且程序中标识符不能以关键字命名;

4.基本数据类型
Java语言中的数据类型分为基本类型和引用类型
基本类型:float double byte short int long char boolean
引用类型:类类型 接口类型 数组类型
数据类型本身是描述程序中数据所具备的特点的,同时数据类型也可以用来定义变量,而变量又是用来接收和存储数据的。
所以java中的变量也只有俩大种类:基本类型变量和引用类型变量

计算机中:
1字节=8位 0000 0001

基本数据类型又可以分为:整型 浮点类型 布尔类型 字符类型
整型
byte 8位 1字节
short 16位 2字节
int 32位 4字节
long 64位 8字节

浮点类型
float 32位 4字节
double 64位 8字节

布尔类型
boolean 8位 1字节

字符类型
char 16位 2字节

注意:java中采用unicode编码,用俩个字节表示一个字符,但是在其他字符编码中可能不是使用俩个字节表示一个字符

4.1 boolean
boolean类型数据的值为true或者false,在JVM中会转换为1或者0
注意:0代表的是false 1代表的是true
例如:
boolean flag = ture;
boolean bool = false;

4.2 char
char是字符,String是字符串
String是类类型,而char是基本数据类型
一个String是由0个或者n个char组成的

1)字符编码
Java语言对文本字符采用Unicode编码。由于计算机内存只能存取二进制数据,因此必须为各个字符进行编码。
例如:a --编码-->0000 0000 0110 0001
2)常见的字符编码包括:
a.ASCII
ASCII--Amecian Standard Code for Information Interchange(美国信息交换标准代码). 主用于表达现代英语和其他西欧语言中的字符。它是现今最通用的单字节编码系统,它只用一个字节的7位,一共表示128个字符。

b.ISO-8859-1
又称为Latin-1, 是国际标准化组织(ISO)为西欧语言中的字符制定的编码,用一个字节(8位)来为字符编码,与ASCII字符编码兼容。所谓兼容,是指对于相同的字符,它的ASCII字符编码和ISO-8859-1字符编码相同。

c.GB2312
它包括对简体中文字符的编码,一共收录了7445个字符(6763个汉字+682个其他字符). 它与ASCII字符编码兼容。

d.GBK
对GB2312字符编码的扩展,收录了21886个字符(21003个字符+其它字符), 它与GB2312字符编码兼容。

e.Unicode:
由国际Unicode协会编制,收录了全世界所有语言文字中的字符,是一种跨平台的字符编码。
UCS(Universal Character Set)是指采用Unicode字符编码的通用字符集。
Unicode具有两种编码方案:
用2个字节(16位)编码,被称为UCS-2, Java语言采用;
用4个字节(32位)编码,被称为UCS-4;

f. UTF
有些操作系统不完全支持16位或32位的Unicode编码,UTF(UCS Transformation Format)字符编码能够把Unicode编码转换为操作系统支持的编码,常见的UTF字符编码包括UTF-8, UTF-7和UTF-16.

3)字符编码表
每一种字符编码都有一个与之字符编码表,例如在Unicode编码表中十六进制的数字6136对应的汉字是愶
例如:
char c = '\u6136';
System.out.println(c);

4)char值的形式
Java语言采用Unicode编码,字符占2个字节。
字符a
二进制数据形式为 0000 0000 0110 0001
十六进制数据形式为 0x0061
十进制数据形式为 97

char c = 'a';
//设定"a"的十六进制数据的Unicode编码
char c = '\u0061';
//设定"a"的十六进制数据的Unicode编码
//0x开头的数字位十六进制
char c = 0x0061;
//设定"a"的十进制数据的Unicode编码
char c = 97;
//设定"a"的八进制数据的Unicode编码
//0开头的数字为八进制
char c = 0141;

注意:一个中文汉字就是一个字符
char c = '中';

5)转义字符
Java编程人员在给字符变量赋值时,通常直接从键盘输入特定的字符,而不会使用Unicode字符编码,因为很难记住各种字符的Unicode字符编码值。

对于有些特殊字符,比如单引号,如不知道它的Unicode字符编码,直接从键盘输入编译错误:

//编译出错
char c = ''';

为了解决这个问题,可采用转义字符来表示单引号和其他特殊字符:
char c = '\'';
char c = '\\';

转义字符以反斜杠开头,常用转义字符:
\n 换行符,将光标定位到下一行的开头
\r 回车,把光标移动到行首(和环境有关)
\t 垂直制表符,将光标移到下一个制表符的位置
\\ 反斜杠字符
\' 单引号字符
\" 双引号字符

6)空字符串和\u0000
键盘上任何一个按键都是一个字符,例如回车键、空格键、Esc键、Shift键等等

//空格字符
char c1 = ' ';

//字符串s1包含了一个空格字符
String s1 = " ";

//字符串s2不包含任何字符,即空字符串(不是null)
String s2 = "";

//这样表示是错误的
//没有空字符
char c2 = '';

//这俩个值是一样的,是char类型的默认值
//只是会占一个字符的位置
char c3 = 0;
char c4 = \u0000;

4.2 整数类型
byte, short, int和long都是整数类型,并且都是有符号整数(正负)。与有符号整数对应的是无符号整数,两者的区别在于把二进制数转换为十进制整数的方式不一样。

有符号整数把二进制数的首位作为符号数,当首位是0时,对应十进制的正整数,当首位是1时,对应十进制的负整数。对于一个字节(byte)的二进制数, 它对应的十进制数的取值范围是-128~127

无符号整数把二进制数的所有位转换为正整数。对于一个字节(byte)的二进制数, 它对应的十进制数的取值范围是0~255

在Java语言中,为了区分不同进制的数据,八进制数以“0”开头,十六制以“0x”开头,JDK1.7还支持了二进制的直接表示,0b开头
例如:
byte b1 = 97; 十进制
byte b2 = 0141; 八进制
byte b3 = 0x61; 十六进制
byte b4 = 0b01100001; 二进制

//都是97打印出来
System.out.println(b1);
System.out.println(b2);
System.out.println(b3);
System.out.println(b4);

整数类型的默认类型是int,对于给出一个字面值是99的数据,在没有指明这个数据是什么具体的类型的情况下,那么java默认认为是int类型。
例如:
//编译报错
//a+1中a是byte类型,字面值1没有声明类型,那么默认是int
//byte是8位,int是32位,那么结果是32位的数字
//b只是一个byte类型的变量,那么只能接收8位的数字
//修改为int b = a+1;就可以编译通过
byte a = 1;
byte b = a+1;

//编译通过
//虽然1+1中的1都是默认的int类型
//但是这个俩个1都是固定的字面值
//编译器可以判断出其结果是否超出了byte表示的范围
//上面例子中a+1不能判断出结果的原因是:
//a是变量,是有可能发生变化的
byte c = 1+1;

//编译报错
//编译器判断出其结果超出了byte的表示范围(-128~127)
byte d = 1+127;

//编译报错
//原因:32位的数据赋值给byte类型的变量
//因为使用的1这些都是字面值,默认是int
//所以它默认是在前面补了24个0
byte e = 0b11111111;

//编译通过
//输出结果为255
//因为1的前面补了24个0
int e = 0b11111111;

//编译通过
//输出结果为-1
byte f = (byte)0b11111111;

四种整型类型的声明
byte a1 = 1; (内存中占8位) 1字节
short a2 = 1; (内存中占16位)2字节
int a3 = 1; (内存中占32位)4字节
long a4 = 1L; (内存中占64位)8字节

使用long类型数据的时候后面要加大写L或者小写l,建议加上大写的L,因为小写的l和数字1很像似。

四种整型类型的表示范围
byte 8位 范围:负2的7次方~2的7次方减1
short 16位 范围:负2的15次方~2的15次方减1
int 32位 范围:负2的31次方~2的31次方减1
long 64位 范围:负2的63次方~2的63次方减1

4.3 浮点型
float和double都是java中的浮点型,浮点型可以用来表示小数.

float是32位, 1符号位+8指数位+23尾数位
double是64位,1符号位+11指数位+52尾数位

float和double的精度是由尾数的位数来决定的。浮点数在内存中是按科学计数法来存储的.
float的精度为7位左右有效数字
double的精度为16位左右有效数字

俩种浮点型数据的声明
//后面加f或者F
float f = 10.5f;
//后面加d或者D
double d = 10.5d;

浮点型的二进制形式
参考样例:
float f = 10.5f;
int b = Float.floatToIntBits(f);
System.out.println(Integer.toBinaryString(b));

浮点型的默认类型是double,对于给出一个字面值是10.8的数据,在没有指明这个数据是什么具体的类型的情况下,那么java默认认为是double类型。
例如:
//编译通过
//字面值1.5默认类型是double
double d = 1.5;

//编译报错
//字面值1.5默认类型是double
//double和float的精确度不一样
float f = 1.5;

//f2编译通过,因为字面值1的类型是int
//f3编译报错,因为字面值1.5的类型是double
float f1 = 10.5f;
float f2 = f1+1;
float f3 = f1+1.5;

浮点型的精度丢失
例如:
System.out.println(1.0-0.66);
输出结果:
0.33999999999999997

Java中的简单浮点数类型float和double不能够进行精确运算,因为大多数情况下是正常的,但是偶尔会出现如上所示的问题。这个问题其实不是JAVA的bug,因为计算机本身是二进制的,而浮点数实际上只是个近似值,所以从二进制转化为十进制浮点数时,精度容易丢失,导致精度下降。

   要保证精度就要使用BigDecimal类,而且不能直接从double直接转BigDecimal,要将double转string再转BigDecimal。也就是不能使用BigDecimal(double val)方法,而是需要使BigDecimal(String val)方法。
例如:
BigDecimal d1 = new BigDecimal("1.0");
BigDecimal d2 = new BigDecimal("0.66");
double result = d1.subtract(d2).doubleValue();
System.out.println(result);
输出结果:0.34

5.变量的声明和赋值
java中的任意类型可以用来声明变量,包括八个基本类型和三个引用类型

//变量的声明
int x;

//声明多个类型相同的变量
int x,y;
相当于
int x;
int y;

//先声明变量
//再给变量赋值
int x;
x = 10;

//声明变量的同时就赋值
int x = 10;

思考:变量在程序中的作用是什么?

6.理解对象
java是面向对象的编程语言(OOP),面向对象的开发方法把软件系统看成各种对象的集合,这种方式也是接近人的自然思维方式。

世界上万事万物实在太多了,不能一概而论,所以要解决一个问题,必须是要把事物限定到一定的范围之内,那么这个范围就是我们要解决问题的问题域。
例如:我们要给"希望中学"开发一套教师管理系统,那么我们要把这个系统的分析与设计限定在"希望中学"的具体教师管理的规则之中,而不是针对全世界所有中学的教师管理规则。

对象是对问题领域中事物的抽象。对象具有以下特性:
1) 万物皆为对象。问题领域中的实体和概念都可以抽象为对象。例如学生,成绩单、教师、课和教室。
2) 每个对象都是惟一的。正如世界上不存在一模一样的树叶。
3) 对象具有属性和行为。
例如:
小张,性别女,年龄22,身高1.6m, 体重40kg, 能够学习,唱歌。
小张的属性包括姓名、性别、年龄、身高和体重
小张的行为包括学习、唱歌。
4) 对象具有状态。状态是指对象在某个时刻的属性取值。对象的某些行为会改变对象自身的状态。
例如:
小张本来体重为40kg,经为减肥后,体重减到35kg.

肥胖状态: 40kg
|
| 减肥行为
|
肥胖状态: 35kg

5) 每个对象都是某个类的实例
例如:
小张和小王都属于学生类的实例
中国和美国都属于国家类的实例
中文和英文都属于语言类的实例

类是具有相同属性和行为的对象的集合。

同一个类的所有实例(对象)都有相同属性名,但属性的取值不一定相同,例如:
小张和小王都属于学生类,都有姓名、性别、年龄、身高和体重这些属性,但是他们的这些属性取值都可能不同。

同一个类的所有实例(对象)都有相同行为,意味着它们具有一些相同的功能。
例如:
小张和小王都属于学生类,他们都能学习以及能唱歌

6) java中的对象其实就是堆区中的一块内存空间
JVM管理的内存,被划分为了若干区域,其中有一个被称之为堆区,java运行过程产生的所有对象几乎都会在堆区中.垃圾回收器(gc)的工作主要也就是把堆区中把不再被使用的内存(也就是对象)进行回收。
new关键字就是向JVM申请内存空间以便接下来创建对象,这块内存地址就是所创建对象的内存地址,通过该地址也是在内存中找到该对象的唯一方式。

7.定义类
1)分析学生都具备哪些特点以及行为
学生都有学号、姓名、性别
学生都可以说话、学习、跑步
2)把学生这一群体抽象为一个java类:Student
所以一个java类是对某一类事物的整体描述
Student类是对整体学生的描述
3)把学生的"特点"抽象为Student类中的"属性"
所以只要是属于这个Student类的对象都具有这些属性
4)把学生的"行为"抽象为Student类中的"方法"
所以只要是属于这个Student类的对象都具有这些方法
5)如果有需要,可以在类中添加对于的构造器,以便我们在创建对象的时候给对象的属性赋值,如果不添加构造器那么JVM会自动帮我们在类中添加一个无参构造器

定义一个学生类:Student
public class Student{
//属性
public long id;
public String name;
public char gender;

//方法
public void say(){
System.out.println("I can say..");
}
public void study(){
System.out.println("I can study..");
}
public void run(){
System.out.println("I can run..");
}

//无参构造器 创建对象的时候使用
public Student(){}
//有参构造器 创建对象的时候使用
public Student(long id,String name,char gender){
this.id = id;
this.name = name;
this.gender = gender;
}
}

8.创建类的实例
在java代码中,需要把类进行实例化得到该类的对象后,再使用对象去访问对象中的属性以及调用到对象中的方法
形式:
对象.对象中的属性
对象.对象中的方法()
对象.对象中的方法(参数)
注1:首先要使用类进行实例化创建出这个对象
注2:对象调用方法时一定有小括号,对象访问属性时一定没有小括号

类中的属性和方法一般情况是不能直接使用的,类中的代码只是提供了一个创建对象的模板,根据这个模板创建出的对象才可以使用。
所以类只是创建对象的模板,对象才是调用方法、执行代码、完成功能这个过程中的关键点。
注意:类A中有什么属性和方法,那么该类的对象中就有什么属性和方法,因为该对象是根据类A这个模板创建出来的.

根据上面所编写的Student类,进行类的实例化,也就是创建对象。
1)使用 new+类中构造器 的形式创建出该类的对象
new Student();
或者
new Student(1L,"tom",'男');
这种方式可以直接给对象中属性赋值
2)为了方便进一步使用这个对象,需要使用变量去接收这个对象
Student s = new Student();
java是强类型编程语言,数据是什么类型的,那么接收数据的变量类型也要与之对应
3)接下来可以使用对象访问其属性,也可以调用其方法
Student s = new Student();
//对象访问其属性并且给该属性赋值
s.id = 2L;
s.name = "zhangsan";
s.gender = 'm';

//打印出对象中的属性值
System.out.println("id: "+s.id);
System.out.println("name: "+s.name);
System.out.println("gender: "+s.gender);

//对象调用其方法
s.say();
s.study();
s.run();

9.基本类型变量和引用类型变量的区别
1)基本类型变量指的是使用byte、short、int、long、float、double、boolean、char这八种类型声明出来的变量
2)引用类型变量指的是使用任意一个类、任意一个接口、任意一个数组所声明出来的变量
3)基本类型的数据是一种比较简单的数据,不能包含其他类型的数据,也不能调用任何方法
4)对象是一种比较复杂的数据,可以包含其他类型的数据,也可以调用方法
例如:对象s中包含了其他三个不同类型的数据
Student s = new Student(1L,"tom",'男');
5)基本类型变量接收的只能是一些比较简单的数据(8/16/32/64位)
6)引用类型变量接收的只能是对象
Student s = new Student();
引用类型的变量可以简称为 引用
简称:引用"指向"对象

例如:
//使用x不能访问任何属性也不能调用任何方法
int x = 1;

Student s = new Student();
//使用s可以访问对象中的属性
s.name = "tom";
//也可以调用对象中的方法
s.run();

java_day02_标识符等的更多相关文章

  1. ORA-12154:TNS:无法解析指定的连接标识符

    问题:ORA-12154:TNS:无法解析指定的连接标识符 原因:没有配置tnsnames.ora文件 解决方案: 配置环境变量变量名:ORACLE_HOME 变量值:如:D:\Database\pr ...

  2. 转:IE兼容模式下 SCRIPT1028: 缺少标识符、字符串或数字

    IE兼容模式下 SCRIPT1028: 缺少标识符.字符串或数字例如下面一段代码 var a = {    x: 1,    y: 2,};alert(a.x);如果在IE的兼容性视图(IE7文档模式 ...

  3. sql server报:名称 不是有效的标识符

    可能出现的几种情况: 1.执行sql提示 名称***不是有效的标识符 --添加括号 sql exec(sql) 注意exec的时候要到括号 exec  (@sql) 2.sql中的单引号嵌套采用两个单 ...

  4. 我对 Java 标识符的分类命名方法

    我对 Java 的各种标识符有一套固定的分类方法,以下分享一下我的命名方法以及进行一些说明. # 前缀: 方法 方法:f_doSomeThing().分类词是 f,采自 [f]unction 方法,也 ...

  5. java的基础知识文件操作和标识符

    1.文件夹的操作 dir :显示当前文件夹中的所有文件和文件夹. cd 路径:  进入到指定的路径. cd ..  : 回到上一级目录 cd  \ : 回到当前目录的跟目录 md 文件夹名  创建一个 ...

  6. java基础1_标识符,数据类型

    JDK的卸载与安装 : 1  卸载 a 从程序中卸载   控制面板 - 程序和功能 - 卸载JDK; b 删除  C:\Windows\System32 下面的  java   javac  java ...

  7. Java的书写格式,标识符及命名规则,注释

    Java的书写格式,标识符及命名规则,注释 1.Java语言的书写格式(约定成俗) 1) 大括号要对齐(左大括号与句尾对其,后面大括号与句头对齐),并且成对写 2) 左大括号前面有空格 3) 遇到左大 ...

  8. Java的关键字与标识符

    Java作为一门编程语言,与其他语言一样,有字符集.标识符.和关键字.变量.常量.语句等编程语言的基本要素. 1.关键字 abstract boolean break byte case catch ...

  9. MS SQL 错误:无法绑定由多个部分组成的标识符 "xxxxx"

    今天有个同事问我一个SQL问题,觉得有点意思,虽然能很快定位并解决问题,但是就是有种说不清道不明的感觉.因为不能解释清楚(很多是建立在假设上),顺便记录一下,希望有清楚原理的人能解答一二. 原SQL语 ...

随机推荐

  1. Docker参数 -i -t 的作用

    Docker 参数 -i -t 的作用通常的解释是: -t让docker分配一个伪终端并绑定到容器的标准输入上, -i则让容器的标准输入保持打开. 问题所以通常都是这样的: sudo docker r ...

  2. 【miscellaneous】单播、广播和多播IP地址

    转自:http://www.cnblogs.com/gaoxing/archive/2012/02/19/2358484.html 除地址类别外,还可根据传输的消息特征将IP地址分为单播.广播或多播. ...

  3. HBASE概念补充

    HBASE概念补充 HBase的工作方式: hbase中的表在行的方向上分隔为多个HRegion,分散在不同的RegionServer中 这样做的目的是在查询时可以将工作量分布到多个RegionSer ...

  4. ZOJ Problem Set - 1004

    1.翻译参考 http://liucw.blog.51cto.com/6751239/1198026 2.代码参考 http://www.cnblogs.com/devymex/archive/201 ...

  5. A Mixed Flash Translation Layer Structure for SLC-MLC Combined Flash Memory System

    http://blog.sina.com.cn/s/blog_502c8cc40100pztk.html 摘要 1.In this paper, we propose the SLC-MLC mixe ...

  6. 什么是NameNode和DataNode?他们是如何协同工作的?

    [学习笔记] 什么是NameNode和DataNode?他们是如何协同工作的? 马克-to-win @ 马克java社区:一个HDFS集群包含一个NameNode和若干的DataNode(start- ...

  7. VC++ 窗口透明化及透明窗口上绘画、截图、轨迹

    源文件:https://files.cnblogs.com/files/MrFengD/Temp.rar

  8. python-open函数操作实例

    一.这个是源配置文件: global               log 127.0.0.1 local2        daemon        maxconn 256        log 12 ...

  9. Tomcat中的Host和Engine级别的servlet容器

    这边文章主要介绍的是Host容器 和 Engine容器.如果你想在同一个Tomcat上部署运行多个Context容器的话,你就需要使用Host容器,从理论上来讲,如果你的Tomcat只想要部署一个Co ...

  10. SQL SERVER 相关

    while循环 declare @sum int; declare @i int; ; ; ) begin ) begin set @sum=@sum+@i; end ; end select @su ...