学习总结

一:异常处理
1>:当程序出现一些问题的,可以是严重问题,可以是一种异常,将这些通常为Throwable
*Throwable 类是 Java 语言中所有错误或异常的超类
Throwable
error
exception

举例:
张三去山上旅行
1)张三骑车去旅行,山路崩塌了,不能前行了----->不可抗力因素
2)张三骑车去旅行,骑着发现轮胎没气了------->需要检查的问题
3)骑着,山路有石子,他就非得往石子上骑,导致车胎没气了---->自己原因造成的,no zuo no die

不抗力因素----->error: 属于严重问题 内存溢出了 (加载页面中大量图片的时候,程序会挂掉---使用第三方的框架去处理:ImageLoader)
异常:
编译时期异常:只要出现的不是运行时期异常,统称为编译时期 日期的文本格式---解析 java.util.Date类型:ParseException:解析异常
编译时期异常:开发者必须处理!
运行时期异常:RuntimeException
编译通过了,但是开发者代码不严谨(NullPointerExceptino等等...)
2>:异常的处理分为两种:
1)try...catch...finally (标准格式) :捕获异常
2)throws ... 抛出异常

变形格式...
try...catch...
try...catch...catch...
catch....
try{
一些代码
try里面的代码越少越好
代码包含了可能会出现问题的代码
}catch(异常类 异常类对象){
try出现异常了,描述的异常刚好就是catch的异常类,就会执行catch里面代码
//处理异常
}
/
public class ExceptionDemo2 {
public static void main(String[] args) {
int a = 10 ;
int b = 0 ;
try {//捕获到
//出现问题的代码
System.out.println(a/b);
}catch(ArithmeticException e) { //ArithmeticException e = new ArithmeticException() ;
//用输出语句来处理异常
System.out.println("初始不能0");
// e.printStackTrace();
}
System.out.println("over");
}
}
3>:如何处理多个异常
两个或两个以上的异常的时候怎么办?

try{
可能出现问题的代码
}catch(异常类 对象名){
处理异常的代码
}

