Java常用基础(一)

发布 : 2019-01-29 分类 : 编程 浏览 :

随机数

1
2
3
4
5
Random rand =  new Random(47)
47为随机数种子,随机数种子一样产生的随机数序列一样,
若空则以当前时间为种子,每次产生的随机数不一样

产生[0,1)区间的小数Math.random();

输入输出

1
2
3
4
5
6
7
8
//输入
Scanner in = new Scanner(new BufferedInputStream(System.in));
in.hasNext();
in.nextInt();
//输出
PrintWriter out = new PrintWriter(new BufferedOutputStream(System.out));
out.println("Hello World");
out.flush();

进制

十六进制以0x开头

1
2
3
char c = 0xffff;     // max char hex value
byte b = 0x7f; // max byte hex value
short s = 0x7fff; // max short hex value

如果试图将一个变量初始化为超出自身表示范围的值(无论这个值的数值形式如何),编译器都会向我们报告一条错误信息。如果超出范围,编译器会将值自动转换为int型,并告诉我们需要对这次赋值进行“窄化转型”

窄化转型

将能容纳更多信息的数据类型转换成无法容纳那么多信息的类型,有可能面临信息丢失的危险

1
2
3
4
//如浮点型转换为整形
int i = 29.7;
print(i);
//输出29,而不是30

round()

java.lang 中的四舍五入函数

1
2
3
double d = 29.7;
print(Math.round(d));
//将输出30

指数记数法

1
2
3
// 1.3e-43表示的是1.3 x 10`-43f
float f = 1.3e-43f
//编译器通常会将指数作为双精度(double)处理,在尾部加上f是告诉编译器将double 转换成float,否则会出错

按位操作符

& 与

| 或

~ 非

&=、|=、^=都是合法的

移位操作符

<< >> <<= >>= >>>=

类型转换

只要类型比int小,(即char byte short),在运算之前这些值会自动转换成int。这也一来,最终生成的结果就是int型。如果把结果值赋值给较小的类型,就必须使用强制类型转换(既然把结果赋值给了较小的类型,就可能出现信息的丢失)。
通常,表达式中出现的最大的数据类型决定了表达式最终结果的数据类型,如果将一个float值与一个double值相乘,结果就是double;如果将一个int和一个long值相加,则结果为long。

“==” 与equals()

“==”比较基本数据类型,相同返回true不用返回false
比较引用时,如果引用指向内存中的同一对象则返回true。

equals()

1
public  boolean equals(Object obj)

当参数obj引用的对象与当前对象为同一个对象时,就返回true,否则返回false。
equals()方法的本意为确定两个对象的引用是否相同,而JDK类中有一些类覆盖了oject类的equals()方法,比较规则为:如果两个对象的类型一致,并且内容一致,则返回true,这些类有:java.io.file,java.util.Date,java.lang.string,包装类(Integer,Double等)

1
2
3
4
5
6
7
8
9
10
11
12
13
public class EqualsTest {
public static void main(String[] args) {
String s1=new String("sss");
String s2=new String("sss");

System.out.println(s1==s2);
System.out.println(s1.equals(s2));
}
}

//————————运行结果为——————
//false
//true

由此知道,在String中equals()方法被进行了覆盖,使其意义变为比较两个对象的内容是否一致

Foreach

遍历数组并输出

1
2
3
4
5
6
7
8
9
10
11
double d[] = new double[10];
for(int i = 0; i < 10; i++)
d[i] = Math.random();
for (double t : d)
System.out.println(t);

for(int i : range(100))
{
if(i == 74)break;
else System.out.print(i);
}

标签

标签是后面根有冒号的标识符:
label1:

1
2
3
4
5
6
7
8
9
10
11
12
13
label1:
outer-iteration{
inner-iteration{
//...
break;
//...
continue;
//...
continue label1;
//...
break label1;
}
}

break中断内部迭代,回到外部迭代。
continue使执行点移回内部迭代的起始处
continue label1中断内部迭代以及外部迭代,直接转到label1处,重新开始迭代过程。
break label1也会中断所有迭代,并回到label1,但并不重新开始迭代

构造器初始化之初始化顺序

在类的内部,变量定义的先后顺序决定了初始化的顺序。即使变量定义散布于方法定义之间,它们人就会在任何方法(包括构造器)被调用之前得到初始化。例如

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
class Window{
Window(int marker){ print("Window(" + marker + ")"); }
}

clase House{
Window w1 = new Window(1);
House(){
print("House()");
w3 = new Window(33);
}
Window w2 = new Window(2);
void f(){ print("f()") };
Window w3 = new Window(3);
}

public class OrderOfInitialization{
public static void main(String[] args){
House h = new House();
h.f();
}
}

/* Output:
Window(1)
Window(2)
Window(3)
House()
Window(33)
f()
*/

显然定义的变量最先初始化,并且先定义的变量先初始化

instanceof

fun1 extends fun
fun1 instanceof fun //返回true

super

super 指向父类的方法
例如重写了父类的方法,又想用父类原来的方法

this

this 指向本类的方法

本文作者 : HeoLis
原文链接 : http://ishero.net/Java常用基础(一).html
版权声明 : 本博客所有文章除特别声明外,均采用 CC BY-NC-SA 4.0 许可协议。转载请注明出处!

学习、记录、分享、获得

微信扫一扫, 向我投食

微信扫一扫, 向我投食