代理模式
需求:
小明让小李替他追小丽(送洋娃娃,送花,送巧克力)
没有代理的代码:
# -*- encoding: utf-8 -*-
#追求者类
class pursuit
attr_accessor :mm
def initialize(mm)
@mm = mm
end
def give_dolls
puts "#{mm.name} 送你洋娃娃"
end
def give_flowers
puts "#{mm.name} 送你鲜花"
end
def give_chocolate
puts "#{mm.name} 送你巧克力"
end
end
#被追求者类
class girl
attr_accessor :name
def initialize(name)
@name = name
end
end
xiao_hong = girl.new('小红')
xiao_ming = pursuit.new(xiao_hong)
xiao_ming.give_dolls
xiao_ming.give_flowers
xiao_ming.give_chocolate
只有代理的代码:
# -*- encoding: utf-8 -*-
#代理类
class proxy
attr_accessor :mm
def initialize(mm)
@mm = mm
end
def give_dolls
puts "#{mm.name} 送你洋娃娃"
end
def give_flowers
puts "#{mm.name} 送你鲜花"
end
def give_chocolate
puts "#{mm.name} 送你巧克力"
end
end
#被追求者类
class girl
attr_accessor :name
def initialize(name)
@name = name
end
end
xiao_hong = girl.new('小红')
xiao_ming = proxy.new(xiao_hong)
xiao_ming.give_dolls
xiao_ming.give_flowers
xiao_ming.give_chocolate
只是把追求者类换成了代理类。
实际的代理模式代码:
# -*- encoding: utf-8 -*-
#公共接口module
module givegift
def give_dolls
end
def give_flowers
end
def give_chocolate
end
end
#追求者类
class pursuit
include givegift
attr_accessor :mm, :name
def initialize(mm)
@mm = mm
end
def give_dolls
puts "#{mm.name} 替#{name}送你洋娃娃"
end
def give_flowers
puts "#{mm.name} 替#{name}送你鲜花"
end
def give_chocolate
puts "#{mm.name} 替#{name}送你巧克力"
end
end
#代理类
class proxy
include givegift
attr_accessor :gg
def initialize(mm)
@gg = pursuit.new(mm)
end
def give_dolls
gg.give_dolls
end
def give_flowers
gg.give_flowers
end
def give_chocolate
gg.give_chocolate
end
end
#被追求者类
class girl
attr_accessor :name
def initialize(name)
@name = name
end
end
xiao_hong = girl.new('小红')
xiao_ming = proxy.new(xiao_hong)
xiao_ming.gg.name = '小明'
xiao_ming.give_dolls
xiao_ming.give_flowers
xiao_ming.give_chocolate
装饰模式
需求:
给人搭配不同的服饰
代码版本一
# -*- encoding: utf-8 -*-
class person
attr_accessor :name
def initialize(name)
@name = name
end
def wear_t_shirts
puts '大t恤'
end
def wear_big_trouser
puts '垮裤'
end
def wear_sneakers
puts '破球鞋'
end
def wear_suit
puts '西装'
end
def wear_tie
puts '领带'
end
def wear_leather_shoes
puts '皮鞋'
end
def show
puts "*****装扮的#{name}\n\n"
end
end
xc=person.new('小菜')
puts "******第一种装扮"
xc.wear_t_shirts
xc.wear_big_trouser
xc.wear_sneakers
xc.show
puts "******第二种装扮"
xc.wear_suit
xc.wear_tie
xc.wear_leather_shoes
xc.show
这样写的话,功能是实现了,问题是如果增加“超人”的装扮,就要修改person类,违反了开放-封闭原则。
代码版本二
# -*- encoding: utf-8 -*-
class person
attr_accessor :name
def initialize(name)
@name = name
enddef show
puts "*****装扮的#{name}\n\n"
end
end
class finery
def show
end
end
class tshirts < finery
def show
puts '大t恤'
end
end
class bigtrouser < finery
def show
puts '垮裤'
end
end
class sneakers < finery
def show
puts '破球鞋'
end
end
class suit < finery
def show
puts '西装'
end
end
class tie < finery
def show
puts '领带'
end
end
class leathershoes < finery
def show
puts '皮鞋'
end
end
xc=person.new('小菜')
ts = tshirts.new
bt = bigtrouser.new
sk = sneakers.new
puts "******第一种装扮"
ts.show
bt.show
sk.show
xc.show
suit = suit.new
tie = tie.new
ls = leathershoes.new
puts "******第二种装扮"
suit.show
tie.show
ls.show
xc.show
这样改了之后,如果增加超人装扮,确实不需要去修改person类。存在的问题是,各种衣服是独立的,并且暴露在外边的,就是一件一件穿的,没有顺序,没有控制。
代码版本三
# -*- encoding: utf-8 -*-
class person
attr_accessor :name
def initialize(name=nil)
@name = name
end
def show
puts "*****装扮的#{name}\n\n"
end
end
class finery < person
attr_accessor :componet
def decorate(componet)
@componet = componet
end
def show
componet.show if componet
end
end
class tshirts < finery
def show
super
puts '大t恤'
end
end
class bigtrouser < finery
def show
super
puts '垮裤'
end
end
class sneakers < finery
def show
super
puts '破球鞋'
end
end
class suit < finery
def show
super
puts '西装'
end
end
class tie < finery
def show
super
puts '领带'
end
end
class leathershoes < finery
def show
super
puts '皮鞋'
end
end
xc=person.new('小菜')
ts = tshirts.new
bt = bigtrouser.new
sk = sneakers.new
puts "******第一种装扮"
ts.decorate xc
bt.decorate ts
sk.decorate bt
sk.show
suit = suit.new
tie = tie.new
ls = leathershoes.new
puts "******第二种装扮"
suit.decorate xc
tie.decorate suit
ls.decorate bt
ls.show
发表评论