Java实验报告经验总结

每一段是每一次实验报告写的经验总结,一共是一学期的内容

文章目录

      ~~~~~       分析:这次做程序中也出了不少问题,究其根本还是没有理解清楚各语句功能和其应用。
      ~~~~~       比如说:当我们在定义浮点数时,数字的后面必须加上f或F。还需要注意的是java中唯一个public类的名字要和文件名相同,否则不能编译,会报错。在写System.out.println(“”);语句时,System的第一个s必须要大写,因为Java是严格区分大小写的。Java中的布尔类型是boolean,而c++中是bool,所以这点要区分好。
      ~~~~~       “细节决定成败”,所以在写代码的时候一定要一丝不苟。


      ~~~~~       通过此次实验掌握了JAVA语言的基本语法和基本数据数据类型的使用方法;并且可以熟练运用分支、循环等语句控制程序流程,对一些基本类型的数据和语句的使用都有了进一步的了解。在较熟练的掌握和运用浅层书面知识的基础上,能对较复杂的题目进行分析、编译和运行。
      ~~~~~       此次实验的内容没有错误出现,比较顺利的完成了编写运行。通过亲自写出代码对for循环语句和数组的使用更加了解,并且在我写的过程中和之前学过的c++知识进行对比,这让我更加清晰java和c++的不同之处,也有利于我对java语言的各种知识点的记忆。
      ~~~~~       不管是在是在实验中还是在课外的实践中,写java的时候都遇到了一些需要重视的问题,特别是一些微小的细节。避免因为一些小错误导致代码不能运行,“千里之堤,溃于蚁穴”就是这个道理。所以我们在写代码的时候应当认真思考,全神贯注,一丝不苟。


      ~~~~~       1.首先通过这次编程对输入函数Scanner sc=new Scanner(System.in);有了进一步的了解。
输入一个整数的代码例子:

int n;
Scanner sc=new Scanner(System.in);
n=sc.nextInt();

      ~~~~~       2.此外,还学习到通过System.out.printf(“%nd”,x);可以控制整数x的输出位数,%nd表示输出数字x时占用n个位置,默认为右对齐方式,不足用空格补齐。
      ~~~~~       3.同时又强化了二维数组的初始化, int [][]a=new int [n][n];
