java项目实验报告_20165318 《Java程序设计》实验一(Java开发环境的熟悉)实验报告...

20165318 《Java程序设计》实验一(Java开发环境的熟悉)实验报告

一、实验报告封面

课程:Java程序设计        班级:1653班        姓名:孙晓暄        学号:20165318

指导教师:娄嘉鹏                              实验日期:2018年4月2日

实验时间:13:45 - 3:25                    实验序号:实验一

实验名称:Java开发环境的熟悉

实验题目:实现凯撒密码并进行安全加固,并进行测试(正常情况,异常情况,边界情况)

实验内容:

1.使用JDK编译、运行简单的Java程序;

2.使用IDEA 编辑、编译、运行、调试Java程序。

实验要求:

1.没有Linux基础的同学建议先学习《Linux基础入门(新版)》《Vim编辑器》 课程;

2.完成实验、撰写实验报告,注意实验报告重点是运行结果,遇到的问题(工具查找,安装,使用,程序的编辑,调试,运行等)、解决办法(空洞的方法如“查网络”、“问同学”、“看书”等一律得0分)以及分析(从中可以得到什么启示,有什么收获,教训等);

3.实验报告中统计自己的PSP(Personal Software Process)时间;

4.严禁抄袭。

二、实验内容及步骤

(一)使用JDK编译、运行简单的java程序

命令行下的程序开发

步骤一(新建文件夹):打开windows下的git bash → 输入cd java命令进入java目录 → 输入mkdir 20165318test建立以自己学号命名的文件夹 → 输入cd 20165318test进入文件夹 → 输入mkdir exp1建立“实验一”文件夹 → 输入cd exp1进入“实验一”文件夹 → 输入mkdir src ,mkdir bin,建立src和bin文件夹。

d112d824c01930907932b5ae2e851566.png

步骤二(编译、运行java程序):使用git bash中的vim编辑器编辑java程序 → 在命令行下编译、运行

2e2db11d9b7bca8135d3e993e1654a53.png

90941dc6d5272447640987469ff42e5e.png

b0d615287cdf4de6696c201665bbf29e.png

(二)使用IDEA编辑、编译、运行、调试Java程序

1、新建「HelloJDB」类,输入如下代码:

eb631f70f6f2bc944ccf0b109cd33116.png

2、运行「HelloJDB」,单击运行按钮(或使用Alt+Shift+F10快捷键)

1badd4b68366013cf70286b4247feab4.png

3、设置断点,单步运行。

在需要设置断点的一行左侧单击鼠标,出现红色圆点。比如如下在第七行设置了断点:

11998c1a605b72ef7c84f88bde1cfc45.png

在上方Run菜单找到Debug...进行单步调试(或使用Alt+Shift+F9快捷键):

c2ca95ce06fd0589228b0ef29a3ed5d0.png

运行到第七行截止,结果如下:

9550f16971006d3b5ad1665c4c593bf9.png

继续向下单步执行可使用Step Into(快捷键F7)和Step Over(快捷键F8)

250fef30e40f34251b828b2b3eeb4454.png

① Step Over(F8):程序向下执行一行(如果当前行有方法调用,这个方法将被执行完毕返回,然后到下一行)

② Step Into(F7):程序向下执行一行。如果该行有自定义方法,则运行进入自定义方法(不会进入官方类库的方法)

③ Force Step Into:进入任何方法

④ Step Out(Shift+F8):如果在调试的时候进入了一个方法,并觉得该方法没有问题,就可以使用stepout跳出该方法,返回到该方法被调用处的下一行语句。值得注意的是,该方法已执行完毕。

⑤ Run to Cursor:将程序运行到光标处。

可使用Resume(快捷键F9)直接运行完毕,如下图:

4980cc8d7843b4a10eaef4bd72006610.png

4、条件断点

如果想查看大循环中出现的问题,可以通过条件断点来解决。如下图所示设置条件断点,使用Resume(快捷键F9)从上一个断点直接运行到此条件断点。

95955c63d58157af8ed060f354b30e6f.png

(三)练习:实现凯撒密码并进行安全加固,并进行测试(正常情况,异常情况,边界情况)

『要求』:通过命令行和IDEA两种方式实现,在IDEA下练习调试程序。

1、设计思路

我们知道凯撒密码是一种代换密码。他的基本思想是:通过把字母移动一定的位数来实现加密和解密。明文中的所有字母都在字母表上向后(或向前)按照一个固定数目进行偏移后被替换成密文。位数就是凯撒密码加密和解密的密钥。

我要实现使用凯撒密码在不同密钥下对明文,进行加密;或对密文进行解密。

2、代码撰写

shiyan1.java

/**

* Created by SXX on 2018/3/31

*/

import java.io.*;

import java.util.Scanner;

