Java-OO设计-有理数类的设计

简介: Java-OO设计-有理数类的设计

OO设计–JAVA-有理数类的设计


问题


按照BigDecimal类以面向对象的方式设计有理数类。

给出你的测试代码。要在与有理数类不同包的其他类中调用有理数类。

尝试回答与c语言的有理数代码相比较。


Rational函数

package test;
import java.math.BigDecimal;
public class Rational {
  private long numerator = 0; //分子
  private long denominator = 1; //分母
  public long getNumerator() {
    return numerator;
  }
  public void setNumerator(long numerator) {
    this.numerator = numerator;
  }
  public long getDenominator() {
    return denominator;
  }
  public void setDenominator(long denominator) {
    this.denominator = denominator;
  }
  public Rational(){//分子分母初始化
    this.numerator = 0;
    this.denominator = 1;
  }
  public Rational(long numerator, long denominator){
    this.numerator = numerator/gcd(Math.abs(numerator), Math.abs(denominator)); //分子化简(除以分子、分母的最大公约数)
    this.denominator = denominator/gcd(Math.abs(numerator), Math.abs(denominator));//分母化简(除以分子、分母的最大公约数)
  }
  public static long gcd (long number1, long number2){//最大公约数计算
    while (number1 != number2)
    {
      if (number1 > number2)
        number1 = number1 - number2;
      else
        number2 = number2 - number1;
    }
    return number1;
  }
  public static Rational add (Rational num1, Rational num2) {//有理数求和
    long tempNumerator = num1.numerator*num2.denominator + num1.denominator*num2.numerator;
    long tempDenominator = num1.denominator*num2.denominator;
    long gcd = gcd(Math.abs(tempNumerator),Math.abs(tempDenominator));
    Rational rationalNumber = new Rational(tempNumerator/gcd,tempDenominator/gcd);
    return rationalNumber;
  }
  public static Rational subtract (Rational num1, Rational num2) {//有理数求差
    long tempNumerator = num1.numerator*num2.denominator - num1.denominator*num2.numerator;
    long tempDenominator = num1.denominator*num2.denominator;
    long gcd = gcd(Math.abs(tempNumerator),Math.abs(tempDenominator));
    Rational rationalNumber = new Rational(tempNumerator/gcd,tempDenominator/gcd);
    return rationalNumber;
  }
  public static Rational multiply (Rational num1, Rational num2) {//有理数求积
    long tempNumerator = num1.numerator*num2.numerator;
    long tempDenominator = num1.denominator*num2.denominator;
    long gcd = gcd(Math.abs(tempNumerator),Math.abs(tempDenominator));
    Rational rationalNumber = new Rational(tempNumerator/gcd,tempDenominator/gcd);
    return rationalNumber;
  }
  public static Rational divide (Rational num1, Rational num2) {//有理数求商
    long tempNumerator = num1.numerator*num2.denominator;
    long tempDenominator = num1.denominator*num2.numerator;
    long gcd = gcd(Math.abs(tempNumerator),Math.abs(tempDenominator));
    Rational rationalNumber = new Rational(tempNumerator/gcd,tempDenominator/gcd);
    return rationalNumber;
  }
}

测试Class文件

package test;
public class RationalTes {
  private static Rational num1=new Rational(1,2); //第一个分数
  private static Rational num2=new Rational(12,4); //第二个分数
  private static double test = Double.parseDouble("3457367536")/(double)6769656;
  public static void main(String[] args) {
    Rational result=Rational.add(num1, num2);
    System.out.println("有理数求和:");
    System.out.println("(分数形式):1/2+12/4="+result.getNumerator()+"/"+result.getDenominator());
    System.out.println("(小数形式):1/2+12/4="+(result.getNumerator()/(double)result.getDenominator()));
    result=Rational.subtract(num1, num2);
      System.out.println("有理数求差:");
    System.out.println("(分数形式):1/2-12/4="+result.getNumerator()+"/"+result.getDenominator());
    System.out.println("(小数形式):1/2-12/4="+(result.getNumerator()/(double)result.getDenominator()));
    result=Rational.multiply(num1, num2);
    System.out.println("有理数求积:");
    System.out.println("(分数形式):1/2*12/4="+result.getNumerator()+"/"+result.getDenominator());
    System.out.println("(小数形式):1/2*12/4="+(result.getNumerator()/(double)result.getDenominator()));
    result=Rational.divide(num1, num2);
    System.out.println("有理数求商:");
    System.out.println("(分数形式):1/2-12/4="+result.getNumerator()+"/"+result.getDenominator());
    System.out.println("(小数形式):1/2*12/4="+(result.getNumerator()/(double)result.getDenominator()));
  }
}

