java - 方法不会增加对象 ArrayList 中的 int 变量?

标签 java arraylist

我一直在使用“Loanbook”方法遇到这个问题,它的功能是将存储在对象 ArrayList 中的“numOnLoan”变量递增 1,但是当我运行该方法时它似乎没有改变值(value)。

//Allows loaning of books
public static void Loanbook(Scanner sc, ArrayList<Book> books){
System.out.println("Please enter a book title");
    if(sc.hasNext()){
        String criteria = sc.nextLine();
        for (int i = 0; i < books.size(); i++){
            if(criteria.equals(books.get(i).getBookTitle())){
            System.out.println("The book " + books.get(i).getBookTitle() + " there are " + books.get(i).getNumInStock() + " in stock");
                    books.get(i).setNumOnLoan(books.get(i).GetNumOnLoan()+1);
                    System.out.println("number on loan: " + books.get(i).GetNumOnLoan()); break;    
                        }
                    } System.out.println("Book Loaned");
                        LibraryTester.MenuReturn(sc, books);

            }   
                LibraryTester.MenuReturn(sc, books);
        }

我怀疑这是代码逻辑的问题,但是我对其进行了编辑,代码似乎没有按照我的要求进行。

编辑: 书.java

public class Book {
private int id;
private String bookTitle;
private String authorName;
private int bookReleaseYear;
private int numOnLoan;
private int numInStock;

//constructor
public Book(int id, String bookTitle, String authorName, int bookReleaseYear, int numOnLoan, int numInStock) {
    this.id = id;
    this.bookTitle = bookTitle;
    this.authorName = authorName;
    this.bookReleaseYear = bookReleaseYear;
    this.numOnLoan = numOnLoan;
    this.numInStock = numInStock;
}
//Getters/Setters
public int getId() {
    return id;
}

public void setId(int id) {
    this.id = id;
}

public String getBookTitle() {
    return bookTitle;
}

public void setBookTitle(String bookTitle) {
    this.bookTitle= bookTitle;
}

public String getAuthorName() {
    return authorName;
}

public void setAuthorName(String authorName) {
    this.authorName = authorName;
}

public int GetNumOnLoan() {
    return numOnLoan;
}

public void setNumOnLoan(int numOnLoan) {
    this.numOnLoan = numOnLoan;
}

public int getNumInStock() {
    return numInStock;
}

public void setNumInStock(int numInStock) {
    this.numInStock = numInStock;
}



public int getBookReleaseYear() {
    return bookReleaseYear;
}

public void setBookReleaseYear(int bookReleaseYear) {
    this.bookReleaseYear = bookReleaseYear;
}

库.java

import java.util.ArrayList;

import java.util.Scanner;

public class Library {

public ArrayList<Book> books = new ArrayList<Book>();

public Library(){
      super();
    }

//Getters/Setters
public Library(ArrayList<Book> books) {
    this.books = books;
}

public ArrayList<Book> getBooks() {
    return books;
}

public void setBooks(ArrayList<Book> books) {
    this.books = books;
}

//Methods

//Allows loaning of books
public static void Loanbook(Scanner sc, ArrayList<Book> books){
System.out.println("Please enter a book title");
    if(sc.hasNext()){
        String criteria = sc.nextLine();
        for (int i = 0; i < books.size(); i++){
            if(criteria.equals(books.get(i).getBookTitle())){
            System.out.println("The book " + books.get(i).getBookTitle() + "    there are " + books.get(i).getNumInStock() + " in stock");
                    books.get(i).setNumOnLoan(+1);
                    System.out.println("number on loan: " +    books.get(i).GetNumOnLoan()); break; 
                        }
                    } System.out.println("Book Loaned");
                        LibraryTester.MenuReturn(sc, books);

            }   
                LibraryTester.MenuReturn(sc, books);
        }


}

public static void Returnbook(Scanner sc, ArrayList<Book> books){
System.out.println("Please enter a book title");
    if(sc.hasNext()){
        String criteria = sc.nextLine();
    for (int i = 0; i < books.size(); i++){
        if(criteria.equals(books.get(i).getBookTitle())){
        System.out.println("The book " + books.get(i).getBookTitle() +
        " is in stock," + " there are " + books.get(i).getNumInStock() + " in stock and " + books.get(i).GetNumOnLoan() + " out on loan");
        books.get(i).setNumOnLoan(-1);; break;

                        } 


                    } System.out.println("Book returned");
                        LibraryTester.MenuReturn(sc, books);

            }
        }

库测试器.java

import java.util.ArrayList;
import java.util.Collections;
import java.util.Comparator;
import java.util.Scanner;

public class LibraryTester {

public static void main(String[] args) {

    Scanner sc = new Scanner(System.in);
    Library lib = new Library();
    ArrayList<Book> books = lib.getBooks();
    books = Library.CreateBooksArrayList();
    MenuInput(sc, books);
    sc.close();
    lib.setBooks(books);

}



//prints menu
public static void PrintMenu(){
    System.out.println("Public Library Menu System");
    System.out.println("---------------------------");
    System.out.println("1: Add Book");
    System.out.println("2: Search for book");
    System.out.println("3: Loan Book");
    System.out.println("4: Return Book");
    System.out.println("5: Amend Book Details");
    System.out.println("6: Display all Books");
    System.out.println("7: Delete a Book");
    System.out.println("8: Other Options");
    System.out.println("9: Exit system");
    System.out.println("----------------------------");
}


// Allows menu input
public static void MenuInput(Scanner sc, ArrayList<Book> books){
int input = 0;
PrintMenu();
if(sc.hasNextInt()){
    input = sc.nextInt();

    switch(input){
    case 1:Library.AddBook(sc, books);
    case 2:Library.SearchBooks(sc, books);;
    case 3:Library.Loanbook(sc,books);
    case 4:Library.Returnbook(sc, books);
    case 5:Library.AmendDetails(sc,books);
    case 6:Library.DisplayAllBooks(sc,books);
    case 7:Library.Removebook(sc, books);;
    case 8:OtherMenu(sc,books);
    case 9:System.exit(0);
    }
} else {
    System.out.println("Please enter a number");
}



}



//Returns user to main menu
public static void MenuReturn(Scanner sc, ArrayList<Book> books){
System.out.println("Press any key to return to the main menu");
if(sc.hasNextLine()){
    sc.nextLine();
    MenuInput(sc, books);
    }
}





}

编辑:我似乎得到了输出:

Please enter a book title
Input:   book1
Please enter a book title
The book book1 is in stock, there are 5 in stock and 1 out on loan
Book returned
Press any key to return to the main menu

最终编辑:修复了这个问题,由于 if 语句的问题,代码没有运行,当我删除它时,所有文本同时出现时出现问题,这个问题已通过 am extra 'sc.nextLine 修复'. ReturnBook 在没有调用的情况下运行的问题是由于缺少“中断”;在菜单系统中。

感谢大家的帮助,尤其是 Shreyans Sheth

最佳答案

我刚刚深入研究了你的代码。

你似乎有一个讨厌的错误(如果是的话)。

我会解决这个您问题中的特定行:“它的功能是将存储在对象 ArrayList 中的 'numOnLoan' 变量递增 1,但是当我运行该方法时,它似乎并没有改变值。

原始方法:

public void setNumOnLoan(int numOnLoan)  
{
    this.numOnLoan= numOnLoan;
}

Loanbook 中的方法调用:

books.get(i).setNumOnLoan(1);


LoanBook 方法中,您只需将“+1”作为参数传递,每次只分配 1。这是您需要做的。

public void setNumOnLoan(int numOnLoan)  
{
    //When numOnLoan is 1, as you have passed everytime
    //the current value gets incremented by one. I think that is what you wanted.
    this.numOnLoan += numOnLoan; //You add it to the existing variable
}



您真的应该将该函数命名为其他名称。我很确定那里还有更多错误,但这是否可以实现您想要的?


输出:
(第一次调用Loanbook)
请输入书名
输入 :bbbbb
bbbbb这本书还有5本库存
借出数量:2
借书

(第二次调用Loanbook)
请输入书名
输入:bbbbb
bbbbb这本书还有5本库存
借出人数:3
借书

关于java - 方法不会增加对象 ArrayList 中的 int 变量?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/34222260/

相关文章:

java - 为什么这个对象在此 ArrayList 中显示为 "unknown class"?

java - 为什么 clone() 是复制数组的最佳方式?

java - add() 在android androidx.fragment.app.FragmentTransaction 中定义

java - Collection.removeIf 工作很奇怪

java - 多维数组列表 indexOf?

java - 获取字符串并将某些类型的字符存储在数组列表中

java - 从原始 ArrayList 获取值

java - 获取列表网格中过滤结果的数量(smartgwt)

java - JSF网页包含

javascript - 如何有条件地将选定的行从表A复制到表B?