《Java知识点总结系列》第三章——程序的流程控制篇

内容预览

顺序流程

分支流程

循环流程

顺序流程

以前的程序都是顺序流程,这里略过。

分支流程

1. if语句

a) 格式:

if(布尔表达式){

语句内容

语句内容

}

b) 示例代码

int a = 10;

int b =SystemIn.nextInt();

if(b!=0){

System.out.println(“a/b =” + a / b);

}

c) if语句特例

if(布尔表达式)语句内容

说明:只有一行语句需要执行

程序的可读性:反馈(不满足也给出提示信息)

2. if …else语句

a) 格式:

if(布尔表达式){

语句内容1;

}else{

语句内容2;

}

b) 说明:if:如果 else:否则

c) 效率比多重if高 1&0 0&&1

3. if…elseif…else语句

a) 格式:

if(布尔表达式){

语句内容;

}else if(布尔表达式){

语句内容;

} else if(布尔表达式){

语句内容;

}

else{

语句内容

}

4. switch/case语句

a) 格式:

switch(数据){

case值1:语句1;

case 值2:语句2;

……

default:语句;

}

b) 说明:C#和Java的语法相似度可以到达50% ---60%,但是C#在switch/case语句里必须加break

c) switch&case注意事项

i. 每一个case声明之后应该有break

ii. default语句可以放置在最后、中间或开始处

iii. 确保switch的变量类型是byte、short、char或者int之一 iv. 如果你使用的是JDK7,switch的变量类型还支持String类型(JDK6、JDK5或者以下版本不支持)

v. 复杂的switch&case

case 4:{ 代码块 }

vi. 数据值不允许重复

vii. 多重if VSswitch/case:多重if(某个变量的值处于某个区间 如80——90),而switch/case只能用于等值判断。

循环流程

1. 循环流程(重复执行一条语句或一组语句)

2. Java中的3种循环流程方式

a) while循环

b) do……while循环

c) for循环

d) 注意:循环条件 代码块(循环体) 循环次数

3. while循环

a) 格式:

while(布尔表达式){

代码内容

}

b) 死循环 while(true){ }

c) 隐式死循环

int count = 1; while(1 < = 5) {System,out.println(count);}

4. do……while循环(while 可以完成的do….while亦可完成)

a) 格式:

do{

代码内容

}while(布尔表达式);//注意分号

b) while & do……while的区别

当不满足初始循环条件时,while循环体一次都不执行,而do……while至少执行一次

5. for循环

a) 格式:

for(初始值;循环条件;增量表达式){

代码内容

//初始值循环条件增量表达式都可省略,但是分号不可省,也就是必须要有两个分号 //特殊:两个初始值 for(int i = 0, j= 6; i < = 6; i ++, j --)

}

初始值:即定义一个变量(不一定为0)

循环条件:即判断循环是否执行的条件(布尔表达式)

增量表达式:即对先前定义的变量进行加减运算

b) for循环规律总结

i. i初始值从0开始<n循环对应执行n次 ii. i初始值从1开始<=n循环对应执行n次 iii. for循环体内i的取值一次从初始值开始一直取到条件判断的n值,如果<n则取到n的前一个值,如果<=n则取到n的值

c) for循环案例

i. 写一个程序,计算1+…+100的累加和 ii. 思路:存储累加和的结果 如何获得1…100的数字

d) for循环与while循环的使用场景

i. for循环可以与while循环相互替换使用 ii. for循环一般多用于确定次数的循环 iii. while一般多用于不确定次数的循环

e) for总结

i. 在循环前初始化循环变量的值 ii. 在循环体重改变循环变量的值 iii. for循环与while循环类似

6. break和continue关键字

a) break:跳出当前循环

for(int i = 0; i < 3; i ++){

if(i == 1)

break;

System.out.println(“i = ”+ i);

}

结果:

i = 0;

b) continue:跳出本次循环

for(int i = 0; i < 3; i ++){

if(i == 1)

continue;

System.out.println(“i = ”+ i);

}

结果:

i = 0;

i = 2;

7. 循环的标签(为循环命名) //lab循环

lab:for(int i = 0; i < 3; i ++){

System.out.println(“i = ”+ i);

}

8. break与continue关键字和循环的标签

lab:for(int i = 0; i < 3; i ++){

if(i == 1)

break lab;

System.out.println(“i = ”+ i);

}

lab:for(int i = 0; i < 3; i ++){

if(i == 1)

continue lab;

System.out.println(“i = ”+ i);

}

9. 循环嵌套