try{
可能出现问题的代码
int[] arr = {1,2,3} ;
Sop(arr[3]);
int a = 10 ;
int b =0 ;
Sop(a/b) ;

}catch(异常类名1 对象名1){
//异常处理
}catch(异常类名2 对象名2(){

//异常处理
}
*/
public class ExceptionDemo3 {
public static void main(String[] args) {
//method1();
//method2();

//两个异常的处理:直接进行处理,不用分别try...catch
// method3();
/int a = 10 ;
int b = 0 ;
int[] arr = {1,2,3} ;
try {
//产生一个异常对象
System.out.println(arr[3]);
System.out.println(a/b);
System.out.println("代码可能到这一步出现了问题,怎么办?");
}catch(Exception e) { //最大的类不能出现在这个位置
System.out.println("程序出问题了....");
}catch(ArithmeticException e) {
System.out.println("除数不能为0");
}catch(ArrayIndexOutOfBoundsException e) { //爷爷 (最大的类一定在最后 几个异常 extends RuntimeException extends exception
System.out.println("访问了数组中不存在的角标");
}
/
}
private static void method3() {
int a = 10 ;
int b = 0 ;
int[] arr = {1,2,3} ;
try {
//产生一个异常对象
System.out.println(arr[3]);
System.out.println(a/b);
System.out.println("代码可能到这一步出现了问题,怎么办?");
}catch(ArrayIndexOutOfBoundsException e) {
System.out.println("访问了数组中不存在的角标");
}catch(ArithmeticException e) {
System.out.println("除数不能为0");
}catch(Exception e) { //爷爷 (最大的类一定在最后 几个异常 extends RuntimeException extends exception
System.out.println("程序出问题了....");
}
}
//两个异常的处理
//分别try...catch
private static void method2() {
int a = 10 ;
int b = 0 ;

try {
System.out.println(a/b);
}catch(ArithmeticException e) {
System.out.println("除数不能为0");
}

int[] arr = {1,2,3} ;
try {
System.out.println(arr[3]);
}catch(ArrayIndexOutOfBoundsException e) {
System.out.println("访问数组中不存在的角标...");
}
}
//一个异常的处理
private static void method1() {
int a = 10;
int b = 0 ;
try {
System.out.println(a/b);
}catch(ArithmeticException e) {
System.out.println("除数不能为0");
}
}
}
4>:Jdk7以后出现另一种方式处理多个异常

try{
可能出现问题的代码;
}catch(异常类名1 | 异常类名2 |... 对象名){

处理异常
}
5>:Jdk7以后出现另一种方式处理多个异常

try{
可能出现问题的代码;
}catch(异常类名1 | 异常类名2 |... 对象名){

处理异常
}
/
public class ExceptionDemo {
public static void main(String[] args) {
/
int a = 10 ;
int b = 0 ;
int[] arr = {1,2,3} ;
try {
System.out.println(a/b);
System.out.println(arr[3]);
}catch(ArithmeticException e) {
System.out.println("除数不能为空");
}catch(ArrayIndexOutOfBoundsException e) {
System.out.println("访问了数组中不存在的脚标");
}catch(Exception e) {
System.out.println("程序出问题了....");
}*/

//jdk7以后的方式
//注意:catch中多个异常类属于同一个级别
int a = 10 ;
int b = 0 ;
int[] arr = {1,2,3} ;
try {
//可能有问题
System.out.println(a/b);
System.out.println(arr[3]);
}catch(ArithmeticException | ArrayIndexOutOfBoundsException e) {
System.out.println("程序出问题了...");
}
}
}
6>:编译时期异常和运行时期异常的区别?

编译时期:开发者必须进行显示处理,不处理,编译不能通过,
运行时期异常:无需进行显示处理,可以像编译时期一样进行处理

处理异常的第二种方式:使用throws 抛出异常 (跟在方法的后面)
xxx 返回值 方法名() throws 异常类名{
}
7>: 标准格式 try{ ... }catch(异常类 对象){ // 异常处理 } 执行try里面的代码
,如果出现了问题,它会通过代码的问题创建一个异常对象,然后通过异常对象和catch里面的异常类是否一致
如果一致的情况,就会出现catch里面的代码,执行Throwable里面的方法

public String getMessage() :消息字符串
public String toString(): 异常的简短描述 ":
":由冒号和空格组成

public void printStackTrace():返回值void 直接调用, 包含了消息字符串,还有": "
信息描述,具体出现异常的代码定位以及定位的源码上
*/
public class ExceptionDemo3 {
public static void main(String[] args) {
//定义日期文本格式
try {
String strDate = "2018-6-20" ;
SimpleDateFormat sdf = new SimpleDateFormat("yyyy-MM-dd HH:mm:ss") ;
//解析
Date d = sdf.parse(strDate) ; //
System.out.println(d);

}catch(ParseException e) { //创建一个异常对象:PareException e = new ParseException() ;
//使用throwable里面的一些方法
// String str = e.getMessage() ;
// System.out.println(str);//Unparseable date: "2018-6-20"
/*String str = e.toString() ;//简单描述
System.out.println(str);//包名.类名: getMessage() ;
/
//public void printStackTrace():返回值void 直接调用(输出在控制台的), 包含了消息字符串,还有": "
// 信息描述,具体出现异常的代码定位以及定位的源码上
e.printStackTrace();
}
System.out.println("日期解析完毕...");

System.out.println("---------------------------");

//final,finally,finalize的区别?
//final 可以修饰类,该类不能被继承;可以修饰变量,该变量是常量;可以修饰成员方法,该方法重写
//finalize:gc():运行垃圾回收器,实际是调用finalize()方法,和垃圾回收器有关系
//finally:在io,数据库中以及后面对数据库操作(DBUtuls/c3p0/Hibernate/MyBatis)里面中释放资源的

try {
    String str = "2018-6-20" ;
    SimpleDateFormat sdf = new SimpleDateFormat("yyyy-MM-dd") ;
    Date dd = sdf.parse(str) ;
    System.out.println(dd);
    System.exit(0); //finally中代码:只有在一种情况下,它不会执行,在指向finally语句之前,jvm退出了
} catch (ParseException e) {
    e.printStackTrace();//处理异常的:直接有问题 直接打印在控制台上,告诉开发者哪一块有问题!
}finally {
    //释放资源
    System.out.println("这里释放资源....");
}

}
}
8>:
throw:表示也是抛出异常,抛出的一个异常对象 (throw new 异常类名() :匿名对象的方式)

面试题:
throws和throw的区别?
throws:也是表示抛出异常,它后面跟的异常类名,并且可以多个异常类名中间逗号开
举例:
public void show() throws IoException,ClassNotFoundException{...}
在方法上抛出,由调用者处理
它表示抛出异常的可能性
throw:抛出的一个异常对象
在语句体中抛出的,由语句体进行处理
它表示抛出异常的肯定性
9>:try...catch...finally
finally语句体是一定会执行的,除非是Jvm退出了
面试题:
如果catch里面有return 语句,finally中的代码还会执行,是在return语句之前执行还是return后执行?
finally中代码是一定会执行的,是在return前
/
public class FinallyTest {
public static void main(String[] args) {
System.out.println(getInt());
}
private static int getInt() {
int a ;
try {
a = 10 ;
System.out.println(a/0);
a = 20 ;
}catch(Exception e) {
a= 30 ;
return a ;
/*
try的代码出现问题了,执行catch中的语句,30赋值a,
return 30(已经形成了一个回路径)finally代码一定会执行(除非Jvm) a = 40 ,在fianlly外面
有return a: a记录回路径的那个a,返回30
/
}finally {
//除非jvm退出了
a = 40 ;
}
return a;//30
}
}
10>:
异常中的注意事项:
子类继承父类的时候的注意事项
1)子类重写父类的方法的时候,子类的方法的抛出的异常必须要么是父类的方法异常一样,要么是父类方法异常的子类
2)子类重写父类方法的时候,如果父类中的这个方法没有抛出异常,那么子类重写的这个方法也不能抛出异常,只能try...catch
二:
1>:File类:表示文件或者目录的路径的抽象表现形式. IO流就是对文件进行操作的
public File(String pathname):表示pathname的抽象路径表现的形式 (开发中使用这种方式)
public File(String parent,String child)
根据 parent 路径名字符串和 child 路径名字符串创建一个新 File 实例
*public File(File parent, String child):根据一个file对象和一个文件路径来构造File实例

/
public class FileDemo {
public static void main(String[] args) {
//表示:e盘下的demo文件夹中的a.txt文件
//E:\dmeo\a.txt
// public File(String pathname):表示pathname的抽象路径表现的形式
File file = new File("E:\demo\a.txt") ;
System.out.println(file);
//
public File(String parent,String child)
File file2 = new File("E:\demo","a.txt");
System.out.println(file2);
//3.public File(File parent, String child)
File file3 = new File("E:\demo") ;
File file4 = new File(file3, "a.txt") ;
System.out.println(file4);

//三种方式都可以使用(表示文件/目录的路径的抽象形式),根据具体的要求(第一种方式最常用的)

}
}
2>:跟创建相关的功能:
public boolean createNewFile():创建文件,当文件不存在的时候,创建此抽象路径下的文件
public boolean mkdir():创建一个文件夹,如果文件夹存在,不创建
public boolean mkdirs():创建文件夹,如果父目录不存在,会创建此目录

*/
public class FileDemo2 {
public static void main(String[] args) throws IOException {
//E盘下创建demo文件夹
File file = new File("e:\demo") ;
System.out.println("mkdir:"+file.mkdir());

System.out.println("------------------------");

//public boolean createNewFile():创建文件,当文件不存在的时候,创建此抽象路径下的文件
//本身方法异常:IOException
File file2 = new File("e:\demo\a.txt") ;
System.out.println("createNewfile:"+file2.createNewFile());

///java.io.IOException: 系统找不到指定的路径。
File file3 = new File("e:\test\b.txt") ;
System.out.println("createNewFile:"+file3.createNewFile());
//创建文件的前提:文件夹一定要存在,如果不存在,IOException

//public boolean mkdirs():创建文件夹,如果父目录不存在,会创建此目录
//在E盘下创建E:\aaa\bbb\ccc
/File file4 = new File("e:\aaa") ;
System.out.println("mkdir:"+file.mkdir());
/

File file4 = new File("E:\aaa\bbb\ccc") ;
System.out.println("mkdirs:"+file4.mkdirs());
}
}
3>:删除功能
public boolean delete() :删除文件或者文件夹(目录不能是空的) :逐一删除文件或者目录的

如果创建一个文件/目录,没有写盘符的时候,会创建在哪里呢?
会创建在当前项目路径下
4>:
绝对路径:c:\xxx\xxx.txt
相对路径:a.txt
*回想:html页面(以后jsp页面)
后台地址 :URI 统一资源定位符
<form action="http://localhost:8080/Web工程名称/后台(XXX.servlet)" metod="提交方式">
用户名:<input type="text" name="username"/>
密码:<input type ="password" name="pwd"/>
<input type ="hidden" name="hid"/>

<img src="图片的路径"/>
</form>

页面的重定向/转发
response.sendRedirect("/工程名称/xxx.jsp") ;
File 的重命名功能:
public boolean renameTo(File dest)重新命名此抽象路径名表示的文件。
如果路径名一致的情况,那么只是重命名
如果两次路径名称不一致,那么不只是重命名,并且剪切
/
public class FileDemo {
public static void main(String[] args) {
//表示当前项目下的高圆圆.jpg这个文件
File file = new File("高圆圆.jpg") ;
File newFile =new File("杨桃.jpg") ;
System.out.println("renameTo():"+file.renameTo(newFile));
System.out.println("-------------------------");
File file2 = new File("杨桃.jpg") ;
File file3 = new File("e:\高圆圆.jpg") ;
System.out.println("renameTo():"+file2.renameTo(file3));
}
}
5>:File类的判断功能
public boolean isDirectory():判断是否是文件夹
public boolean isFile() :判断是否是文件
public boolean canRead(): 是否可读
public boolean canWriter():是否可写
public boolean exists() :是否存在
public boolean isHidden():是否是隐藏文件
6>:
File类的获取功能:
public String getAbsolutePath():获取抽象文件的绝对路径
public String getPath():获取相对路径的字符串
public String getName()返回由此抽象路径名表示的文件或目录的名称
public long length()返回由此抽象路径名表示的文件的长度。
public long lastModified():文件最后一次被修改的时间(时间毫秒值)
*/
6>:
File的高级功能
public String[] list() :获取当前某个路径下的所有的文件夹以及文件名称的字符串数组
public File[] listFiles() :获取当前某个路径下所有的文件夹以及文件的File数组

需求:获取e盘下所有的文件夹以及文件的名称
*/
public class FileDemo {
public static void main(String[] args) {
//表示e盘
File file = new File("e:\") ;
String[] list = file.list() ;
for(String s:list) {
System.out.println(s);
}
System.out.println("--------------------------");

File[] fileArray = file.listFiles() ;
//防止他出现空指针异常
if(fileArray !=null) {
//遍历
for(File f:fileArray) {
System.out.println(f.getName());
}
}
}
}
7>:
1 )判断E盘目录下是否有后缀名为.jpg的文件,如果有,就输出此文件名称
e盘下:图片文件
思路:
1)使用File对象表示e盘的根目录
2)File[] listFiles() ;String[] list() 获取当前盘符下所有的文件以及文件夹的File数组
3)对File数组对象进行非空判断,判断他是否为null,不是null,遍历
4)如果他是文件,并还有满足是否以.jpg结尾
满足就可以进行输出文件名称
*/
public class FileTest2 {
public static void main(String[] args) {
//封装e盘根目录
File file = new File("e:\") ;
//获取当前盘下所有的文件夹以及文件的File数组
File[] fileArray = file.listFiles() ;
//非空判断
if(fileArray!=null) {
//遍历
for(File f :fileArray) {
//将每一个表示的文件/文件夹对象遍历出来
//判断是否是文件
if(f.isFile()) {
//满足文件
//并且以.jpg结尾的
if(f.getName().endsWith(".jpg")) {
//满足就输出
System.out.println(f.getName());
}
}
}
}
}
}
8>:
)判断E盘目录下是否有后缀名为.jpg的文件,如果有,就输出此文件名称
使用方式:A:封装e盘,获取所有的文件以及文件夹的File数组(文件以及文件及的名称数组)
遍历的时候进行一系列判断进行条件过滤,麻烦
B:当前获取到的时候就已经拿到.jpg文件等等....
File的高级功能
public String[] list(FilenameFilter filter)
public File[] listFiles(FilenameFilter filter)

FilenameFilter:一个接口:  文件名称过滤器
boolean accept(File dir, String name)测试指定文件是否应该包含在某一文件列表中。

        文件是否包含在文件列表中,取决于返回值,true;false表示不包含

*/
public class FileTest3 {
public static void main(String[] args) {
//封装e盘
File src = new File("e:\");//表现形式

//采用文件名称过滤器:匿名内部类的方式
String[] strArray = src.list(new FilenameFilter() {

@Override
public boolean accept(File dir, String name) {

// return false;
//首先封装File对象
/*File file = new File(dir, name) ;
//判断是否文件
boolean flag = file.isFile() ;
boolean flag2 = name.endsWith(".jpg") ;

    return flag && flag2 ;*/

    //一步走
    return new File(dir, name).isFile() && name.endsWith(".jpg") ;
}

}) ;

//遍历字符串数组
for(String s: strArray) {
System.out.println(s);
}
}
}
三:IO流内容
1>:IO:在设备和设备之间的一种数据传输!
IO流的分类:
按流的方向分:
输入流: 读取文件 (e:\a.txt):从硬盘上文件读取出来后输出这个文件的内容
输出流: 写文件:将e:\a.txt 内容读出来--->写到f盘下
按数据的类型划分:
字节流
字节输入流:InputStream :读取字节
字节输出流:OutputStream :写字节
字符流
字符输入流:Reader :读字符
字符输出流:Writer :写字符
需求:在当项目下输出一个文件,fos.txt文件(文本文件)
只要文本文件,优先采用字符流,字符流在字节流之后出现的
使用字节流进行操作
无法创建字节输出流对象:OutputSteam :抽象类,不能实例化
又学习过File类,并且当前是对文件进行操作,子类:FileOutputSteam进行实例化

File+InputStream
File+OutputStream
FileXXX (FileReader)
FileXXX (FileWriter)

开发步骤:
1)创建字节输出流对象
2)写数据
3)关闭资源
2>:
关于字节输出流写数据的方法
public void write(int b):一次写一个字节
public void write(byte[] b) :一次写一个字节数组
public void write(byte[] b, int off,int len):一次写一部分字节数组
@author 张杨
/
public class FileOutputStreamDemo2 {
public static void main(String[] args) throws Exception {
//构造一个字节数出流对象
FileOutputStream fos = new FileOutputStream("fos2.txt") ;

//写数据
//一次一个字节
// fos.write(97);
// fos.write(127);
// public void write(int b):
// public void write(byte[] b) :一次写一个字节数组
byte[] bys = {97,98,99,100,101} ;
// fos.write(bys);
// public void write(byte[] b, int off,int len):一次写一部分字节数组
fos.write(bys, 0, 2);
//关闭资源
fos.close();
}
}
3>:
\需求:输出文本文件,给文本文件中添加一些数据

