
在java中,当一个类需要使用另一个类中定义的成员(如方法或变量)时,通常需要创建该类的实例,并通过实例调用其公共方法。然而,在实际开发中,尤其当项目包含多个文件和目录时,会遇到类无法被识别或方法无法解析的问题。这往往与java的包(package)机制和类路径(classpath)有关。
Java包是组织类和接口的一种方式,它提供命名空间(namespace)以避免命名冲突,并有助于管理大型项目。当两个或多个类具有相同的名称时,包可以区分它们。如果没有明确声明包,类默认属于“默认包”。
给定的场景中,Bill类尝试通过menu.getStarters()访问Menu类中的getStarters()方法,却遇到了“Cannot resolve method getStarters in Menu”的错误。这表明Java编译器无法识别menu对象是哪个Menu类的实例,或者它所引用的Menu类中不包含getStarters()方法。
仔细分析,问题通常出在以下几点:
解决此类问题的最健壮和推荐方法是为自定义类声明明确的包,并在需要时进行显式导入。
立即学习“Java免费学习笔记(深入)”;
首先,为你的Menu类指定一个唯一的包名。这有助于避免与Java标准库中的同名类发生冲突。例如,你可以创建一个名为Restaurant的包来存放所有与餐厅模拟相关的类。
Menu.java 文件修改:
package Restaurant; // 添加包声明
import Foods.Desserts;
import Foods.Drinks;
import Foods.Main;
import Foods.Starter;
import java.util.ArrayList;
public class Menu {
/**
* @author Max Huddlestan
*/
//Created Array lists for each course to track the prices
ArrayList<Starter> starters;
ArrayList<Main> mains;
ArrayList<Desserts> desserts;
ArrayList<Drinks> drinks;
//this constructor should make it so each class had each of these array lists
public Menu(){
addStarters();
addMain();
addDesserts();
addDrinks();
}
//using an object of each class i can add a name and a price to the food in its respective course
public void addStarters(){
starters = new ArrayList<Starter>();
starters.add(new Starter("Soup", 8.00));
starters.add(new Starter("Garlic Bread", 8.00));
starters.add(new Starter("Chicken Wings", 9.00));
starters.add(new Starter("Caesar Salad", 10));
starters.add(new Starter("N/A", 0));
}
public void addMain(){
mains = new ArrayList<Main>();
mains.add(new Main ("Beef Burger", 16.5));
mains.add(new Main("Steak", 18.50));
mains.add(new Main("Spaghetti Bolognese", 14.00));
mains.add(new Main("Pizza", 14.75));
mains.add(new Main("Vegan Lasagne", 15.30));
mains.add(new Main("N/A", 0));
}
public void addDesserts(){
desserts = new ArrayList<Desserts>();
desserts.add(new Desserts("Sticky Toffee Pudding", 7.5));
desserts.add(new Desserts("Vegan Brownie", 7.5));
desserts.add(new Desserts("Ice Cream Sundae", 7.5));
desserts.add(new Desserts("Apple Tart", 7.5));
desserts.add(new Desserts("N/A", 0));
}
public void addDrinks() {
drinks = new ArrayList<Drinks>();
drinks.add(new Drinks("Beer", 5.3));
drinks.add(new Drinks("Wine", 7.0));
drinks.add(new Drinks("Coca Cola", 3.30));
drinks.add(new Drinks("Fanta", 3.30));
drinks.add(new Drinks("Water", 0));
drinks.add(new Drinks("N/A", 0));
}
public ArrayList<Starter> getStarters() {return starters;}
public ArrayList<Main> getMains() {return mains;}
public ArrayList<Desserts> getDesserts() {return desserts;}
public ArrayList<Drinks> getDrinks() {return drinks;}
@Override
public String toString() {
String startersList = "+";
for (Starter s : starters) {
startersList += s.toString();
}
return startersList;
}
}注意事项:
现在,由于Menu类属于Restaurant包,Bill类需要通过import语句明确告知编译器它要使用的是Restaurant.Menu,而不是java.awt.Menu。
Bill.java 文件修改:
package BillsIncome; // 假设Bill类也属于一个包
import Restaurant.Menu; // 显式导入自定义的Menu类
import Foods.Desserts;
import Foods.Drinks;
import Foods.Main;
import Foods.Starter;
import java.awt.*; // 注意:如果不需要java.awt包中的其他类,可以考虑移除此导入,以避免潜在的混淆。
import java.util.ArrayList;
public class Bill {
public static void main(String[] args) {
Menu menu = new Menu(); // 现在这里的Menu明确指代Restaurant.Menu
TakeOrder orders = new TakeOrder(); // 假设TakeOrder类存在并可用
ArrayList<String> order = new ArrayList<String>();
order.add(orders.selectStarter());
order.add(orders.selectMain());
order.add(orders.selectDessert());
order.add(orders.selectDrink());
System.out.println(menu.getStarters()); // 此行现在可以正确解析
}
}完成以上修改后,Bill类将能够正确识别并访问Restaurant.Menu类中的getStarters()方法。
对于非常小型的项目,如果你不想使用显式包声明,可以将Menu.java和Bill.java文件都放在同一个目录下,并且不在这两个文件中添加任何package声明。这样,它们都将属于“默认包”,并且可以互相访问。
Menu.java (无包声明):
// 不包含 package 声明
import Foods.Desserts;
// ... 其他代码与之前相同
public class Menu {
// ...
}Bill.java (无包声明):
// 不包含 package 声明
// 不需要 import Restaurant.Menu;
// ... 其他代码与之前相同
public class Bill {
// ...
}注意事项:
解决Java类间访问问题的关键在于理解和正确使用包机制:
通过遵循这些实践,你可以有效地管理Java项目中的类依赖,确保代码的正确编译和执行。
以上就是Java类间ArrayList访问:解决“无法解析方法”的包冲突问题的详细内容,更多请关注php中文网其它相关文章!
每个人都需要一台速度更快、更稳定的 PC。随着时间的推移,垃圾文件、旧注册表数据和不必要的后台进程会占用资源并降低性能。幸运的是,许多工具可以让 Windows 保持平稳运行。
Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号