java如何记录日志 java如何记录每个方法的运行时间
在Java应用中,记录和管理交易历史数据是常见需求。本文将详细介绍如何利用Java的集合框架,特别是java.util.List,结合自定义方便对象来有效地和存储搜索记录。我们将通过实际代码示例,如何定义交易数据结构、如何在交易发生时将其添加到历史记录中,以及如何实地查询这些记录,同时探讨数据持久化等进阶概念。核心概念:交易记录的数据结构 p>
在处理类似银行转账的场景时,只需在方法执行完毕后打印结果是不够的,我们需要将每次交易的关键信息(如转账方、收款方、金额、时间等)保存下来,以便后续查询或分析。来存储这些信息是不可行的,因为每次方法调用都会覆盖前一次的数据,并且无法存储多条交易记录。
为了有效地管理多条交易记录,我们需要:
定义一个自定义类来表示单条交易记录。此类将封装支出交易的所有相关属性,例如:发送方(发送方)接收方(接收方)金额(交易金额)时间戳(交易时间)通过将这些属性组合成一个对象,我们可以更好地组织数据,完善代码以实现区别性和可性维护。
使用集合框架来存储这些交易对象。java.util.List是一个非常适合的接口,它代表一个社区的元素序列。ArrayList是List接口的一个常用实现,它提供了动态数组的功能,可以方便地添加和访问元素。
下面是Transaction类的定义示例:
立即学习“Java免费学习笔记(深入)”;import java.time.LocalDateTime;import java.time.format.DateTimeFormatter;/** * 表示记账银行交易的记录。 */public class Transaction { private String sender; private String receiveer; private double amount; private LocalDateTime timestamp; // 使用LocalDateTime记录交易发生的时间 /** * 构造函数,用于创建新的交易记录。 * @param sender交易的发送方。 * @param receive 交易的接收方。 * @param amount 交易的金额。
*/ public Transaction(String sender, String receiveer, double amount) { this.sender = sender; this.receiver = receive; this.amount = amount; this.timestamp = LocalDateTime.now(); // 默认记录外部当前系统时间 } // 为所有属性提供公共的getter方法,方便访问 public String getSender() { return sender; } public String getReceiver() { return receive; } public double getAmount() { return amount; */ @Override public String toString() { DateTimeFormatter formatter = DateTimeFormatter.ofPattern(quot;yyyy-MM-dd HH:mm:ssquot;); return quot;交易时间: quot;timestamp.format(formatter) quot;,发送方: quot; 发送方 quot;,接收方: quot;接收方 quot;,金额: quot;String.format(quot;.2fquot;, amount) quot;元quot;;}}登录后复制实现交易历史记录
还有 Transaction 类,我们就可以在每次交易成功后,创建一个 Transaction 对象,把它添加到 List 中。这个列表通常需要作为应用程序的某个全局或可访问的成员变量来维护。
以下是一个简化的银行应用示例,演示了如何集成交易历史记录功能:import java.util.ArrayList;import java.util.List;import java.util.Scanner;public class BankingApp { private static double Balance = 1000.0; // 假设初始余额 private static Scanner Scanner = new Scanner(System.in); private static String currentUser = quot;我的账户quot;; // 假设当前 // 用户声明一个静态的List来存储所有交易记录 private static Listlt;Transactiongt; transactionHistory = new ArrayListlt;gt;(); public static void main(String[] args) { runApplication(); // 启动应用程序主循环 } /** * 应用程序主显示循环,菜单并处理输入用户。 */ public static void runApplication() { int choice; do { System.out.println(quot;\n--- 银行应用主 ---quot;); System.out.println(“1.转动”;); System.out.println(quot;2.查看交易历史quot;); System.out.println(quot;3.查看当前余额quot;); System.out.println(quot;4.退出quot;); System.out.print(quot;请选择操作: quot;); if (scanner.hasNextInt()) { choice =scanner.nextInt();scanner.nextLine(); //消费掉换行符,避免影响下一次nextLine() } else { System.out.println(quot;无效输入,请输入数字选项。
quot;);scanner.nextLine(); // 消费掉无效输入 choice = 0; // 设置为无效选项,继续循环 continue; } switch (choice) { case 1:moneyTransfer();break;case 2:viewTransactionHistory();break;case 3:System.out.println(quot;当前余额: quot;String.format(quot;.2fquot;,balance) quot;元quot;);break; case 4: System.out.println(quot;感谢使用,再见!quot;);break; // 退出循环 default: System.out.println(quot;无效选择,请重新输入。quot;); } } while (choice != 4);scanner.close(); // 关闭Scanner资源 } /** * 处理资金转账操作。 */ public static void MoneyTransfer() { System.out.println(quot;\n--- 循环功能 ---quot;); System.out.print(quot;请输入收款人姓名: quot;); String receiveName = Scanner.nextLine(); System.out.print(quot;请输入转账金额: quot;); double TransferAmount; if (scanner.hasNextDouble()) { TransferAmount = Scanner.nextDouble(); Scanner.nextLine(); // 消费换行符 } else { System.out.println(quot;无效金额,请输入数字。
quot;);scanner.nextLine(); // 消费无效输入 return; // 返回主菜单 } if (transferAmount lt;= 0) { System.out.println(quot;转账金额必须大于零。quot;); } else if (balance lt;transferAmount) { System.out.println(quot;余额不足,无法完成转账。当前余额: quot; String.format(quot;.2fquot;,balance) quot;元quot;); } else { 创建balance -=transferAmount; //Transaction对象并添加到历史记录列表 Transaction transaction = new Transaction(currentUser,receiverName,transferAmount); transactionHistory.add(transaction); System.out.println(quot;已成功转账 quot; String.format(quot;.2fquot;,transferAmount) quot; 元给用户: quot; receiveName); System.out.println(quot;当前余额: quot; String.format(quot;.2fquot;,余额) quot;元quot;); } } /** * 查看所有交易历史记录。 */ public static void viewTransactionHistory() { System.out.println(quot;\n--- 交易历史记录 ---quot;); if (transactionHistory.isEmpty()) { System.out.println(quot;目前没有交易记录。quot;); } else { // 遍历并打印每一条交易记录 for (Transaction t : transactionHistory) { System.out.println(t); // 调用Transaction类的toString方法进行格式化输出 } } }}登录后复制
在上述代码中:transactionHistory是一个List类型的静态变量,用于在整个应用程序生命周期中存储交易记录。
在 MoneyTransfer 方法中,当转账成功后,我们创建一个新的 Transaction 对象,并使用 transactionHistory.add(transaction);将添加到列表中。runApplication 方法使用一个 do-while 循环来持续显示菜单并处理用户输入,直到用户选择退出。这比原始问题中 return startPanel();的连接调用更健壮,避免了潜在的堆栈溢出问题。查看交易历史
viewTransactionHisstory 方法返回 transactionHistory列表并打印出每一条记录。由于我们在 Transaction 类中重写了 toString() 方法,直接打印 Transaction 对象才能得到格式化的输出。注意事项与进阶
内存存储的限制:当前方案中,transactionHistory存储列表在程序的内存中。这意味着一旦程序关闭,所有存储的交易历史数据都将丢失。对于实际的应用程序来说,这通常是不重要的。
数据持久化:为了使数据在程序关闭后仍然存在,需要将数据进行持久化存储。常见的持久化方式包括:文件存储: 将数据写入文本文件(如 CSV、JSON、XML)或二进制文件。这适用于数据量较小、结构相对简单的关系型数据库(如 MySQL、PostgreSQL、SQLite)或 NoSQL 数据库(如 MongoDB)。这是企业级应用中最常用的方式,提供了丰富的数据管理、查询、事务和数据库控制能力。Java 通常通过 JDBC(Java Database Connectivity)或其他 ORM(Object-Relational Mapping)框架(如 Hibernate,
并发安全:如果你的应用程序是多线程的,并且多个线程可能同时尝试修改transactionHistory列表(例如,多个用户同时进行
以上就是Java中如何有效记录和管理交易历史数据的详细内容,更多请关注乐哥常识网其他相关文章!