내 새 Git 강의 봐봐! 야! 내 새 Git 강의 봐봐! 야! GitByBit.com에 내 새 Git 강의 올라왔어, 봐봐! 야! Git 좀 시원하게 복습하고 싶지? GitByBit.com에 내 새 강의!
플라이웨이트

루비로 작성된 플라이웨이트

플라이웨이트는 구조 패턴이며 프로그램들이 객체들의 메모리 소비를 낮게 유지하여 방대한 양의 객체들을 지원할 수 있도록 합니다.

이 패턴은 여러 객체 사이의 객체 상태를 공유하여 위를 달성합니다. 다르게 설명하자면 플라이웨이트는 다른 객체들이 공통으로 사용하는 데이터를 캐싱하여 RAM을 절약합니다.

복잡도:

인기도:

사용 사례들: 플라이웨이트 패턴의 유일한 목적은 메모리 섭취를 최소화하는 것입니다. 당신의 프로그램이 RAM 부족으로 문제를 겪지 않는다면 당분간 이 패턴을 무시할 수 있습니다.

식별: 플라이웨이트는 새로운 객체들 대신 캐싱 된 객체들을 반환하는 생성 메서드의 유무로 식별될 수 있습니다.

개념적인 예시

이 예시는 플라이웨이트의 구조를 보여주고 다음 질문에 중점을 둡니다:

  • 패턴은 어떤 클래스들로 구성되어 있나요?
  • 이 클래스들은 어떤 역할을 하나요?
  • 패턴의 요소들은 어떻게 서로 연관되어 있나요?

main.rb: 개념적인 예시

require 'json' # The Flyweight stores a common portion of the state (also called intrinsic # state) that belongs to multiple real business entities. The Flyweight accepts # the rest of the state (extrinsic state, unique for each entity) via its method # parameters. class Flyweight # @param [String] shared_state def initialize(shared_state) @shared_state = shared_state end # @param [String] unique_state def operation(unique_state) s = @shared_state.to_json u = unique_state.to_json print "Flyweight: Displaying shared (#{s}) and unique (#{u}) state." end end # The Flyweight Factory creates and manages the Flyweight objects. It ensures # that flyweights are shared correctly. When the client requests a flyweight, # the factory either returns an existing instance or creates a new one, if it # doesn't exist yet. class FlyweightFactory # @param [Hash] initial_flyweights def initialize(initial_flyweights) @flyweights = {} initial_flyweights.each do |state| @flyweights[get_key(state)] = Flyweight.new(state) end end # Returns a Flyweight's string hash for a given state. def get_key(state) state.sort.join('_') end # Returns an existing Flyweight with a given state or creates a new one. def get_flyweight(shared_state) key = get_key(shared_state) if !@flyweights.key?(key) puts "FlyweightFactory: Can't find a flyweight, creating new one." @flyweights[key] = Flyweight.new(shared_state) else puts 'FlyweightFactory: Reusing existing flyweight.' end @flyweights[key] end def list_flyweights puts "FlyweightFactory: I have #{@flyweights.size} flyweights:" print @flyweights.keys.join("\n") end end # @param [FlyweightFactory] factory # @param [String] plates # @param [String] owner # @param [String] brand # @param [String] model # @param [String] color def add_car_to_police_database(factory, plates, owner, brand, model, color) puts "\n\nClient: Adding a car to database." flyweight = factory.get_flyweight([brand, model, color]) # The client code either stores or calculates extrinsic state and passes it to # the flyweight's methods. flyweight.operation([plates, owner]) end # The client code usually creates a bunch of pre-populated flyweights in the # initialization stage of the application. factory = FlyweightFactory.new([ %w[Chevrolet Camaro2018 pink], ['Mercedes Benz', 'C300', 'black'], ['Mercedes Benz', 'C500', 'red'], %w[BMW M5 red], %w[BMW X6 white] ]) factory.list_flyweights add_car_to_police_database(factory, 'CL234IR', 'James Doe', 'BMW', 'M5', 'red') add_car_to_police_database(factory, 'CL234IR', 'James Doe', 'BMW', 'X1', 'red') puts "\n\n" factory.list_flyweights 

output.txt: 실행 결과

FlyweightFactory: I have 5 flyweights: Camaro2018_Chevrolet_pink C300_Mercedes Benz_black C500_Mercedes Benz_red BMW_M5_red BMW_X6_white Client: Adding a car to database. FlyweightFactory: Reusing existing flyweight. Flyweight: Displaying shared (["BMW","M5","red"]) and unique (["CL234IR","James Doe"]) state. Client: Adding a car to database. FlyweightFactory: Can't find a flyweight, creating new one. Flyweight: Displaying shared (["BMW","X1","red"]) and unique (["CL234IR","James Doe"]) state. FlyweightFactory: I have 6 flyweights: Camaro2018_Chevrolet_pink C300_Mercedes Benz_black C500_Mercedes Benz_red BMW_M5_red BMW_X6_white BMW_X1_red 

다른 언어로 작성된 플라이웨이트

C#으로 작성된 플라이웨이트 C++로 작성된 플라이웨이트 Go로 작성된 플라이웨이트 자바로 작성된 플라이웨이트 PHP로 작성된 플라이웨이트 파이썬으로 작성된 플라이웨이트 러스트로 작성된 플라이웨이트 스위프트로 작성된 플라이웨이트 타입스크립트로 작성된 플라이웨이트