Java 简单计算器(加法)

简介: 如何用java写一个简易的加法计算器?本人菜鸟一枚,半个小时完成。大部分代码的解读注释已经标记好了

Java 简单计算器(加法)

结构图:



image.png

如何用java写一个简易的加法计算器?本人菜鸟一枚,半个小时完成。大部分代码的解读注释已经标记好了,如下


程序入口


程序的main方法应该始终保持干净清爽,不应该乱七八糟


在这里,我们定义一个公共类 TestCompu(计算器测试)


public class TestCompu {
    public static void main(String[] args) {
        Compu compu = new Compu();
    }
}

2.计算器需要一个窗口来展示,于是我们创建一个 Compu的窗口(Frame),只需要继承Frame就可以调用Frame中所有方法,其余的解释见代码中,


import java.awt.*;
import java.awt.event.WindowAdapter;
import java.awt.event.WindowEvent;
//计算器类
public class Compu extends Frame {
    //用构造器设置默认属性和方法
    public Compu(){
        //组件设置
        //3 * 文本框
        TextField num1 = new TextField(10); //‘10’可以理解为文本框长度
        TextField num2 = new TextField(10);
        TextField num3 = new TextField(20);
        //1 * 标签
        Label label = new Label("+");
        //1 * 按钮
        Button button = new Button("=");
        //设置布局-采用流式布局
        setLayout(new FlowLayout());
        //组件可见(注意顺序)
        add(num1);
        add(label);
        add(num2);
        add(button);
        add(num3);
        //自适应窗口参数
        pack();
        //窗口可见
        setVisible(true);
        //为按钮‘=’设置监听来实现功能
        //需要一个ActionListener,所以我们需要构造一个 ActionListener 建下一个class
        MyActionListener myActionListener = new MyActionListener(num1,num2,num3);
        button.addActionListener(myActionListener);
        //设置关闭窗口的方法
        addWindowListener(new WindowAdapter() {
            @Override
            public void windowClosing(WindowEvent e) {
                System.exit(0);
            }
        });
    }
}

3.在上面的Compu的类中,由于按键的功能需要依赖监听器来实现,所以我们,创建一个名为MyActionListener的类


import java.awt.*;
import java.awt.event.ActionEvent;
import java.awt.event.ActionListener;
public class MyActionListener implements ActionListener {
    //准备三个文本框接受
    private TextField num1,num2,num3;
    //有参构造
    public MyActionListener(TextField num1,TextField num2,TextField num3) {
        //把Compu中的文本框  numx 传给 监听器中的 num x
        this.num1 = num1;
        this.num2 = num2;
        this.num3 = num3;
    }
    //按钮功能设置
    @Override
    public void actionPerformed(ActionEvent e) {
        //1. 将 num1 和 num2 这俩文本框中的值 相加
        //首先,将num1 num2 通过有参构造以参数的形式传到这个类 并以 int形式 赋值给 n1 n2 (待会要用它俩来计算)
        int n1 = Integer.parseInt(num1.getText());
        int n2 = Integer.parseInt(num2.getText());
        //2. 相加之和给文本框num3
        num3.setText(""+(n1+n2));   //num3是文本框不是数值!!!
        //3. 相加后清除num1 num2 文本框中的数
        num1.setText(" ");
        num2.setText(" ");
    }
}

运行效果:


image.png

以上就是这个简易加法运算器的全部代码了,但这种写法不是最优,但最适合新手理解上手,如果有注释错误的地方,请多多包涵,欢迎指正,如果觉得写的还不错,也请点赞肯定一下,感激感激!!


相关文章
|
Java 开发工具 流计算
flink最新master代码编译出现Java Runtime Environment 问题
在尝试编译Flink源码时遇到Java运行时环境致命错误:EXCEPTION_ACCESS_VIOLATION。问题出现在JVM.dll+0x88212。使用的是Java 11.0.28和Java HotSpot(TM) 64-Bit Server VM。系统为Windows客户端,没有生成核心dump文件。错误日志保存在hs_err_pid39364.log和replay_pid39364.log。要解决这个问题,建议检查JDK版本兼容性,更新JDK或参照错误报告文件提交Bug至http://bugreport.java.com/bugreport/crash.jsp。
|
SQL 消息中间件 分布式计算
Hive 中级练习题(40题 待更新)
Hive 中级练习题(40题 待更新)
|
6月前
|
SQL 存储 消息中间件
vivo基于Paimon的湖仓一体落地实践
本文整理自vivo互联网大数据专家徐昱在Flink Forward Asia 2024的分享,基于实际案例探讨了构建现代化数据湖仓的关键决策和技术实践。内容涵盖组件选型、架构设计、离线加速、流批链路统一、消息组件替代、样本拼接、查询提速、元数据监控、数据迁移及未来展望等方面。通过这些探索,展示了如何优化性能、降低成本并提升数据处理效率,为相关领域提供了宝贵的经验和参考。
832 3
vivo基于Paimon的湖仓一体落地实践
|
人工智能 数据库
【科研技巧】如何判断某个期刊是什么类别及影响因子?是否是顶会?如何期刊内检索?AI写综述?AI做PPT?
本文提供了关于如何判断期刊类别、影响因子,识别顶级会议,以及在期刊内部进行检索的科研技巧,并探讨了AI技术在撰写综述和制作PPT方面的应用。
339 6
【科研技巧】如何判断某个期刊是什么类别及影响因子?是否是顶会?如何期刊内检索?AI写综述?AI做PPT?
|
9月前
|
关系型数据库 MySQL 数据库
CDC YAML 在阿里云的最佳实践
本文撰写自阿里云开源大数据平台数据通道团队,主要介绍了 Flink CDC YAML 在实时计算Flink版的最佳实践。
664 4
CDC YAML 在阿里云的最佳实践
|
SQL JSON 分布式计算
|
消息中间件 Kafka 程序员
Flink(九)【时间语义与水位线】
Flink(九)【时间语义与水位线】
|
SQL 分布式计算 数据管理
聊聊Hive数据血缘——从Atlas没有列级血缘的Bug讲起
聊聊Hive数据血缘——从Atlas没有列级血缘的Bug讲起
446 0
|
SQL 传感器 分布式计算
Flink(五)【DataStream 转换算子(上)】
Flink(五)【DataStream 转换算子(上)】
|
运维 应用服务中间件 调度