for(int i = 0; i < 4; i ++){

for((int j = 0; j <3; i ++){

代码内容

}

}

案例:打印如下三角形

思路:外层循环:行;内层循环:*号 *

**

***

for(int i = 1; i <= 3; i ++){

for((int j = 1; j <= i;j ++){

System.out.print(“*”); }

System.out.println();

}

10. 循环嵌套中的循环标签

lab1:for(int i = 0; i < 4; i ++){

lab2:for((int j = 0; j< 3; i ++){ if(j == 1)

break;//跳出内层循环

System.out.println(“i=” + i + “j = ” + j); }

}

结果:i = 0 j = 0

i = 1 j = 0

i = 2 j = 0

for(int i = 0; i < 4; i ++){

for((int j = 0; j <3; i ++){

if(j == 1)

break lab1;

System.out.println(“i=” + i + “j = ” + j); }

}

结果:i = 0 j = 0

continue和break的分析类似

 

第二篇:JAVA知识点总结

JAVA知识点总结一

1 Java中一个char类型可以存放一个汉字吗?为什么?

可以。因为JVM的最小单位是两个字节,而java中以unicode存放汉字了,unicode占用了两个字节。

2 Java中实现多线程的方法有几种?怎样实现同步?

实现多线程的方法有两种:1 扩展Thread类;2 实现Runnable接口

实现方法同步有两种:1 在方法前面加sychronized

2 在方法中调用wait()和notify()或者notifyall();

3 抽象类和接口

抽象类:至少有一个方法不完整的类叫抽象类.抽象类不能被实例化.继承该抽象类的类可以是抽象类,也可以是非抽象类.抽象类用语实现公用代码.

接口:纯粹的抽象类.他的所有方法都没有实现.抽象类用于概括共同行为.

一个类可以实现多个接口,但是只能扩展一个类.接口不能扩展其他类.

何时用抽象类?何时用接口?

当要定义行为模型时用接口,而当实现公共代码时用抽象类.

收获1:

在使用PreparedStatement类的时候。我需要给它set一个时间类型的变量。保存年月日。一直没有意识到这个问题。我只知道 PreparedStatement中的setDate(index.java.sql.Date),方法可以处理。只知道java.sql.Date是 java.util.Date的一个子类。保存数据库中一直是yyyy-MM-dd格式的日期。一直没太注意。现在想保存年月日时分秒了。才想到处理它。

但 是我怎么设置都是年月日。后来看看了jdk的源码,才知道这个date类只能保存年月日。又发现了一个 setTime(index,java.sql.Time)类,高兴了。这次可以了吧。但是还不行。结果只有;时分秒,而没有年月日。看源码才知道他也是 java。Util.Date的一个子类。只保存时分秒。

我郁闷了。难道没有一个保存完整日期的么。再看发现了一个。 setTimestamp(index,

java.sql.Timestamp),哦,这个java.sql.Timestamp应该可以的。不错。他果然支持。这次也顺便看了一眼 java.sql.Timestamp类的源码。不错。今天认识了一下这几个类。

收获2:

今天在写一个循环处理中发现了一个重大的习惯性错误:

代码如下:

for (int j = 0; j < itemList.size(); j++) {

ItemLoginForm item = (ItemLoginForm) itemList.get(j);

String name=form.getForm_id()+"_"+item.getItem_code();

if(request.getParameter(name)!=null)

item.setItem_value(request.getParameter(name));

else

itemList.remove(j); //这里应该是itemList.remove(j--);

}

想法很简单,就是想过滤一下集合。不满足条件的remove掉。但在测试中发现问题。某些元素不参加判断。郁闷了。看了好久才发现原来。List集合在对 他的元素进行处理的时候。执行remove操作。Size会自动减减。所有的元素前移。而变量j的值没有变,这样就错过了下一个元素。确实很难发现。如果 移除某个元素的时候,是j--,这样才能从下一个元素顺次进行。

这个错误使我也清楚地认识了许多细节的东西应该好好的理解,减少这种bug的发生。

1. jvm内部分为主工作区和线程工作区。主工作区是实例的所有线程共有,线程工作区是实例的每个线程专有的工作区,其中包括一些主工作区的一些实例字段数据的拷贝。

2. 服务器一般都有线程池,线程资源是可以重复利用的。你20xx个用户在线,不见得能又200个用户同时(或者说并发)访问。再说,只要对象不是太大,我宁愿用200个拷贝,也不想让用户在这个200个任务的队列里等待。

3. 两个DB之间的复制数据,每个DB各自使用自己的Sequane来生成id。复制数据时,如果DB中的外键是由DB维护的,则不会产生id冲突,如果外键是由外部程序维护的,则可能会产生错误!

4. 对于非static的类的数据成员来说,在该类产生的实例中都有一份,并且相互独立(修改后并不影响其他实例), 但static的数据成员则变成了每个类只有一份,即在该类产生的所有实例共享这一个数据成员, 该数据成员的改变会影响到其他的实例. 而static的方法则是让你不用创建对象及能调用这个方法.

5. ThreadLocal的作用就是将经常要用到的对象的引用放到属于线程自己的一个存储空间中,在该线程的执行过程中,可以通过类的静态的ThreadLocal来方便的获取到这个对象,而不用通过参数的形式传来传去。

相关推荐