zoukankan      html  css  js  c++  java
  • 实验三《Java面向对象程序设计》实验报告

    20162308 实验三《Java面向对象程序设计》实验报告

    实验内容

    1. XP基础
    2. XP核心实践
    3. IDEA工具学习
    4. 密码学算法基础

    实验步骤

    (一)Refactor/Reformat使用

    2017-05-09.png

    public class CodeStandard {
        public static void main(String[] args) {
            StringBuffer buffer = new StringBuffer();
            buffer.append('S');
            buffer.append("tringBuffer");
            System.out.println(buffer.charAt(1));
            System.out.println(buffer.capacity());
            System.out.println(buffer.indexOf("tring"));
            System.out.println("buffer = " + buffer.toString());
            if (buffer.capacity() < 20)
                buffer.append("1234567");
            for (int i = 0; i < buffer.length(); i++)
                System.out.println(buffer.charAt(i));
        }
    }
    

    (二)单元测试&重构

    重构Complex类的equal方法
    equal判断时没有考虑Java处理浮点数产生的误差,应将a==b改为abs(a-b)<=1E-8
    Case2.jpg

    public class Complex {
        public final double eq = 1E-7;
        double RealPart;
        double ImagePart;
        public double getRealPart() {
            return RealPart;
        }
        public void setRealPart(double realPart) {
            RealPart = realPart;
        }
        public double getImagePart() {
            return ImagePart;
        }
        public void setImagePart(double imagePart) {
            ImagePart = imagePart;
        }
        public Complex(double R, double I) {
            RealPart = R;
            ImagePart = I;
        }
        public boolean equals(Complex obj1) {
            if (Math.abs(this.getRealPart () - obj1.getRealPart ()) <= eq && Math.abs(this.getImagePart () - obj1.getImagePart ())<=eq)
                return true;
            else return false;
        }
        public String toString() {
            return RealPart + " + " + ImagePart + "i";
        }
        public Complex ComplexAdd(Complex obj) {
            return new Complex ( RealPart + obj.getRealPart (), ImagePart + obj.getImagePart () );
        }
        public Complex ComplexSub(Complex obj) {
            return new Complex ( RealPart - obj.getRealPart (), ImagePart - obj.getImagePart () );
        }
        public Complex ComplexMulti(Complex obj) {
            return new Complex ( RealPart * obj.getRealPart () - ImagePart * obj.getImagePart (), RealPart * obj.getImagePart () + ImagePart * obj.getRealPart () );
        }
    }
    
    

    (三)密码学算法

    2017-05-10.png
    学习了DES和RSA加密算法,其中DES为对称加密算法,现在已经不够安全。RSA为非对称加密算法,由公钥和私钥组成,由于数学上认为对大整数快速分解质因数是困难的,所以说RSA算法目前而言还是安全的。之前和一个密码学方向的phd聊天,谈到随着量子计算机的出现,未来是有可能在相对较短的时间内实现质因数分解的,另外一个方面,也可以通过劫持随机数生成器,来实现攻击。

  • 相关阅读:
    lvs中dr模式配置脚本
    使用AFNetworking第三方下载类
    java 经常使用測试框架
    Qt5的插件机制(1)--Qt 框架中的插件载入机制概述
    leetcode笔记:Merge Sorted Array
    oracle仿全文检索切词机制实现文本信息类似度查找
    hadoop学习;datajoin;chain签名;combine()
    php函数in_array奇怪现象
    Sql_Server中怎样推断表中某列是否存在
    Java Bean 简单介绍及其应用
  • 原文地址:https://www.cnblogs.com/pingch/p/6852140.html
Copyright © 2011-2022 走看看