问题:
写一些数据,这些数据并没有换行,如何实现换行的效果...
针对不同的操作系统,里面的换行符合不一样的

windows: \r\n
Linx:\n
mac:\r

一些高级记事本针对任意的换行会有换行的效果

问题:如何末尾追加数据呢
public FileOutputStream(File file, boolean append):指定为true,末尾追加数据

*/
public class FileOutputStreamDemo {
public static void main(String[] args) throws Exception {
//1)创建字节文件输出流对象:FileOutputStream
// FileOutputStream fos = new FileOutputStream("fos3.txt") ;
FileOutputStream fos = new FileOutputStream("fos3.txt",true) ;
//2)写数据
for(int x = 0 ; x < 10 ; x ++) {
fos.write(("hello"+x).getBytes());
//写入换行符号
fos.write(("\r\n").getBytes()); // editplus工具
}

//3)释放资源
fos.close();
}
}
4>:
IO流中加入异常处理(try...catch...)
*/
public class FileOutputStreamDemo2 {
public static void main(String[] args) {
FileOutputStream fos = null;
try {
fos = new FileOutputStream("fos3.txt");
fos.write("hello".getBytes());
} catch (IOException e) {
e.printStackTrace();
// 释放资源
// 对象对象进行非空判断 :数据连接池 (由于很多资源:Statment,PreparedStatement)
} finally {
if (fos != null) {
try {
fos.close();
} catch (IOException e1) {
e1.printStackTrace();
}
}
}
}
}
4>:
需求:去读取当前项目下的fis.txt这个文件内容,将文件的内容输出在控制台上
InputStream抽象类:字节输入流
FileInputStream
构造方法:
public FileInputStream(String name)
开发步骤:
1)创建字节文件输入流对象
2)读数据
3)释放资源

