πŸ“š
TIL
  • README
  • Git
    • Basic
    • Remote Repository
    • Log & Diff
    • Rebase&Cherri-Pick
    • git-flow
  • DevOps
    • Monolithic vs MSA
    • Jenkins μ‹œμž‘ν•˜κΈ°
    • Airflow μ‹œμž‘ν•˜κΈ°
    • Airflow μ‹œμž‘ν•˜κΈ°
    • Build Tools
      • maven
  • 개발 방법둠
    • TDD
  • Spring
    • IoC
    • Is Spring Bean Thread-Safe?
    • Spring Singleton
    • Component Scan
    • Spring Annotation
    • 의쑴 관계 μ£Όμž…(DI)
    • Lombok ν™œμš©ν•˜κΈ°
    • Bean 생λͺ…주기와 콜백
    • Bean Scope
    • AOP(1) - AOPλž€
    • AOP(2) - Aop Proxy
    • AOP(3) - Dynamic Proxy
    • AOP(4) - AspectJ
    • POJO
    • Spring μ„œλΉ„μŠ€ ꡬ쑰
    • Transaction
    • JPAλž€?
    • JPA Entity
    • Spring Data JPA
    • Spring Data Specification
    • Model Mapping
    • Cache
    • restTemplate
    • YAML 파일 μ„€μ •
    • Spring Boot
      • H2 DB μ„€μ •
      • 닀쀑 λ°μ΄ν„°λ² μ΄μŠ€ μ„€μ •
      • Mybatis μ—°λ™ν•˜κΈ°
    • Spring Batch
      • Batch μ‹œμž‘ν•΄λ³΄κΈ°
      • Batch Job Flow
      • Job
      • Step
      • Batch Scope & Job Parameter
      • JobRepository와 λ©”νƒ€ν…Œμ΄λΈ”
      • Chunk μ§€ν–₯ ν”„λ‘œκ·Έλž˜λ°
      • ItemReader
      • ItemProcessor
      • ItemWriter
      • Batch Schedular
      • Job별 Beanλ“±λ‘ν•˜κΈ°
      • Batch κ΅¬ν˜„μ‹œ λ°œμƒν•œ 였λ₯˜ 정리
      • Spring Batch Scaling
        • Multithread Jobκ΅¬ν˜„μ‹œ μ΄μŠˆμ‚¬ν•­
    • Spring test
      • Junit5
        • ν…ŒμŠ€νŠΈ 이름 ν‘œκΈ°
        • ν…ŒμŠ€νŠΈ κ·Έλ£Ή μ‚¬μ΄μ˜ 관계
        • νƒœκ·Έμ™€ 필터링
        • 동적 ν…ŒμŠ€νŠΈ
        • ν…ŒμŠ€νŠΈ LifeCycle
        • ν…ŒμŠ€νŠΈ λ©”μ„œλ“œ
        • ν…ŒμŠ€νŠΈ μˆœμ„œ
        • AssertJ
        • ν…ŒμŠ€νŠΈ 병렬 μ‹€ν–‰
        • AssertJ
        • Mock
      • Spring Boot Test DB 뢄리
      • Spring Batch Test
  • Web Application
    • Web Server & WAS
    • κ΄€λ ¨ κ°œλ… - HTTP API, HTML, CSR, SSR
    • Servlet
    • JSP
    • Cookie And Session
    • μ˜ˆμ™ΈνŽ˜μ΄μ§€
    • Java Bean
    • JDBC
    • Connection Pool
    • 파일 μ—…λ‘œλ“œ
    • Expression Language
    • JSTL
    • FrontControllerνŒ¨ν„΄ Command νŒ¨ν„΄
    • Forwarding
    • MVC
    • νšŒμ›κ°€μž…μ˜ˆμ œ
    • μ°Έκ³ 
      • κ°œλ°œν™˜κ²½μ„€μ •
  • Java+
    • SOAP/WSDL vs REST
    • WSDL을 JAVA둜 λ³€ν™˜ν•˜κΈ°
    • SOAP 톡신 OPEN API둜 κ°œλ°œν•΄λ³΄κΈ°
  • Java
    • Basic
      • λ³€μˆ˜μ™€ νƒ€μž…
      • μ—°μ‚°μž
      • 쑰건문과 반볡문
      • μ°Έμ‘° νƒ€μž…
      • 클래슀
      • 상속(Inheritance)
      • μΈν„°νŽ˜μ΄μŠ€(Interface)
      • 쀑첩 ν΄λž˜μŠ€μ™€ 쀑첩 μΈν„°νŽ˜μ΄μŠ€
      • μ˜ˆμ™Έ 처리
      • API - Object, System, Class, Math, Wrapper
      • API - String, StringBuffer, StringBuilder
      • Thread
      • Generic
      • Lambda
      • Collection - List, Set
      • Collection - Map
      • Collection - Tree
      • Collection - Stack, Queue
      • Stream
      • Reflection
      • μ •κ·œν‘œν˜„μ‹
      • GUI
      • UML
      • Serializable
    • Advanced
      • OutOfMemoryError
      • AutoValue
      • meta-annotation
        • @Retention
        • @Target
        • @Repeatable
    • Effective Java 3/E
      • ITEM 1: Static Factory Method(정적 λ©”μ†Œλ“œ)
      • ITEM 2: Builder Pattern
      • ITEM 3: Singleton
      • ITEM 4: Private Constructor
      • ITEM 5: Dependency Injection
      • ITEM 6: Avoid Unnecessary Object
      • ITEM 7: Eliminate Object Reference
      • ITEM 8: Avoid finalizer and cleaner
      • ITEM 9: try-with-resources
      • ITEM 10: The gerneral contract when overriding equlas
      • ITEM 11: Overriding hashCode
      • ITEM 12: overriding toString
      • ITEM 13: overriding clone judiciously
      • ITEM 14: Consider implementing comparable
      • ITEM 15: ν΄λž˜μŠ€μ™€ λ©€λ²„μ˜ 접근을 μ΅œμ†Œν™”ν•΄λΌ
      • ITEM 16: Use Accessor methods
      • ITEM 17: λ³€κ²½ κ°€λŠ₯성을 μ΅œμ†Œν™”ν•΄λΌ(λΆˆλ³€ 클래슀)
      • ITEM 18: 상속보단 μ»΄ν¬μ§€μ…˜μ„ μ‚¬μš©ν•΄λΌ
      • ITEM 19: 상속을 κ³ λ €ν•΄ μ„€κ³„ν•˜κ³  λ¬Έμ„œν™”ν•΄λΌ
      • ITEM 20: 좔상 ν΄λž˜μŠ€λ³΄λ‹€ μΈν„°νŽ˜μ΄μŠ€λ₯Ό μš°μ„ ν•˜λΌ
      • ITEM 21: μΈν„°νŽ˜μ΄μŠ€λŠ” κ΅¬ν˜„ν•˜λŠ” μͺ½μ„ 생각해 섀계해라.
      • ITEM 22: μΈν„°νŽ˜μ΄μŠ€λŠ” νƒ€μž…μ„ μ •μ˜ν•˜λŠ” μš©λ„λ‘œλ§Œ μ‚¬μš©ν•΄λΌ
      • ITEM 23: νƒœκ·Έ 달린 ν΄λž˜μŠ€λ³΄λ‹€ 클래슀 계측ꡬ쑰λ₯Ό ν™œμš©ν•΄λΌ
      • ITEM 24: 멀버 ν΄λž˜μŠ€λŠ” λ˜λ„λ‘ static으둜 κ΅¬ν˜„ν•΄λΌ
      • ITEM 25: ν†±λ ˆλ²¨ ν΄λž˜μŠ€λŠ” ν•œ νŒŒμΌμ— ν•˜λ‚˜λ§Œ 생성해라.
      • ITEM 26: Raw type은 μ‚¬μš©ν•˜μ§€ 마라
      • ITEM 27: 비검사 κ²½κ³ λ₯Ό μ œκ±°ν•΄λΌ
      • ITEM 28: λ°°μ—΄λ³΄λ‹€λŠ” 리슀트λ₯Ό μ‚¬μš©ν•΄λΌ
      • ITEM 29: 이왕이면 μ œλ„€λ¦­ νƒ€μž…μœΌλ‘œ λ§Œλ“€μ–΄λΌ
      • ITEM 30: 이왕이면 μ œλ„€λ¦­ λ©”μ„œλ“œλ‘œ λ§Œλ“€μ–΄λΌ
      • ITEM 31 : ν•œμ •μ  μ™€μΌλ“œμΉ΄λ“œλ₯Ό μ‚¬μš©ν•΄ API μœ μ—°μ„±μ„ 높여라
      • ITEM 32: μ œλ„€λ¦­κ³Ό κ°€λ³€μΈμˆ˜λ₯Ό ν•¨κ»˜ μ“Έ λ•ŒλŠ” 신쀑해라
      • ITEM 33: νƒ€μž… μ•ˆμ „ 이쒅 μ»¨ν…Œμ΄λ„ˆλ₯Ό 고렀해라
      • ITEM 34: int μƒμˆ˜ λŒ€μ‹  μ—΄κ±° νƒ€μž…μ„ μ‚¬μš©ν•΄λΌ
      • ITEM 35: ordinal λ©”μ„œλ“œ λŒ€μ‹  μΈμŠ€ν„΄μŠ€ ν•„λ“œλ₯Ό μ‚¬μš©ν•΄λΌ
      • ITEM 36: λΉ„νŠΈ ν•„λ“œ λŒ€μ‹  EnumSet을 μ‚¬μš©ν•΄λΌ
      • ITEM 37: ordinal 인덱싱 λŒ€μ‹  EnumMap을 μ‚¬μš©ν•΄λΌ
      • TEM 38 : ν™•μž₯ν•  수 μžˆλŠ” μ—΄κ±°νƒ€μž…μ΄ ν•„μš”ν•˜λ©΄ μΈν„°νŽ˜μ΄μŠ€λ₯Ό μ‚¬μš©ν•΄λΌ
      • ITEM 39: λͺ…λͺ… νŒ¨ν„΄λ³΄λ‹€ μ• λ„ˆν…Œμ΄μ…˜μ„ μ‚¬μš©ν•΄λΌ
      • ITEM 40: @Override μ–΄λ…Έν…Œμ΄μ…˜μ„ μΌκ΄€λ˜κ²Œ μ‚¬μš©ν•΄λΌ
      • ITEM 41: μ •μ˜ν•˜λ €λŠ” 것이 νƒ€μž…μ΄λΌλ©΄ 마컀 μΈν„°νŽ˜μ΄μŠ€λ₯Ό μ‚¬μš©ν•΄λΌ
      • ITEM 42: 읡λͺ… ν΄λž˜μŠ€λ³΄λ‹€λŠ” λžŒλ‹€λ₯Ό μ‚¬μš©ν•΄λΌ
      • ITEM 43: λžŒλ‹€λ³΄λ‹€λŠ” λ©”μ„œλ“œ μ°Έμ‘°λ₯Ό μ‚¬μš©ν•΄λΌ
      • ITEM 44: ν‘œμ€€ ν•¨μˆ˜ν˜• μΈν„°νŽ˜μ΄μŠ€λ₯Ό μ‚¬μš©ν•΄λΌ
      • ITEM 45: μŠ€νŠΈλ¦Όμ€ μ£Όμ˜ν•΄μ„œ μ‚¬μš©ν•΄λΌ
      • ITEM 46: μŠ€νŠΈλ¦Όμ—μ„œ λΆ€μž‘μš© μ—†λŠ” ν•¨μˆ˜λ₯Ό μ‚¬μš©ν•΄λΌ
      • ITEM 47: λ°˜ν™˜ νƒ€μž…μœΌλ‘œλŠ” μŠ€νŠΈλ¦Όλ³΄λ‹€ μ»¬λ ‰μ…˜μ΄ λ‚«λ‹€.
      • ITEM 48: 슀트림 λ³‘λ ¬ν™”λŠ” μ£Όμ˜ν•΄μ„œ μ‚¬μš©ν•΄λΌ
      • ITEM 49: λ§€κ°œλ³€μˆ˜κ°€ μœ νš¨ν•œμ§€ 검사해라
      • ITEM 50: μ μ‹œμ— 방어적 볡사본을 λ§Œλ“€μ–΄λΌ
      • ITEM 51: λ©”μ„œλ“œ μ‹œκ·Έλ‹ˆμ²˜λ₯Ό μ‹ μ€‘νžˆ 섀계해라
      • ITEM 52: λ‹€μ€‘μ •μ˜λŠ” μ‹ μ€‘νžˆ μ‚¬μš©ν•΄λΌ
      • ITEM 53: κ°€λ³€μΈμˆ˜λŠ” μ‹ μ€‘νžˆ μ‚¬μš©ν•΄λΌ
      • ITEM 54: null이 μ•„λ‹Œ, 빈 μ»¬λ ‰μ…˜μ΄λ‚˜ 배열을 λ°˜ν™˜ν•΄λΌ
      • ITEM 55: Optional λ°˜ν™˜μ€ μ‹ μ€‘ν•˜κ²Œ 해라
      • ITEM 56: 곡개된 API μš”μ†Œμ—λŠ” 항상 주석을 μž‘μ„±ν•΄λΌ
      • ITEM 57: μ§€μ—­λ³€μˆ˜μ˜ λ²”μœ„λ₯Ό μ΅œμ†Œν™”ν•΄λΌ
      • ITEM 58: 전톡적인 for λ¬Έλ³΄λ‹€λŠ” for-each문을 μ‚¬μš©ν•΄λΌ
      • ITEM 59: 라이브러리λ₯Ό 읡히고 μ‚¬μš©ν•΄λΌ
      • ITEM 60: μ •ν™•ν•œ 닡이 ν•„μš”ν•˜λ‹€λ©΄ float와 double은 피해라
      • ITEM 61: λ°•μ‹±λœ κΈ°λ³Έ νƒ€μž…λ³΄λ‹€λŠ” κΈ°λ³Έ νƒ€μž…μ„ μ‚¬μš©ν•΄λΌ
      • ITEM 62: λ‹€λ₯Έ νƒ€μž…μ΄ μ μ ˆν•˜λ‹€λ©΄ λ¬Έμžμ—΄ μ‚¬μš©μ„ 피해라
      • ITEM 63: λ¬Έμžμ—΄ 연결은 λŠλ¦¬λ‹ˆ μ£Όμ˜ν•΄λΌ
      • ITEM 64: κ°μ²΄λŠ” μΈν„°νŽ˜μ΄μŠ€λ₯Ό μ‚¬μš©ν•΄ 참쑰해라
      • ITEM 65: λ¦¬ν”Œλ ‰μ…˜λ³΄λ‹€λŠ” μΈν„°νŽ˜μ΄μŠ€λ₯Ό μ‚¬μš©ν•΄λΌ
      • ITEM 66: λ„€μ΄ν‹°λΈŒ λ©”μ„œλ“œλŠ” μ‹ μ€‘νžˆ μ‚¬μš©ν•΄λΌ
      • ITEM 67: μ΅œμ ν™”λŠ” μ‹ μ€‘νžˆ 해라
      • ITEM 68: 일반적으둜 ν†΅μš©λ˜λŠ” λͺ…λͺ… κ·œμΉ™μ„ 따라라
    • 객체지ν–₯ 섀계 원칙(SOLID)
    • λ””μžμΈνŒ¨ν„΄
      • Strategy Pattern
      • Template Method Pattern
      • Factory Method Pattern
      • Singleton
      • Delegation
      • Proxy
      • Adapter Pattern
    • μ‹€μŠ΅
      • μΈν„°νŽ˜μ΄μŠ€ μ‹€μŠ΅ - Vehicle
      • μΈν„°νŽ˜μ΄μŠ€ μ‹€μŠ΅ - Remote
      • GUI μ‹€μŠ΅ - Calculator
      • GUI μ‹€μŠ΅ - button
      • GUI μ‹€μŠ΅ - lotto
      • Thread μ‹€μŠ΅ - μ’Œμ„μ˜ˆμ•½, 메세지보내기
    • Jar vs War
  • λ°μ΄ν„°λ² μ΄μŠ€
    • KEY
    • Index
    • Transaction
    • Trigger
    • Procedure / Function
    • Package
    • λ°μ΄ν„°λ² μ΄μŠ€ 배움터
      • λ°μ΄ν„°λ² μ΄μŠ€ μ‹œμŠ€ν…œ
      • 관계데이터 λͺ¨λΈ
      • κ΄€κ³„λŒ€μˆ˜μ™€ SQL
    • MySQL
      • Databaseλž€
      • MySQL μ‹œμž‘ν•˜κΈ°
      • MySQL Database
      • MySQL Table
      • CRUD
      • κ΄€κ³„ν˜• λ°μ΄ν„°λ² μ΄μŠ€
      • Server와 Client
    • PostgreSQL
    • NoSQL
      • Install Cassandra on mac
      • Cassandraλž€?
      • NiFiλž€
  • Algorithm
    • String
    • Recursion
    • Dynamic Programming
    • Array, Struct, Pointer
    • Math
    • Sort
    • List
    • Stack
    • Queue
    • Graph
    • Tree
    • Maze
    • AVL
    • μ΄μ§„νƒμƒ‰νŠΈλ¦¬(Binary Search Tree)
    • DFS와 BFS
    • λ‹€μ΅μŠ€νŠΈλΌ μ•Œκ³ λ¦¬μ¦˜(Dijkstra's Algorithm)
    • Red-Black 트리
    • A* μ•Œκ³ λ¦¬μ¦˜
    • Heap
    • Huffman Coding
    • Priority Queue
    • Bellman-Ford μ•Œκ³ λ¦¬μ¦˜
    • C++
      • Class
      • STL
        • STL pair
        • STL Container - Associate Container
        • STL Container - Sequence Container
        • STL Container - Container Adapter
  • JavaScript
    • JABASCRIPT BASIC
    • Shallow Copy vs Deep Copy
    • OBJECT MODEL
    • NODE
    • 동기 처리 vs 비동기 처리
    • AJAX
    • CALLBACK
    • PROMISE
    • DEFERRER
    • UNDERSCORE
    • WEBPACK
    • SCOPE
    • EXECUTION CONTEXT
    • Image Object
    • BFCacheλž€?
    • history.scrollRestoration
    • Intersection Observer
    • JWT - JSON Web Token
    • HTML vs JSON
  • Vue.js
    • ν™˜κ²½μ„€μ •
    • Vue.jsλž€?
    • Vue Instance
    • Vue Component
    • Vue Router
    • HTTP 톡신
    • Template
    • Single File Component
    • Vue Animation
    • Vuex
    • Djnago와 μ—°λ™ν•˜κΈ°
  • Backbone.js
    • Model
    • Collection
    • Sync
    • view
  • Node.js
    • Doit! - λ…Έλ“œλ‘œ λ§Œλ“€ 수 μžˆλŠ” λŒ€ν‘œμ μΈ μ„œλ²„μ™€ μš©λ„
    • Doit! - λ…Έλ“œμ— λŒ€ν•΄ μ•Œμ•„λ³΄κ³  개발 도ꡬ μ„€μΉ˜ν•˜κΈ°
    • Doit! - λ…Έλ“œ κ°„λ‹¨ν•˜κ²Œ μ‚΄νŽ΄λ³΄κΈ°
    • Doit! - λ…Έλ“œμ˜ μžλ°”μŠ€ν¬λ¦½νŠΈμ™€ μΉœν•΄μ§€κΈ°
    • Doit! - λ…Έλ“œμ˜ κΈ°λ³Έ κΈ°λŠ₯ μ•Œμ•„λ³΄κΈ°
    • Doit! - μ›Ή μ„œλ²„ λ§Œλ“€κΈ°
    • Doit! - λ°μ΄ν„°λ² μ΄μŠ€ μ‚¬μš©ν•˜κΈ°
    • Doit! - μ΅μŠ€ν”„λ ˆμŠ€ ν”„λ‘œμ νŠΈλ₯Ό λͺ¨λ“ˆν™”ν•˜κΈ°
    • Doit! - λ·° ν…œν”Œλ¦Ώ μ μš©ν•˜κΈ°
    • Doit! - 패슀포트둜 μ‚¬μš©μž μΈμ¦ν•˜κΈ°
    • Doit! - μ±„νŒ…μ„œλ²„ λ§Œλ“€κΈ°
    • Doit! - JSON-RPC μ„œλ²„ λ§Œλ“€κΈ°
  • Python
    • Warning-Could not import the lzma module
    • Pandas
      • Pandas 자료ꡬ쑰
      • Pandas 데이터 μž…μΆœλ ₯
      • DataFrame Data μ‚΄νŽ΄λ³΄κΈ°
      • μ‹œκ°ν™” 도ꡬ - Matplotlib
  • ML
    • μΆ”μ²œ μ‹œμŠ€ν…œ
      • Collaborative Filtering
      • Matrix Factorization
  • Django
    • Basic
      • ν™˜κ²½μ„€μ •
      • About Django
      • Start Django Project
      • Secret Key κ΄€λ¦¬ν•˜κΈ°
      • Settings λΆ„λ¦¬ν•˜κΈ°
      • Django App
      • Django View & URL (1)
      • Django Model
        • MySQL 연동
      • Django Admin
      • Django View & URL (2)
      • Django Template
      • Django Template & View & URL
      • Django Static
      • Django form
    • Advanced
      • Django Generic View
      • Django Automated Testing
      • Django Extenstion Template
      • Django Model Package
      • Django OpenSSL setting
    • REST framework
      • Rest API
      • Serializers
      • ViewSet
    • Error
      • ν™˜κ²½μ„€μ • zlib 였λ₯˜λ°œμƒ
      • ModuleNotFoundError
    • νŒ¨ν‚€μ§€
      • django-debug-toolbar
    • Vue.js μ—°λ™ν•˜κΈ°
  • Ruby
    • variable & input/output
    • 쑰건문
    • 반볡문
    • Array & Hash
    • Method
    • Proc&Lamda
    • Class
  • Ruby on Rails
    • Scaffolding
    • Controller
    • Model
    • Model-M:N relation
    • Model Validation
    • 멋사 10μ£Όμ°¨ μˆ˜μ—…(Tip)
  • HTML/CSS
    • Udacity - Intro to HTML/CSS
    • Udacity - Responsive Web Design
    • Udacity - Responsive Images
    • HTML Basic
    • CSS Basic
    • HTML5 Sementic Tag
    • HTML ν…μŠ€νŠΈ κ΄€λ ¨ νƒœκ·Έλ“€
    • HTML5 λ©€ν‹°λ―Έλ””μ–΄
    • HTML 폼 κ΄€λ ¨ νƒœκ·Έλ“€
    • ν…μŠ€νŠΈ κ΄€λ ¨ μŠ€νƒ€μΌ
    • 색상과 배경을 μœ„ν•œ μŠ€νƒ€μΌ
    • λ ˆμ΄μ•„μ›ƒμ„ μœ„ν•œ μŠ€νƒ€μΌ
    • CSS 포지셔닝
    • λ‹€μž¬λ‹€λŠ₯ν•œ CSS3 μ„ νƒμž
    • CSS와 μ• λ‹ˆλ©”μ΄μ…˜
    • λ°˜μ‘ν˜• μ›Ήμ΄λž€?
  • OS(운영체제)
    • Linux
      • Daemon
      • Cron
      • ν”„λ‘œμ„ΈμŠ€ κ΄€λ ¨ λͺ…λ Ήμ–΄
      • ν…μŠ€νŠΈ 파일 λͺ…λ Ήμ–΄
  • Network
    • λ„€νŠΈμ›Œν¬ κΈ°λ³Έ κ°œλ…
    • λ„€νŠΈμ›Œν¬ κΈ°λ³Έ κ·œμΉ™
    • 물리 계측
    • 데이터 링크 계측
    • λ„€νŠΈμ›Œν¬ 계측
    • 전솑 계측
    • μ‘μš© 계측
    • λ„€νŠΈμ›Œν¬ 전체 흐름
    • 무선 랜
  • IT 기타지식
    • NASλž€
Powered by GitBook
On this page
  • μ§λ ¬ν™”λž€?
  • 직렬화 쑰건
  • μ™œ μ‚¬μš©ν• κΉŒ?
  • μž₯점
  • μ–Έμ œ μ–΄λ””μ„œ μ‚¬μš©ν•΄μ•Όν• κΉŒ?
  • μ˜ˆμ‹œ
  • serialVersionUID
  • 직렬화 μ‚¬μš©μ‹œ μ£Όμ˜μ‚¬ν•­
  • μš©λŸ‰ 문제
  • ν˜Έν™˜μ„±
  • μ°Έκ³ 

Was this helpful?

  1. Java
  2. Basic

Serializable

PreviousUMLNextAdvanced

Last updated 4 years ago

Was this helpful?

μ§λ ¬ν™”λž€?

Serializeableμ΄λž€ μžλ°” μ‹œμŠ€ν…œ λ‚΄λΆ€μ—μ„œ μ‚¬μš©λ˜λŠ” 객체 λ˜λŠ” 데이터λ₯Ό μ™ΈλΆ€μ˜ μžλ°” μ‹œμŠ€ν…œμ—μ„œλ„ μ‚¬μš©ν•  수 μžˆλ„λ‘ byte ν˜•νƒœλ‘œ 데이터 λ³€ν™˜ν•˜λŠ” 기술과 byte둜 λ³€ν™˜λœ 데이터λ₯Ό λ‹€μ‹œ 객체둜 λ³€ν™˜ν•˜λŠ” κΈ°μˆ μ„ ν•©μ³μ„œ λ§ν•œλ‹€.

μ‹œμŠ€ν…œ 적으둜 λ§ν•˜λ©΄, JVM(Java Virtual Machine)의 λ©”λͺ¨λ¦¬μ— 상주(νž™/μŠ€νƒ)λ˜μ–΄ μžˆλŠ” 객체 데이터λ₯Ό λ°”μ΄νŠΈ ν˜•νƒœλ‘œ λ³€ν™˜ν•˜λŠ” 기술과 μ§λ ¬ν™”λœ λ°”μ΄νŠΈ ν˜•νƒœμ˜ 데이터λ₯Ό 객체둜 λ³€ν™˜ν•΄μ„œ JVM으둜 μƒμ£Όμ‹œν‚€λŠ” ν˜•νƒœλ₯Ό λ§ν•œλ‹€.

이전에 Djangoμ—μ„œλŠ” python κΈ°λ³Έ 데이터 μœ ν˜•μ„, JSON, XML ν˜•νƒœλ‘œ λ³€ν™˜ν•˜κΈ° μœ„ν•΄ μ‚¬μš©ν–ˆμ—ˆλ‹€.

쑰금 더 μžμ„Ένžˆ μ‚΄νŽ΄λ³΄λ©΄,

  • λŒ€λΆ€λΆ„ OS의 ν”„λ‘œμ„ΈμŠ€ κ΅¬ν˜„μ€ μ„œλ‘œ λ‹€λ₯Έ 가상메λͺ¨λ¦¬μ£Όμ†Œκ³΅κ°„(VAS)λ₯Ό κ°–κΈ° λ•Œλ¬Έμ— Object νƒ€μž…μ˜ μ°Έμ‘°κ°’ 데이터 μΈμŠ€ν„΄μŠ€λ₯Ό 전달할 수 μ—†λ‹€.(μ „λ‹¬ν•˜λ”λΌλ„, μ„œλ‘œ λ‹€λ₯Έ λ©”λͺ¨λ¦¬ κ³΅κ°„μ—μ„œ μ „λ‹¬λœ μ°Έμ‘°κ°’μ΄λ―€λ‘œ 무의미) λ•Œλ¬Έμ— μ„œλ‘œ λ‹€λ₯Έ λ©”λͺ¨λ¦¬ 곡간 μ‚¬μ΄μ˜ 데이터λ₯Ό μ „λ‹¬ν•˜κΈ° μœ„ν•΄μ„œ λ©”λͺ¨λ¦¬ κ³΅κ°„μ˜ μ£Όμ†Œκ°’μ΄ μ•„λ‹Œ Byte ν˜•νƒœλ‘œ μ§λ ¬ν™”λœ 객체 데이터λ₯Ό 전달해 μ‚¬μš©ν•˜λŠ” μͺ½μ—μ„œ μ—­μ§λ ¬ν™”ν•˜μ—¬ μ‚¬μš©ν•  수 μžˆλ‹€.

  • Java ν΄λž˜μŠ€λŠ” 객체 μ•ˆμ— 객체가 μ‘΄μž¬ν•  수 μžˆλ‹€. 객체 Aμ•ˆμ— λ“€μ–΄μžˆλŠ” 객체 Bλ₯Ό μ§λ ¬ν™”ν•˜λ©΄, 객체 B자체의 데이터λ₯Ό Primitive type(Byte type)의 λ°μ΄ν„°λ‘œ λ³€ν™˜ν•œλ‹€. μ§λ ¬ν™”λœ λ°μ΄ν„°λŠ” λͺ¨λ‘ Primitive νƒ€μž…μ˜ 데이터 묢음이며, 파일 μ €μž₯μ΄λ‚˜ λ„€νŠΈμ›Œν¬ 전솑 μ‹œ νŒŒμ‹±ν•  수 μžˆλŠ” μœ μ˜λ―Έν•œ 데이터가 λ˜λŠ” 것이닀.

  • JSON, CSV λ“±μ˜ 포맷은 직렬화/역직렬화 μ‹œμ— νŠΉμ • 라이브러리λ₯Ό λ„μž…ν•˜λ©΄ μ‰½κ²Œ 개발이 κ°€λŠ₯ν•˜λ©°, ꡬ쑰가 λ³΅μž‘ν•΄μ§€λ©΄ 직접 λ§€ν•‘ν•΄μ€˜μ•Όν•œλ‹€.

직렬화 쑰건

  1. Java.io.Serializable μΈν„°νŽ˜μ΄μŠ€λ₯Ό 상속 받은 객체와 Primitive νƒ€μž…μ˜ 데이터

    • κΈ°λ³Έμžλ£Œν˜•(Primitive Type)은 μ •ν•΄μ§„ Byte λ³€μˆ˜

  2. 객체의 멀버듀 쀑 Serializable μΈν„°νŽ˜μ΄μŠ€κ°€ κ΅¬ν˜„λ˜μ§€ μ•Šμ€ 것이 μ‘΄μž¬ν•˜λ©΄ μ•ˆλœλ‹€.

  3. transient κ°€ μ„ μ–Έλœ λ©€λ²„λŠ” μ „μ†‘ν•˜μ§€ μ•ŠλŠ”λ‹€.

    • transientμ„ μ–Έμ‹œ 직렬화 λŒ€μƒμ—μ„œ μ œμ™Έλ¨

μ™œ μ‚¬μš©ν• κΉŒ?

μžλ°” 직렬화 ν˜•νƒœμ˜ 데이터 κ΅ν™˜μ€ μžλ°” μ‹œμŠ€ν…œ κ°„μ˜ 데이터 κ΅ν™˜μ„ μœ„ν•΄ μ‘΄μž¬ν•œλ‹€.

μž₯점

  • μžλ°” μ‹œμŠ€ν…œμ—μ„œμ˜ κ°œλ°œμ— μ΅œμ ν™” λ˜μ–΄μžˆλ‹€. λ³΅μž‘ν•œ 데이터 ꡬ쑰의 클래슀 객체일지라도, μ§λ ¬ν™”μ˜ 기본만 μ§€ν‚€λ©΄ 큰 μž‘μ—… 없이 직렬화/역직렬화가 κ°€λŠ₯ν•˜λ‹€.

  • 데이터 νƒ€μž…μ΄ μžλ™μœΌλ‘œ λ§žμΆ°μ§€κΈ° λ•Œλ¬Έμ— κ΄€λ ¨ 뢀뢄을 크게 μ‹ κ²½μ“°μ§€ μ•Šμ•„λ„ λœλ‹€.

μ–Έμ œ μ–΄λ””μ„œ μ‚¬μš©ν•΄μ•Όν• κΉŒ?

  • JVM의 λ©”λͺ¨λ¦¬μ—μ„œλ§Œ μƒμ£Όλ˜μ–΄μžˆλŠ” 객체λ₯Ό κ·ΈλŒ€λ‘œ μ˜μ†ν™”(Persistence)κ°€ ν•„μš”ν•  λ•Œ μ‚¬μš©λœλ‹€.

    • μ‹œμŠ€ν…œμ΄ μ’…λ£Œλ˜λ”λΌλ„ μ—†μ–΄μ§€μ§€ μ•ŠλŠ” μž₯점을 κ°€μ§€λ©°, μ˜μ†ν™”λœ 데이터이기 λ•Œλ¬Έμ— λ„€νŠΈμ›Œν¬λ‘œ 전솑이 κ°€λŠ₯ν•˜λ‹€.

  • Servlet Session

    • Servlet 기반 WAS(ν†°μΊ£, μ›Ήλ‘œμ§ λ“±)듀은 λŒ€λΆ€λΆ„ μ„Έμ…˜μ˜ μžλ°” 직렬화λ₯Ό μ§€μ›ν•˜κ³  μžˆλ‹€. λ‹¨μˆœνžˆ μ„Έμ…˜μ„ μ„œλΈ”λ¦Ώ λ©”λͺ¨λ¦¬ μœ„μ—μ„œ μš΄μš©ν•œλ‹€λ©΄, 직렬화가 ν•„μš”ν•˜μ§€ μ•Šμ§€λ§Œ, 파일둜 μ €μž₯ν•˜κ±°λ‚˜ μ„Έμ…˜ ν΄λŸ¬μŠ€ν„°λ§, DB μ €μž₯ν•˜λŠ” μ˜΅μ…˜λ“±μ„ μ„ νƒν•˜λ©΄ μ„Έμ…˜ μžμ²΄κ°€ μ§λ ¬ν™”λ˜μ–΄ μ „λ‹¬λœλ‹€. 즉, μ„Έμ…˜μ— ν•„μš”ν•œ κ°μ²΄λŠ” java.io.Serializable μΈν„°νŽ˜μ΄μŠ€λ₯Ό κ΅¬ν˜„ν•˜λŠ” 것을 μΆ”μ²œν•œλ‹€.

  • Cache

    • μžλ°” μ‹œμŠ€ν…œμ—μ„œ 퍼포먼슀λ₯Ό μœ„ν•΄ μΊμ‹œ(Ehcache, Redis, Memcached) 라이브러리λ₯Ό 많이 μ‚¬μš©ν•œλ‹€. μΊμ‹œν•  뢀뢄을 μžλ°” μ§λ ¬ν™”λœ 데이터λ₯Ό μ €μž₯ν•΄μ„œ μ‚¬μš©λœλ‹€. μžλ°” 직렬 ν™”λ§Œ μ΄μš©ν•΄μ„œλ§Œ μΊμ‹œλ₯Ό μ μš©ν•˜μ§€ μ•Šμ§€λ§Œ, κ°€μž₯ κ°„νŽΈν•˜κΈ° λ•Œλ¬Έμ— 많이 μ‚¬μš©ν•œλ‹€.

  • Remote Method Inovation

    • RMIλŠ” 원격 μ‹œμŠ€ν…œ κ°„μ˜ λ©”μ„Έμ§€ κ΅ν™˜μ„ μœ„ν•΄μ„œ μ‚¬μš©ν•˜λŠ” κΈ°μˆ μ΄λ‹€. 보톡 원격 μ‹œμŠ€ν…œκ³Ό 톡신을 μœ„ν•΄ IP와 포트λ₯Ό μ΄μš©ν•΄ μ†ŒμΌ“ν†΅μ‹ μ„ ν•˜μ§€λ§Œ, RMIλŠ” κ·Έ 뢀뢄을 좔상화해 원격에 μžˆλŠ” μ‹œμŠ€ν…œμ˜ λ©”μ„œλ“œλ₯Ό 둜컬 μ‹œμŠ€ν…œμ˜ λ©”μ„œλ“œμΈ κ²ƒμ²˜λŸΌ ν˜ΈμΆœν•  수 μžˆλ‹€. 원격 μ‹œμŠ€ν…œμ˜ λ©”μ„œλ“œλ₯Ό ν˜ΈμΆœν•  λ•Œ μ „λ‹¬ν•˜λŠ” λ©”μ„Έμ§€λ₯Ό μžλ™μœΌλ‘œ μ§λ ¬ν™”ν•˜μ—¬ μ‚¬μš©ν•˜κ³ , 전달받은 원격 μ‹œμŠ€ν…œμ—μ„œ ν•΄λ‹Ή λ©”μ„Έμ§€λ₯Ό μ—­μ§λ ¬ν™”ν•˜μ—¬ μ‚¬μš©ν•œλ‹€.

  • 객체가 μ„Έμ…˜μ— μ €μž₯ν•˜μ§€ μ•ŠλŠ” λ‹¨μˆœν•œ 데이터 집합이고, μ»¨νŠΈλ‘€λŸ¬μ—μ„œ μƒμ„±λ˜μ–΄ λ·°μ—μ„œ μ†Œλ©Έν•˜λŠ” λ°μ΄ν„°μ˜ 전달체라면 객체 μ§λ ¬ν™”λŠ” κ³ λ €ν•˜μ§€ μ•Šμ•„λ„λœλ‹€.

  • μ„Έμ…˜ 관리λ₯Ό μŠ€ν† λ¦¬μ§€λ‚˜ λ„€νŠΈμ›Œν¬ μžμ›μ„ μ΄μš©ν•œλ‹€λ©΄ 객체 직렬화λ₯Ό ν•΄μ•Όν•˜λ©°, λ©”λͺ¨λ¦¬μ—μ„œλ§Œ κ΄€λ¦¬ν•œλ‹€λ©΄ 객체 직렬화λ₯Ό ν•  ν•„μš”κ°€ μ—†λ‹€.

μ‹€μ œλ‘œ μƒν’ˆμƒμ„Έ κ°œλ°œμ‹œ Dtoλ₯Ό μžλ°” 직렬화λ₯Ό ν•˜μ—¬ μƒμ„±ν–ˆμ—ˆλ‹€. μ „μ‹œ μ„œλ²„ - ν”„λ‘ νŠΈ μ„œλ²„ κ°„ 직렬화λ₯Ό 톡해 별도 μž‘μ—… 없이 λ°”λ‘œ 데이터 νƒ€μž…μ„ λ§žμΆ°μ£ΌλŠ” μš©λ„λ‘œ μ‚¬μš©ν–ˆλ‹€.

μ˜ˆμ‹œ

import java.io.Serializable;

import lombok.Data;

@Entity
@Getter
@Setter
@toString
public class AllnItem implements Serializable {
    private static final long serialVersionUID = 4140042043347990835L;

    private String chnlId;
    private String salestrNo;
    private String itemId;
    private String siteNo;
  private String applyYn;
}
AllnItem allnItem = new AllnItem("0000000","1234", "1000000001", "1001", "Y");
byte[] selializedAllnItem;
try (ByteArrayOutputStream baos = new ByteArrayOutputStream()) {
    try (ObjectOutputStream oos = new ObjectOutputStream(baos)) {
        oos.writeObject(allnItem);

        // μ§λ ¬ν™”λœ AllnItem 객체
        selializedAllnItem = baos.toByteArray();
    }
}
try (ByteArrayInputStream bais = new ByteArrayInputStream(selializedAllnItem)) {
    try (ObjectInputStream ois = new ObjectInputStream(bais)) {

        // μ—­μ§λ ¬ν™”λœ AllnItem 객체λ₯Ό μ½μ–΄μ˜¨λ‹€.
        Object obj = ois.readObject();
        AllnItem allnItem = (AllnItem) obj;
    }
}

serialVersionUID

Java 직렬화 λŒ€μƒ κ°μ²΄λŠ” λ™μΌν•œ serialVersionUID λ₯Ό κ°€μ§€κ³  μžˆμ–΄μ•Όν•œλ‹€. ν•˜μ§€λ§Œ, 직접 μ„ μ–Έν•˜μ§€ μ•Šλ”λΌλ„, λ‚΄λΆ€μ μœΌλ‘œ 클래슀의 ꡬ쑰 정보λ₯Ό μ΄μš©ν•΄ μžλ™μœΌλ‘œ μƒμ„±λœ 해쉬값이 ν• λ‹Ήλœλ‹€. κ·ΈλŸ¬λ―€λ‘œ 클래슀의 멀버 λ³€μˆ˜κ°€ μΆ”κ°€λ˜κ±°λ‚˜ μ‚­μ œλ˜λ©΄ serialVersionUID 값이 λ‹¬λΌμ§€κ²Œ λ˜λŠ”λ°, κΈ°μ‘΄ serialVersionUID κ°€ λ³€κ²½λ˜λ©΄ java.io.InvalidCalssException 이 λ°œμƒν•˜κ²Œλœλ‹€.

private static final long serialVersionUID = 1L;

즉, μœ„μ™€ 같이 직접 관리λ₯Ό ν•΄μ•Ό ν΄λž˜μŠ€κ°€ λ³€κ²½λ˜μ–΄λ„ λ¬Έμ œμ—†μ΄ 직렬화/역직렬화가 κ°€λŠ₯ν•˜λ‹€.

μ΄λ•Œ, serialVersionUIDκ°€ κ°™λ‹€κ³  λ¬Έμ œμ—†μ΄ 직렬화/역직렬화λ₯Ό ν•  수 μžˆλŠ” 것은 μ•„λ‹ˆλ‹€. 클래슀의 멀버 λ³€μˆ˜ νƒ€μž…μ΄ κ°™μ•„μ•Όν•˜λ©°, 멀버 λ³€μˆ˜λ₯Ό μ œκ±°ν•˜κ±°λ‚˜ λ³€μˆ˜λͺ…을 λ°”κΎΈλ©΄ μ˜ˆμ™ΈλŠ” λ°œμƒν•˜μ§€ μ•Šμ§€λ§Œ λ°μ΄ν„°λŠ” λˆ„λ½λœλ‹€.

직렬화 μ‚¬μš©μ‹œ μ£Όμ˜μ‚¬ν•­

  • νŠΉλ³„ν•œ λ¬Έμ œκ°€ μ—†μœΌλ©΄ serialVersionUID 값은 직접 κ΄€λ¦¬ν•œλ‹€.

  • μ™ΈλΆ€(DB, μΊμ‹œμ„œλ²„, NoSQL μ„œλ²„)에 μž₯κΈ°κ°„ μ €μž₯될 μ •λ³΄λŠ” μžλ°” μ§λ ¬ν™”μ‚¬μš©μ„ μ§€μ–‘ν•΄μ•Όν•œλ‹€. 역직렬화 λŒ€μƒ ν΄λž˜μŠ€κ°€ μ–Έμ œ 변경이 일어날지 λͺ¨λ₯΄λŠ” ν™˜κ²½μ—μ„œ κΈ΄ μ‹œκ°„λ™μ•ˆ 외뢀에 μ‘΄μž¬ν–ˆλ˜ μ§λ ¬ν™”λœ λ°μ΄ν„°λŠ” Garbageκ°€ 될 κ°€λŠ₯성이 λ†’λ‹€.

  • 자주 λ³€κ²½λ˜λŠ” 데이터λ₯Ό μžλ°” 직렬화λ₯Ό μ‚¬μš©ν•˜μ§€ 말자

  • κ°œλ°œμžκ°€ 직접 컨트둀 κ°€λŠ₯ν•œ 클래슀의 객체가 μ•„λ‹Œ κ²½μš°μ—λŠ” 직렬화λ₯Ό μ§€μ–‘ν•΄μ•Όν•œλ‹€. κ°œλ°œμžκ°€ 직접 μ»¨νŠΈλ‘€ν•˜κΈ° νž˜λ“  κ°μ²΄λž€ 라이브러리, ν”„λ ˆμž„ μ›Œν¬μ—μ„œ μ œκ³΅ν•˜λŠ” 클래슀 객체λ₯Ό λ§ν•œλ‹€. μ΄λŸ¬ν•œ 객체가 직접 serialVersionUID λ₯Ό κ°–κ³  μžˆκΈ°λ„ν•΄, κ°œλ°œμ‹œ νŽΈμ˜μƒ 직렬화 ν•˜μ—¬ DBλ˜λŠ” μΊμ‹œμ— λ°”λ‘œ μ €μž₯ν•œλ‹€λ©΄ 그둜 인해 λ§Žμ€ λ¬Έμ œκ°€ μ•ΌκΈ°λœλ‹€.

    • ν”„λ ˆμž„μ›Œν¬/라이브러리 버전업을 ν•˜λ©΄μ„œ serialVersionUID λ³€κ²½

즉, 변경에 μ·¨μ•½ν•˜λ―€λ‘œ μžλ°” 직렬화 μ‚¬μš©μ‹œμ—λŠ” 자주 λ³€κ²½λ˜λŠ” 클래슀의 κ°μ²΄λŠ” μ‚¬μš© μ•ˆν•˜λŠ” 것이 μ’‹λ‹€. 역직렬화가 λ˜μ§€ μ•Šμ„ λ•Œ μ˜ˆμ™Έμ²˜λ¦¬λŠ” 기본적으둜 ν•„μš”ν•˜λ‹€.

μš©λŸ‰ 문제

μžλ°” μ§λ ¬ν™”μ‹œ 기본적으둜 νƒ€μž…μ— λŒ€ν•œ 정보 λ“± 클래슀의 메타정보도 κ°€μ§€κ³  μžˆμ–΄ μƒλŒ€μ μœΌλ‘œ λ‹€λ₯Έ 포맷에 λΉ„ν•΄ μš©λŸ‰μ— λŒ€ν•œ λ¬Έμ œκ°€ μžˆλ‹€. 특히 클래슀의 ꡬ쑰가 κ±°λŒ€ν•΄μ§ˆ 수둝 μš©λŸ‰μ°¨μ΄κ°€ λ°œμƒν•˜κ²Œ λœλ‹€.

  • μš°ν•˜ν•œ ν˜•μ œλ“€ κΈ°μˆ λΈ”λ‘œκ·Έ 예제 μ½”λ“œ

             String base64Member = "rO0ABXNyABp3b293YWhhbi5ibG9nLmV4YW0xLk1lbWJlcgAAAAAAAAABAgAESQADYWdlSQAEYWdlMkwABWVtYWlsdAASTGphdmEvbGFuZy9TdHJpbmc7TAAEbmFtZXEAfgABeHAAAAAZAAAAAHQAFmRlbGl2ZXJ5a2ltQGJhZW1pbi5jb210AAnquYDrsLDrr7w=";
        byte[] serializedMember = Base64.getDecoder().decode(base64Member);
        System.out.printf("serializedMember (byte size = %s) \n", serializedMember.length);
        try (ByteArrayInputStream bais = new ByteArrayInputStream(serializedMember)) {
            try (ObjectInputStream ois = new ObjectInputStream(bais)) {
                // μ—­μ§λ ¬ν™”λœ Member 객체λ₯Ό μ½μ–΄μ˜¨λ‹€.
                Object objectMember = ois.readObject();
                Member member = (Member) objectMember;
                // JSON으둜 직렬화 ν–ˆμ„ λ•Œ μš©λŸ‰ 체크
                String memberJson = objectMapper.writeValueAsString(member);
                System.out.println(memberJson);
                System.out.printf("json (byte size = %s)\n", memberJson.getBytes("utf-8").length);
            }
        }
    serializedMember (byte size = 146)         
    {"name":"κΉ€λ°°λ―Ό","email":"deliverykim@baemin.com","age":25}
    json (byte size = 62)

κ°„λ‹¨ν•œ λ°μ΄ν„°μ΄μ§€λ§Œ JSON으둜 직렬화 ν–ˆμ„λ•Œ 보닀 두배 μ΄μƒμ˜ μš©λŸ‰ 크기가 μ°¨μ΄λ‚˜λŠ” 것을 λ³Ό 수 μžˆλ‹€. μ§λ ¬ν™”λœ 데이터λ₯Ό λ©”λͺ¨λ¦¬ μ„œλ²„(Redis, Memcached)에 μ €μž₯ν•˜λŠ” ν˜•νƒœλ₯Ό κ°€μ§„ μ‹œμŠ€ν…œμ—μ„œ λ”μš± λ‘λ“œλŸ¬μ§„λ‹€. λ©”λͺ¨λ¦¬ μ„œλ²„ νŠΉμ„±μƒ λ©”λͺ¨λ¦¬ μš©λŸ‰μ΄ 크지 μ•ŠκΈ° λ•Œλ¬Έμ— ν•΅μ‹¬λ§Œ μš”μ•½ν•΄ μ‚¬μš©ν•˜λŠ” ν˜•νƒœκ°€ νš¨μœ¨μ μ΄λ‹€.

μŠ€ν”„λ§ ν”„λ ˆμž„μ›Œν¬μ—μ„œ 기본적으둜 μ§€μ›ν•˜λŠ” μΊμ‹œ λͺ¨λ“ˆ(Spring Data Redis, Spring Session) 쀑 μ™ΈλΆ€ μ‹œμŠ€ν…œμ— μ €μž₯ν•˜λŠ” ν˜•νƒœμ—μ„œ 기본적으둜 μžλ°” 직렬화 ν˜•νƒœλ‘œ 제곡되기 λ•Œλ¬Έμ— 이뢀뢄은 κΌ­ μ£Όμ˜ν•΄μ•Όν•œλ‹€.

ν˜Έν™˜μ„±

μžλ°” 직렬화λ₯Ό μ΄μš©ν•΄ μ™ΈλΆ€ 데이터λ₯Ό μ €μž₯ν•˜λ©΄, μžλ°”μ—μ„œλ§Œ 읽을 수 μžˆλŠ” 점이 κ°€μž₯ μ•„μ‰¬μš΄ 점이닀. JSON ν˜•νƒœλ‘œ μ €μž₯λ˜μ–΄μžˆλ‹€λ©΄, λ‹€λ₯Έ μ–Έμ–΄μ—μ„œλ„ μ‘°μž‘μ΄ κ°€λŠ₯ν•˜λ‹€.

μ°Έκ³ 

Django restframework serializers
μžλ°” 직렬화, 그것이 μ•Œκ³ μ‹Άλ‹€. ν›‘μ–΄λ³΄κΈ°νŽΈ
μžλ°” 직렬화, 그것이 μ•Œκ³ μ‹Άλ‹€. μ‹€λ¬΄νŽΈ
Integerous DevLog - Java Serialization κ°œλ… 정리
https://woowabros.github.io/img/2017-10-05/java-serial-ex1.jpeg