本文目录一览:
- 1、如何从DOE实验设计的最佳参数最终得到一个控制范围?
- 2、求解JAVA编程题:编写一个程序,通过命令行参数方式获得5个整数,并输出这5个数的累加和
- 3、java编程:编写应用程序,从命令行输入两个小数参数,求它们的商。要求程序中捕捉NumberFo
- 4、java 8 新特性中p->p.setLastName("Doe"));
如何从DOE实验设计的最佳参数最终得到一个控制范围?
可以在进行DOE响应优化器之后进行预测分析,给定不同的参数进行结果的预测,帮助我们去确认哪个参数区间是最优的。
求解JAVA编程题:编写一个程序,通过命令行参数方式获得5个整数,并输出这5个数的累加和
if (args.length!=5) {
System.out.println("请输入5个整数");
System.exit(1);
}
int sum=Integer.valueOf(args[0])+Integer.valueOf(args[1])
+Integer.valueOf(args[2])+Integer.valueOf(args[3])
+Integer.valueOf(args[4]);
System.out.println(sum);
java编程:编写应用程序,从命令行输入两个小数参数,求它们的商。要求程序中捕捉NumberFo
分析题目
NumberFormatException,数字格式异常,常见于由字符串转换到数字的时候会出现
比如abc2.0--转换成数字时,系统就会抛出这个异常。
ArithmeticException ,除0异常。这个异常常见于整数除整数,如果被除数是0,那么会抛出这个异常。但是提示要求是小数除小数。double小数就算是0,那么在存储的时候也不是简单的0,而可能是0.00000000001等情况,那么除零异常就不会被抛出。我们可以自己手动判断被除数是否等于0,如果等于0,那么我们手动抛出该异常,然后进行捕获
参考代码一:简洁版
import java.util.Scanner;
public class DivDemoSp {
public static void main(String[] args) {
Scanner sc = new Scanner(System.in);
while(true){
try{
System.out.println("输入除数");
double d1 = Double.parseDouble(sc.nextLine());
System.out.println("输入被除数");
double d2 = Double.parseDouble(sc.nextLine());
if(d2==0){
throw new ArithmeticException("捕获到除0异常~~!!");//手动抛出除零异常
}
double d3 = d1 / d2;
System.out.println("计算结果:" + d1 + "/" + d2 + "=" + d3);
break;//如果能正常运行到这里,说明前面的输入都是正确的,所以可以跳出循环了
}catch(NumberFormatException e1){//捕获数字格式异常
System.out.println("捕获到数字格式异常");
continue;
}catch (ArithmeticException e2) {//捕获到除零异常
System.out.println(e2.getMessage());
continue;
}
}
}
}
测试代码
输入除数
12
输入被除数
捕获到除0异常~~!!
输入除数
12
输入被除数
agc
捕获到数字格式异常
输入除数
12
输入被除数
0.5
计算结果:12.0/0.5=24.0
参考代码二:
public class DivDemo {
static Scanner sc = new Scanner(System.in);// 定义一个扫描器,用于读取输入信息
public static void main(String[] args) {// main方法
div();// 调用除法方法
}
//div方法,用于得到2个小数,并且进行除法运算,如果被除数为0.抛出除零异常
static void div() {
double d1 = getNum("输入 除数");// 调用输入数字的方法
double d2 = getNum("输入被除数");
try {
if (d2 == 0) {//如果被除数等于0,那么抛出除零异常
throw new ArithmeticException("捕获到除零异常!!!");
}
double d3 = d1 / d2;
System.out.println("计算结果:" + d1 + "/" + d2 + "=" + d3);
// div();//可以重新调用div方法,再次进行输入
} catch (ArithmeticException exception) {//捕获到除零异常
System.out.println(exception.getMessage());//打印出异常信息
// div();//当捕获异常后,也可以重新调用div方法,再次进行输入
}
}
//getNum方法,用于得到一个数字
static double getNum(String tips) {
double dnum;// 定义一个小数变量
while (true) {
try {
System.out.println(tips);// 显示提示文字
String s1 = sc.nextLine();// 读取输入的一行信息
dnum = Double.parseDouble(s1);// 如果可以把输入的信息转换成数字就跳出循环,
// 如果无法把信息转成数字就会报数字格式异常
break;//跳出循环
} catch (NumberFormatException exception) {//捕获数字格式异常
System.out.println("捕获到了数字格式错误异常!!!");//提示文字,并且继续循环
}
}
return dnum;//返回数字
}
}
运行测试
输入 除数
1.0
输入被除数
捕获到除零异常!!!
输入 除数
1.0abc
捕获到了数字格式错误异常!!!
输入 除数
1.0
输入被除数
0.5
计算结果:1.0/0.5=2.0
java 8 新特性中p->p.setLastName("Doe"));
这是lambda表达式,也就是匿名函数,对于
persons.forEach(p-p.setLastName("Doe"));
这句代码,persons是一个list,forEach是一个内部迭代的方法,p-p.setLastName("Doe")是一个匿名函数对象。
这个语句等价于
for (Person p : persons) {
p.setLastName("Doe");
}
但是用for循环是外部迭代,速度略慢。
p-p.setLastName("Doe")
p是指list当中取出的对象,p可以自己定义,你写a也可以,相应的就要变成
a-a.setLastName("Doe")
-是lambda表达式的符号,-左边的对象去传入lambda函数体p.setLastName("Doe"),是前面传入的p去调用setLastName方法,如果要调用多个方法,那么方法体要用花括号包含
例如persons.forEach(p-{
p.setLastName("Doe")
System.out.println(p);
});
综上所述
persons.forEach(p-p.setLastName("Doe"));
是把p-p.setLastName("Doe");这个函数对象,给了persons的迭代器,让迭代器用这个函数去对集合中的每一个对象使用
有了lambda,你可以这样定义一个新的线程
new Thread(() - {System.out.println("hello word!");}).start();
() - {System.out.println("hello word!");}这句语句其实就是runnable接口的实现对象,
编译器会根据函数需要实现的接口去隐式转换,Thread的构造方法需要传递Runnable接口的实现类,所以new Thread(() - {System.out.println("hello word!");}).start();相当于
new Thread((Runnable)() - {System.out.println("hello word!");}).start();
其中()是匹配接口中的无参函数,因为Runnable接口中run方法为无参所以是()
-指明前面是传入参数,后面是函数体
有了lambda就能写出更加漂亮的代码,以及更少的工作量,实现一个方法的接口用匿名内部类的话看起来是冗余代码了
纯手打望采纳