读数据方式:
public abstract int read():一次读取一个字节
public int read(byte[] b):一次读取一个字节数组 (读取实际的字节数)

*/
public class FileInputStreamDemo {br/>@Test
public void demo() throws Exception{
//创建一个字节文件输入流对象
//方式1:一次读取一个字节
FileInputStream fis = new FileInputStream("fis.txt") ;
int by = 0 ;
while((by=fis.read())!=-1) {
System.out.print((char)by);
}

//释放资源
fis.close();
}
}
5>:
public int read(byte[] b):一次读取一个字节数组 (读取实际的字节数)
public static void main(String[] args) throws Exception {
//创建一个字节文件输入流对象
FileInputStream fis = new FileInputStream("fis2.txt") ;
byte[] bys2 = new byte[1024] ;
int len2 = 0 ;
while((len2=fis.read(bys2))!=-1) { //判断,赋值,循环
System.out.println(new String(bys2, 0, len2)); //带上len的用法
}
}
}
6>:
复制文本文件。
将当前项目下的a.txt文件的内容读取出来,复制到b.txt文件中
@author Administrator
源文件: a.txt ---> 读取文件的内容---->FileInputStream
目的地文件: b.txt----> 输出文件 --->FileOutputStream
本身读写操作:
读取一个字节,写一个字节,针对不会出现中文乱码的问题..
/
public class CopyFileDemo{
public static void main(String[] args) throws Exception {
//封装目的地文件和源文件
FileInputStream fis = new FileInputStream("a.txt") ;
FileOutputStream fos = new FileOutputStream("b.txt") ;

//进行读写操作
//一次读取一个字节
int by = 0 ;
while((by=fis.read())!=-1) {
//第一个字节,写个一个字节
fos.write(by);
}
System.out.println("------");

//一次读取一个字节数组

//释放资源
fis.close();
fos.close();
}
}
7>:
复制文件:
源文件:c:\a.txt
目的地文件:d:\b.txt

