提醒:创建项目后先看看 readme,和idea还是不一样的,用idea 用习惯了😅
从下面这个图可以看到它的默认运行配置,以及创建类时候得加上后缀.java
1.程序介绍
下面是我给 MarsCode 的话
用java写一个零钱通小程序: 要求
1.先显示出零钱通菜单供用户选择,菜单包括零钱通明细、收益入账、消费和退出
2.其中零钱通明细要输出用户的收益入账金额、时间和余额;
收益入账让用户输入金额,输出余额;消费让用户输入消费金额,输出余额。
收益入账和消费都会记录在零钱通明细中。
如果用户选择退出,则提示“您已退出零钱通”之后退出程序。
3.初始金额为0.0
2. 给出基本逻辑代码
我的关注点是它能不能生成一个相对逻辑完整有点小难度的代码,另外测试一下注释功能。
从它给出的代码来看是可以完全正确的给出框架的。我后面再加几句命令看看能不能生成完整的零钱通程序
不过它默认就是maven项目,我原来打算只是写一个逻辑代码
package com.test;
import java.util.Scanner;
public class SmallChange {
public static void main(String[] args) {
Scanner scanner = new Scanner(System.in);
double balance = 0.0; // 初始金额为0.0
while (true) {
System.out.println("零钱通菜单:");
System.out.println("1. 零钱通明细");
System.out.println("2. 收益入账");
System.out.println("3. 消费");
System.out.println("4. 退出");
System.out.print("请输入您的选择(1-4):");
int choice = scanner.nextInt();
scanner.nextLine(); // 消耗掉输入的换行符
switch (choice) {
case 1:
System.out.println("查看零钱通明细...");
// 在这里添加查看零钱通明细的代码
break;
case 2:
System.out.println("记录收益入账...");
System.out.print("请输入收益入账金额:");
double income = scanner.nextDouble();
balance += income;
System.out.println("余额:" + balance);
// 在这里添加记录收益入账的代码
break;
case 3:
System.out.println("记录消费...");
System.out.print("请输入消费金额:");
double expense = scanner.nextDouble();
if (expense > balance) {
System.out.println("余额不足,消费失败!");
} else {
balance -= expense;
System.out.println("余额:" + balance);
}
// 在这里添加记录消费的代码
break;
case 4:
System.out.println("退出程序...");
// 在这里添加退出程序的代码
System.exit(0);
default:
System.out.println("无效的选择,请重新输入。");
}
}
}
}
是可以正常运行的
2.1 运行效果
第一项的话就是输出一句话。不贴图了
3.进一步实现代码
我给出的要求如下:给出上面代码中缺失的查看零钱通明细的代码
就不给出完整的所有代码了,就是再加了一个方法。
// 假设这是一个获取零钱通明细的方法
private static List<String> getChangeDetail() {
// 这里应该有获取零钱通明细的逻辑,例如从数据库或文件中读取
// 为了示例,这里返回一个静态的明细列表
List<String> details = new ArrayList<>();
details.add("2023-07-01 收入 100.0 元");
details.add("2023-07-02 消费 50.0 元");
details.add("2023-07-03 收入 20.0 元");
return details;
}
可以看到和我想要的:根据我的收益和消费给出动态明细 还是不一样的。
然后我又进一步给指令:实现上面的getChangeDetail 方法,记录我的收益入账和消费。
给的代码和上面的是一样的。
4. 感受总结
首先这个对于初学者来说是很友好的,给出了基本的代码逻辑,注释也非常清晰。如果用来辅助完成学校的编程作业是完全可以的。
但要生成更复杂一些的逻辑好像还不行,也有可能是我的指令不够具体。