티스토리 뷰
- 값 타입은 복잡한 객체 세상을 조금이라도 단순화하려고 만든 개념이다. 따라서 값 타입은 단순하고 안전하게 다룰 수 있어야 한다.
값 타입 공유 참조
- 임베디드 타입 같은 값 타입을 여러 엔티티에서 공유하면 위험함
- 부작용 (side effect) 발생

부작용이 있는 것은 이런 코드인데
Address address = new Address("city", "street", "zup");
Member member1 = new Member();
member1.setUsername("hello1");
member1.setAddress(address);
em.persist(member1);
Member member2 = new Member();
member2.setUsername("hello2");
member2.setAddress(address);
em.persist(member2);
member1.getAddress().setCity("변경");
tx.commit();
이렇게 사용하면 db에서 member1,2 모두 새로운 시티값으로 바뀌게 된다.
값 타입 복사
- 값 타입의 실제 인스턴스인 값을 공유하는 것은 위험
- 대신 값(인스턴스)를 복사해서 사용

Address address = new Address("city", "street", "zup");
Member member1 = new Member();
member1.setUsername("hello1");
member1.setAddress(address);
em.persist(member1);
Address address2 = new Address(address.getCity(),address.getStreet(), address.getZipcode());
Member member2 = new Member();
member2.setUsername("hello2");
member2.setAddress(address2);
em.persist(member2);
member1.getAddress().setCity("변경");
tx.commit();
해당 코드처럼 복사해서 써야 사고가 안난다.
객체 타입의 한계
- 항상 값을 복사해서 사용하면 공유 참조로 인해 발생하는 부작용을 피할 수 있다.
- 문제는 임베디드 타입처럼 직접 정의한 값 타입은 자바의 기본타입이 아니라 객체 타입이다.
- 자바 기본 타입에 값을 대입하면 값을 복사한다.
- 객체 타입은 참조 값을 직접 대입하는 것을 막을 방법이 없다.
- 객체의 공유 참조는 피할 수 없다.

불변 객체
- 객체 타입을 수정할 수 없게 만들면 부작용을 원천 차단
- 값 타입은 불변 객체(immutable object)로 설계해야함
- 불변 객체 : 생성 시점 이후 절대 값을 변경할 수 없는 객체
- 생성자로만 값을 설정하고 수정자(Setter)를 만들지 않으면 됨 !!!!
- 참고 : Integer, String은 자바가 제공하는 대표적인 불변 객체
불변이라는 작은 제약으로 부작용이라는 큰 재앙을 막을 수 있다.
공지사항
최근에 올라온 글
최근에 달린 댓글
- Total
- Today
- Yesterday
링크
TAG
- 리터럴
- thymleaf
- hypertexttransferprotocol
- 스프링부트
- 예외처리
- jpa api
- SpringBoot
- 백엔드 개발자 역량
- Intercepter
- 향해플러스
- filter
- react실행
- JPA
- React
- 스프링공부
- 백엔드 개발자 공부
- HTTP
- 항해99
- BindingResult
- 항해플러스
- 인터셉터
- 향해플러스백엔드
- reject
- Java
- ArgumentResolver
- 로그인
- rejectValue
- 향해99
- 컨트
- exception
일 | 월 | 화 | 수 | 목 | 금 | 토 |
---|---|---|---|---|---|---|
1 | 2 | 3 | 4 | 5 | ||
6 | 7 | 8 | 9 | 10 | 11 | 12 |
13 | 14 | 15 | 16 | 17 | 18 | 19 |
20 | 21 | 22 | 23 | 24 | 25 | 26 |
27 | 28 | 29 | 30 |
글 보관함