源文件---->FileInputStream 读取操作
目的地文件--->FileOuputStram 写入操作

*/
public class CopyFileDemo2 {
public static void main(String[] args) throws Exception {
//封装目的地文件和源文件
FileInputStream fis = new FileInputStream("c:\a.txt") ;
FileOutputStream fos = new FileOutputStream("d:\b.txt") ;

//读写操作
int by = 0 ;
while((by=fis.read())!=-1) {
//不断写数据
fos.write(by);
}

//释放资源
fos.close();
fis.close();
}
}
8>:
源文件: 高圆圆.jpg
目的地文件: mm.jpg

源文件: FileInputStream --->读取
目的地文件: FileOutputStream--->写入
@author Administrator
*/
public class CopyImageDemo {
public static void main(String[] args) throws Exception {
//封装源文件和目的地文件
FileInputStream fis = new FileInputStream("高圆圆.jpg") ;
FileOutputStream fos = new FileOutputStream("mm.jpg") ;

//读写操作
//一次读取字节数组
byte[] bys = new byte[1024] ;
int len = 0 ;
while((len=fis.read(bys))!=-1) {
//写数据
fos.write(bys, 0, len);
}

//释放资源
fis.close();
fos.close();
}
}
9>:
递归:只的是方法调用方法本身的一种现象
Math类:max() 方法 Math.max(10,Math.max(15,20)); 方法嵌套
举例
方法递归:
public void show(int n){
if(n<0){
System.exit(0) ;//jvm退出了
}

System.out.println(n) ;
show(n--) ;
}
方法递归的三个必要条件:
1)方法递归必须有出条件
2)必须满足一些规律
3)一定要写方法
注意:构造方法不存在方法递归的
举例
从前有座山,山里有个庙,庙里有个老和尚和小和尚,老和尚给老和尚讲了一个故事是:
从前有座山,山里有个庙,庙里有个老和尚和小和尚,老和尚给老和尚讲了一个故事是:
从前有座山,山里有个庙,庙里有个老和尚和小和尚,老和尚给老和尚讲了一个故事是:
从前有座山,山里有个庙,庙里有个老和尚和小和尚,老和尚给老和尚讲了一个故事是:
条件结束:山塌了,或者和尚挂了
*/
public class DIGuiDemo {
/public DiGuiDemo() {
DiGuiDemo(){}
}
}
10>:
需求:求5的阶乘
public static void main(String[] args) {
private static int jieCheng(int n) {
if(n==1) {
return 1 ;
}else {
return njieCheng(n-1) ;
}
}
}

猜你喜欢

转载自blog.51cto.com/13678296/2117871