运行结果

542adf86c7e0476fa3da266442110ad4.png


问题总结


Q1:与C语言相比何处体现更加面向对象?


A1:C语言的面向过程就是分析出解决问题所需要的步骤,之后使用函数一步步解决。而Java语言则通过把构成问题事务分解成各个对象,建立对象的目的不是为了完成一个步骤,而是为了描叙某个事物在整个解决问题的步骤中的行为。例如在此代码中,针对各个不同对象,进行数据封装,所有的通信都通过对象的方法来实现。


Q2:如何使用此代码?


A2:下载包到本地,导入包到IDE中,通过“类名.方法”调用函数。使用setter/getter设置和访问private。


Q3:调用时的代码是否依赖该有理数类的属性?当有理数类修改时,是否会影响调用?


A3:调用时的代码对该类的属性有依赖性。当有理数类修改时,会影响调用。


Q4:为什么有的方法设置为private?


A4:在如下场景时将某些方法设置为private:


当一个方法希望只被本类所使用时。


与本类的内部状态无关。

相关文章
|
17天前
|
算法 Java 数据处理
从HashSet到TreeSet,Java集合框架中的Set接口及其实现类以其“不重复性”要求,彻底改变了处理唯一性数据的方式。
从HashSet到TreeSet,Java集合框架中的Set接口及其实现类以其“不重复性”要求,彻底改变了处理唯一性数据的方式。HashSet基于哈希表实现,提供高效的元素操作;TreeSet则通过红黑树实现元素的自然排序,适合需要有序访问的场景。本文通过示例代码详细介绍了两者的特性和应用场景。
33 6
|
5天前
|
存储 安全 Java
java.util的Collections类
Collections 类位于 java.util 包下,提供了许多有用的对象和方法,来简化java中集合的创建、处理和多线程管理。掌握此类将非常有助于提升开发效率和维护代码的简洁性,同时对于程序的稳定性和安全性有大有帮助。
32 17
|
1天前
|
存储 Java 程序员
Java基础的灵魂——Object类方法详解(社招面试不踩坑)
本文介绍了Java中`Object`类的几个重要方法,包括`toString`、`equals`、`hashCode`、`finalize`、`clone`、`getClass`、`notify`和`wait`。这些方法是面试中的常考点,掌握它们有助于理解Java对象的行为和实现多线程编程。作者通过具体示例和应用场景,详细解析了每个方法的作用和重写技巧,帮助读者更好地应对面试和技术开发。
19 4
|
2天前
|
Java 编译器 开发者
Java异常处理的最佳实践,涵盖理解异常类体系、选择合适的异常类型、提供详细异常信息、合理使用try-catch和finally语句、使用try-with-resources、记录异常信息等方面
本文探讨了Java异常处理的最佳实践,涵盖理解异常类体系、选择合适的异常类型、提供详细异常信息、合理使用try-catch和finally语句、使用try-with-resources、记录异常信息等方面,帮助开发者提高代码质量和程序的健壮性。
8 2
|
6天前
|
存储 安全 Java
如何保证 Java 类文件的安全性?
Java类文件的安全性可以通过多种方式保障,如使用数字签名验证类文件的完整性和来源,利用安全管理器和安全策略限制类文件的权限,以及通过加密技术保护类文件在传输过程中的安全。
|
10天前
|
Java 数据格式 索引
使用 Java 字节码工具检查类文件完整性的原理是什么
Java字节码工具通过解析和分析类文件的字节码,检查其结构和内容是否符合Java虚拟机规范,确保类文件的完整性和合法性,防止恶意代码或损坏的类文件影响程序运行。
|
10天前
|
Java API Maven
如何使用 Java 字节码工具检查类文件的完整性
本文介绍如何利用Java字节码工具来检测类文件的完整性和有效性,确保类文件未被篡改或损坏,适用于开发和维护阶段的代码质量控制。
|
10天前
|
存储 Java 编译器
java wrapper是什么类
【10月更文挑战第16天】
18 3
|
13天前
|
Java 程序员 测试技术
Java|让 JUnit4 测试类自动注入 logger 和被测 Service
本文介绍如何通过自定义 IDEA 的 JUnit4 Test Class 模板,实现生成测试类时自动注入 logger 和被测 Service。
20 5
|
13天前
|
Java 开发者
在Java多线程编程中,创建线程的方法有两种:继承Thread类和实现Runnable接口
【10月更文挑战第20天】在Java多线程编程中,创建线程的方法有两种:继承Thread类和实现Runnable接口。本文揭示了这两种方式的微妙差异和潜在陷阱,帮助你更好地理解和选择适合项目需求的线程创建方式。
13 3