일 | 월 | 화 | 수 | 목 | 금 | 토 |
---|---|---|---|---|---|---|
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 |
- Item04
- Spring Boot
- java
- NotBlank
- Web
- 데이터베이스
- @ControllerAdvice
- Effetive Java
- multi module
- Connection Pool
- Service Locator
- 플라이웨이트
- db
- Proxy Patter
- restTemplate
- springboot
- NotEmpty
- FCM
- Effective Java
- 트랜잭션
- SQL 삽입 공격
- 디자인 패턴
- Service Locator 패턴
- @Valid
- @MockBean
- Firebase
- JPA
- deleteById
- @SpyBean
- 이펙티브 자바
- Today
- Total
NoTimeForDawdling
기본형(Primitive Type)과 참조형(Reference Type) 본문
기본형과 참조형의 종류
기본형과 참조형의 종류는 다음과 같습니다.
- 기본형(Primitive Type)
- Boolean Type(boolean)
- Numeric Type
- Character Type(char)
- Integral Type
- Integer Type(short, int, long)
- Floating Point Type(float, double)
- 참조형(Reference Type)
- Class Type
- Interface Type
- Array Type
- Enum Type
기본형(Primitive Type)
기본형이란?
- 기본형은 실제 값을 저장하는 공간입니다.
- 자바에서 기본 자료형은 반드시 사용하기 전에 선언되어야 합니다.
- 비객체 타입으로 null값을 가질 수 없습니다.
기본형의 종류(8가지)
Type Bits Range of Values ---------------------------------------------------------------------------------------- byte 8bits -2^7 ~ 2^7-1 (-128 ~ 127) short 16bits -2^15 ~ 2^15-1 (-32768 ~ 32767) int 32bits -2^31 ~ 2^31-1 (-2147483648 ~ 2147483647) long 64bits -2^63 ~ 2^63-1 (-9223372036854775808 ~ 9223372036854775807) float 32bits 0x0.000002P-126f ~ 0x1.fffffeP+127f double 64bits 0x0.0000000000001P-1022 ~ 0x1.fffffffffffffP+1023 char 16bits \u0000 ~ \uffff (0 ~ 2^15-1) * 자바에서 unsgined로 동작하는 자료형 boolean 1bit true, false |
참조형(Reference Type)
참조형이란?
- 참조형은 값이 저장된 곳의 주소를 저장하는 공간으로 객체의 주소를 저장합니다.
- 선언한 자료형이 기본형이 아닌 경우 참조형입니다.
- 참조형에는 클래스형, 인터페이스 형, 배열형이 있습니다.
1. Class Type
클래스형은 기본형과 다르게 객체를 참조하는 형태입니다.
public class MyObject {
private int number;
public MyObject(int number) {
this.number = number;
}
public int getNumber() {
return number;
}
public void setNumber(int number) {
this.number = number;
}
}
위와 같이 MyObject라는 클래스를 하나 만들었습니다.
클래스형은 객체를 참조하는 형태라고 했습니다. 실제로 객체를 참조하는지 다음 코드를 통해 확인해보겠습니다.
public class ClassTypeExam {
public static void main(String[] args) {
MyObject firstClassType = new MyObject(2);
MyObject secondClassType = new MyObject(4);
System.out.println(String.format("First Class Type number: %d", firstClassType.getNumber()));
System.out.println(String.format("Second Class Type number: %d", secondClassType.getNumber()));
firstClassType = secondClassType;
System.out.println("-----------------------------------------");
System.out.println("First Class Type에 Second Class Type 대입 후");
System.out.println(String.format("First Class Type number: %d", firstClassType.getNumber()));
secondClassType.setNumber(6);
System.out.println("-----------------------------------------");
System.out.println("Second Class Type 값 변경 후");
System.out.println(String.format("First Class Type number: %d", firstClassType.getNumber()));
}
}
출력 결과는 위와 같습니다.
출력 결과를 보면 첫 번째 객체의 멤버 변수 값을 바꿨지만, 두 번째 객체도 같은 객체를 참조하기 때문에 동일한 값을 출력하는 것을 볼 수 있습니다.
위 코드에서 firstClassType변수와 secondClassType변수가 가지는 것은 실제 객체가 아닌 객체의 주소를 가진다고 생각하면 됩니다.
첫 번째 객체와 두 번째 객체는 같은 객체의 주소를 가지고 있기 때문에 어느 한쪽이 변하더라도 값이 동일한 것입니다.
두 객체의 연결고리를 끊고 싶다면 어느 하나의 변수에 null이나 new MyObject()를 통해 객체의 주소를 지워버리거나 새로운 객체를 가리키게 하면 됩니다.
2. Wrrapper Class
래퍼 클래스는 기본형을 클래스로 감싼 형태입니다.
기본형은 비객체이기 때문에 null을 넣을 수 없습니다. 하지만 래퍼 클래스를 활용하면 null 값을 넣는 것이 가능합니다.
public class WrapperClassExam {
public static void main(String[] args) {
Integer wrpperForInt = 30;
Integer wrapperInNull = null;
}
}
3. Interface Type
인터페이스를 만들게 되면 새로운 참조 자료형을 만드는 것과 같습니다.
4. Array Type
배열형은 기본형으로도 만들 수 있고 참조형으로도 만들 수 있습니다.
public class ArrayType {
public static void main(String[] args) {
int [] arrayTypeForInt = new int[2];
Long [] arrayTypeForLong = new Long[2];
Object[][] arrayTypeForObject = null;
}
}
-
자료형에 대해 []를 선언함으로 배열을 지정할 수 있습니다.
-
참고로 배열형 변수 또한 배열의 주소를 가지고 있는 것이기 때문에 클래스형의 특징과 일치합니다.
-
같은 객체의 주소를 바라보게 만들면 동일한 배열을 가리키게 됩니다
'Java' 카테고리의 다른 글
[Java] 강한 참조(Strong Reference)와 약한 참조(Weak Reference) (0) | 2021.06.13 |
---|---|
hashCode()와 equals() (0) | 2021.03.05 |
일급 컬렉션(First Class Collection) (0) | 2021.03.01 |
얕은 복사(Shallow Copy) vs 깊은 복사(Deep Copy) (0) | 2021.02.25 |
접근 제어자(Access Modifier) (0) | 2021.02.24 |