只有我们在平常的时候将这些基础打牢,才可以在使用的时候得心应手,信手拈来,可以大大提高我们写程序的效率并且保证了正确率。


      ~~~~~       通过此次实验的整理与学习,我在感觉java编程方面有了很大的进步,同时也更好的理解的面向对象的编程思路,懂得程序设计的可用性以及代码编写的规范性,并且拥有了更好的代码执行经验。
      ~~~~~       在做题目的过程中,遇到很多不会的知识点,比如对String类型的变量求其长度时用到length()函数来获取其长度,在题目中还设计到对字符串其中的一个字符的操作,需要用到charAt()方法来实现只获取其中一个字符。
      ~~~~~       现在学到的java知识还很少,还需要我经常去自我总结和归纳,多复盘,多思考,这样才可以有实质性的进步。


      ~~~~~       1.首先通过这次编程练习对输入函数Scanner sc=new Scanner(System.in);有了更加深刻的了解。输入数字可以用int a=sc.nextInt(); 来读入数字,字符串则用String s=sc.nextLint(); 获取从键盘输入的字符串。
      ~~~~~       2.学会了类的使用,以及类中的构造函数和拷贝构造函数,构造函数可以以传入的实际值作为参数,拷贝构造函数则可以以已经实例化的对象作为参数传入。以及熟悉了在public类中调用其他类中函数的使用方法。

      ~~~~~       1.首先通过这次编程练习学会了抽象类,并且在抽象类的基础上进行新的类的继承,同时也学会了对对象的引用。我们可以在一个新的继承类中重载一个函数,在实际调用的过程中,会调用子类的函数,这样就将父类的函数覆盖掉,实现函数的重载。
      ~~~~~       2.在这次实验中还涉及到了最终类,这种类只有父类,没有子类,不能在它的基础上再进行继承新的类。



  • 16
    点赞
  • 72
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
大连民族大学 计算机科学与工程学院 《Java语言》课程实验报告 实验题目: 计算器的设计与实现 课程名称: Java语言 实验类型: 演示性 验证性 操作性 设计性 综合性 专业:网络工程 班级:**** 学生姓名*** 学号:***** 实验日期:2018年 4月23日 地点:计算机学院综合试验中心(I-303) 实验学时:4 实验成绩: 指导教师签字: 2018年 5月21日 1. 问题需求描述:Problem description 利用Java Swing设计计算器图形化界面,并实现事件的监听,以及计算器基本的加、减、乘、除、 清空、输出运算结果的操作,学习使用各种图形化界面的控件,容器,布局等,学习对 按钮事件的处理等。以及对非法输入的处理。 2. 设计说明:Design notes 本计算器,界面方面总体采用BorderLayout布局,显示输入输入的文本框和清除按钮 采用FlowLayout布局,容器放在BorderLayout的North;0- 9和各种运算符号还有小数点采用GridLayout布局,容器放在BorderLayou的Center;事 件监听和处理通过实现addActioListener监视器接口和ItemEvent事件接口,从而对每一 个按钮实现事件的监听和处理;计算方面,调用ScriptEngineManager和ScriptEngine两 个类,直接通过eval函数直接把输入文本当作JS代码执行,输出执行结果,这样报错也 会直接实现,另把文本框设置不允许直接从键盘输入以防止出现安全事件。 最后通过转化成JS代码运算得到启发,使用类似方法,我还实现了调用VB代码实现计算 器实时读出键盘输入,发出声音。 3. 系统实现:system implementation 1.程序界面展示 4. 总结体会: summary and experience 实验达到了预期的目标。通过此次的编程,我学会了用Java语言编写简单的软件,增强 了我对学习Java的兴趣。编程过程中,总体设计主要是窗口与组件的应用,具体执行则 是利用Java语言设计算法,而难点也在算法的设计上。虽然程序大体上符合要求,但由 于第一次编写这么复杂的程序,程序仍然存在一- 些漏洞,譬如由于未进行异常处理,当连续输入运算符是程序会出错,还有若一直按小 数点的话会得到一连串的小数点。由于最近忙着考试没有时间修改,考试结束后一定认 真修改这些问题。我觉得在编程时应该注意排版对齐,这样不论是自己检查程序还是别 人阅读程序都会更加方便。如果能添加备注的话以后阅读程序会更容易些。在以后的编 程中我会吸取经验,养成认真、严谨的编程习惯。 附:程序清单 1. import javax.swing.JFrame; public class Calculator { public static void main(String[] paramArrayOfString) { CalculatorFrame localCalculatorFrame = new CalculatorFrame(); localCalculatorFrame.setSize(800, 800); localCalculatorFrame.setVisible(true); } } 2 import java.awt.Container; import java.awt.event.WindowAdapter; import java.awt.event.WindowEvent; import javax.swing.JFrame; class CalculatorFrame extends JFrame { public CalculatorFrame() { setTitle("Calculator"); setSize(200, 200); addWindowListener(new WindowAdapter() { public void windowClosing(WindowEvent paramAnonymousWindowEvent) { System.exit(0); } }); Container localContainer = getContentPane(); localContainer.add(new CalculatorPanel()); } } 3. import java.awt.BorderLayout; import java.awt.Color; import java.awt.Container; import java.awt.Font; import java.awt.GridLayout; import java.awt.eve
实验目的: 通过本实验,实现对堆排序算法的理解,掌握堆排序算法的原理以及实现方法,并掌握Java语言的编程技巧。 实验内容: 堆排序是一种树形选择排序方法,是对直接选择排序算法的有效改进。堆排序的基本思想是:将待排序的序列构造成一个大根堆或小根堆,堆顶元素为最大值或最小值,然后将堆顶元素与最后一个元素交换,然后把剩余的元素重新构造成堆。如此反复执行,直到排序完成。由于堆排序算法的时间复杂度为O(nlogn),因此在大数据量的情况下,堆排序是高效的。 堆排序算法的实现主要有两个步骤:构建初始堆和堆排序。其中,构建初始堆是将待排序的序列构建成一个大根堆或小根堆的过程,堆排序是不断将堆顶元素与最后一个元素交换,并重新调整堆的过程。 以下是Java语言实现堆排序的代码: ```java public class HeapSort { public static void heapSort(int[] arr) { int n = arr.length; // 构建初始堆 for (int i = n / 2 - 1; i >= 0; i--) heapify(arr, n, i); // 堆排序 for (int i = n - 1; i >= 0; i--) { // 将堆顶元素与最后一个元素交换 int temp = arr[0]; arr[0] = arr[i]; arr[i] = temp; // 调整堆 heapify(arr, i, 0); } } // 调整堆 public static void heapify(int[] arr, int n, int i) { int largest = i; int left = 2 * i + 1; int right = 2 * i + 2; // 找到左子节点和右子节点中的最大值 if (left < n && arr[left] > arr[largest]) largest = left; if (right < n && arr[right] > arr[largest]) largest = right; // 如果最大值不是根节点,则交换根节点和最大值,并递归调整子堆 if (largest != i) { int temp = arr[i]; arr[i] = arr[largest]; arr[largest] = temp; heapify(arr, n, largest); } } public static void main(String[] args) { int[] arr = { 64, 34, 25, 12, 22, 11, 90 }; heapSort(arr); System.out.println("排序后的数组:"); for (int i = 0; i < arr.length; i++) System.out.print(arr[i] + " "); } } ``` 实验结果: 经过测试,以上代码能够正确地对数列进行堆排序,得到正确的排序结果。 实验总结: 通过本次实验,我学习了堆排序算法的原理和实现方法,并通过Java语言编写了相应的代码。堆排序算法具有高效的时间复杂度,在大数据量的情况下具有明显的优势。这次实验让我对Java语言的编程技巧有了更深刻的理解,也对算法的实现有了更深的认识。

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

_房似锦_

好心人哇!

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值