public class shiyan1 {

public static void main(String[] args) {

EncryptAndDecrypt person = new EncryptAndDecrypt();

System.out.print("请选择加密还是解密:(加密输入1,解密输入2)");

Scanner scanner = new Scanner(System.in);

int n = scanner.nextInt();

if (n == 1) {

System.out.print("请输入明文:");

Scanner scanner1 = new Scanner(System.in);

String m = scanner1.nextLine();

System.out.print("请输入密钥:");

Scanner scanner2 = new Scanner(System.in);

int k = scanner2.nextInt();

try {

String serct = person.encrypt(m, k);

System.out.println("密文是:" + serct);

}

catch (EadException e){

System.out.println(e.warnMess());

}

} else {

System.out.print("请输入密文:");

Scanner scanner1 = new Scanner(System.in);

String m = scanner1.nextLine();

System.out.print("请输入密钥:");

Scanner scanner2 = new Scanner(System.in);

int k = scanner2.nextInt();

try {

String source = person.decrypt(m, k);

System.out.print("明文是:" + source);

}

catch (EadException e){

System.out.println(e.warnMess());

}

}

}

}

EncryptAndDecrypt.java //凯撒密码

public class EncryptAndDecrypt {

String encrypt(String sourceString, int password) throws EadException{ //加密算法

char[] c = sourceString.toCharArray();

int m = c.length;

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

if(c[i]>122||c[i]<65||(c[i]>90&&c[i]<97)){

throw new EadException(sourceString);

}

int mima = (c[i] - 'a' + password) % 26 + 'a'; //加密

c[i] = (char) mima;

}

return new String(c); //返回密文

}

String decrypt(String sourceString, int password) throws EadException{ //解密算法

char[] c = sourceString.toCharArray();

int m = c.length;

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

if(c[i]>122||c[i]<65||(c[i]>90&&c[i]<97)){

throw new EadException(sourceString);

}

int n = c[i] - 'a' - password;

if (n <= 0) {

n = n + 26;

}

int mima = n % 26 + 'a'; //解密

c[i] = (char) mima;

}

return new String(c); //返回明文

}

}

EadException.java //自定义异常类

public class EadException extends Exception{

String message;

public EadException(String sourceString){

message = "所输入的字符不符合要求";

}

public String warnMess(){

return message;

}

}

3、运行结果

命令行实现:

正常情况

96737c85dce58f0f31fc7906f51ac32e.png

边界情况

0f25bce05e78e0a4b7ba34a460de937c.png

25fe3c64c412fb8bd0500f61aebeb307.png

异常情况

f8fe2d8b10c6e7d544c67423f48e72ef.png

IDEA调试:

正常情况

d088478196ebc46727b4a0552ae70094.png

边界情况

ada5a3c08744fc770e15034d79d04e96.png

da58e3f7a69b1511e27215b703b577e6.png

异常情况

cdbdeffdfe69b165f3830e2ea11515f0.png

6fba7c3d96ceea77e0a98e37442db2c7.png

b6cf63b9aa8b7242a8f15d0d52381434.png

三、实验过程中遇到的问题

问题1:当输入字母处于临界值时,不能正常字母,出现异常字符,如下图:

6a205b186b11c6392e0451a82869b0be.png

解决过程:使用终端计算后发现,解密时,当字母对应ASCII码取余26,如果是负数,就会输出异常字符,在程序中添加if语句,负数是加上26,就可以解决了。

问题2:在使用异常类时,我本来想直接使用IOException异常类,但是程序报错。

解决过程:在查阅Scanner类会出现的异常时发现,IOException异常类用于,参数有流的情况下,而我的代码中没有使用流。因此我自己定义了一个异常类,问题得以解决。

四、实验体会与总结

“纸上得来终觉浅,绝知此事要躬行。”书上的代码敲的有3000多行了,真正掌握了书上多少知识点我并不清楚。“实践是检验真理的唯一标准。”实验使我将理论用于实际,对课本知识有了更深的理解。

刚开始看到这个题目的时候,感觉不是很难,但仔细分析之后发现,要真正完整的实现凯撒密码,考虑到尽可能多的情况并不容易,我最初只是进行了一个大致的设计,然后就开始上手编代码,其中遇到很多没有想到的情况,就要打断原来的思路,甚至颠覆之前的想法,这使我编写代码的效率大大降低。因此,敲代码前先构思好整体的框架,尽可能多的想会出现的问题及解决方法,在再编写时用细节一点一点的填充。

之前看书时,我不太理解为什么要将不同的类分开,觉得这样查看起来很麻烦。但这次实验使我感觉到编写时将不同的类分开的好处。最初的代码,我将两个大类都放在一起,出现问题时,要一直上下翻看对比,在自定义异常类时,我将所有的类都分开了,一目了然,运行出现问题时,也比较好查看。

这个代码算是我真正自己编写的代码,编完之后,一股成就感油然而生。这次实验不仅使我更加深入的理解了教材上的知识点,而且锻炼了我的思考能力,让我意识到拥有正确的编程思想的重要性。

码云链接:

代码上传截图:

a7a068767484788184c1cdd80e78aab8.png

步骤

耗时

百分比

需求分析

4min

4%

设计

5min

5%

代码实现

60min

64%

测试

4min

5%

分析总结

20min

22%

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值