작성
·
317
0
package class1.Ex;
public class ProductOrderMain {
public static void main(String[] args) {
ProductOrder[] productOrders = new ProductOrder[3];
productOrders[0] = new ProductOrder();
productOrders[0].productName = "두부";
productOrders[0].price = 2000;
productOrders[0].quantity = 2;
productOrders[1] = new ProductOrder();
productOrders[1].productName = "김치";
productOrders[1].price = 5000;
productOrders[1].quantity = 1;
productOrders[2] = new ProductOrder();
productOrders[2].productName = "콜라";
productOrders[2].price = 1500;
productOrders[2].quantity = 2;
int total = 0;
for (int i = 0; i < 3; i++){
System.out.println("상품명: "+productOrders[i].productName + ", 가격: "+productOrders[i].price + ", 수량"+productOrders[i].quantity);
total += productOrders[i].price;
}
System.out.println("총 결제 금액: " + total);
}
}
답변 2
0
안녕하세요. 도토리님, 공식 서포터즈 OMG입니다.
비유를 통해 설명드리겠습니다.
레고 3개가 들어가는 레고 하우스를 지으려고 합니다
ProductOrder[] productOrders = new ProductOrder[3];
레고 3개의 집을 생성했으니, 각각의 레고를 만들어 보려고하는데요
우선 첫번째 레고를 만들어보겠습니다.
productOrders[0] = new ProductOrder();
레고의 이름을 해리포터라고 해볼게요.
productOrders[0].productName = "해리포터";
여기까지가 레고 3개를 담을 공간을 만들고, 레고를 하나 만들었고, 레고의 이름을 부여하였습니다.
질문 중
productOrders[0] = new ProductOrder();
를 생략하셨다고 하였는데요. 이는 레고가 살 공간은 만들었지만, 실제 레고 그 자체를 만들지 않고 레고의 이름을 부여하려는 행위와 같습니다.(레고가 없는데 이름을 부여하는 행동)
레고 3개가 들어가는 공간을 만든 것이지 레고를 만든게 아니지요.
그래서 NullPointerException이 발생했을 것 같아요.
레고의 공간과 레고 그 자체를 구분지어 생각하시면 좋을 것 같아요 😀
감사합니다.
0
그렇군요. 감사합니다. 이해가 되었습니다.
좋은 하루 보내세요.