0

我有一个关于 Ruby 范围的问题。我将粘贴同一脚本的两个版本,它们都可以工作,但一个将变量引入到类上方的类中,另一个在类实例和调用之前将它们引入下面。我更喜欢在课堂上与他们一起写作,因为如果有的话,我似乎更容易跟踪课堂上的内容。我不能这样做有什么原因吗?

脚本 A

require 'ipaddress'

puts "What class network?"
network_class = gets.chomp.to_s.downcase
puts "What is the ip?"
ip = gets.chomp.to_s.downcase
puts "How many subnets?"
subnets = gets.chomp.to_i

class TheSubNetter

  def initialize(network_class, ip, subnets)
    @network_class = network_class
    @ip = ip
    @subnets = subnets
  end

  def ip_class
    if @network_class == "c"
      IPAddress "#{@ip}/24"
    elsif @network_class == "b"
      IPAddress "#{@ip}/16"
    elsif @network_class == "a"
      IPAddress "#{@ip}/8"
    else
      "Error!"
    end
  end

  def subnet(ip)
    subnets = ip.split(@subnets)
  end

  def ranges(subnets)
    bcast = subnets.map do |i|
      i.broadcast
    end
    bcast.map do |i|
      [i.first.to_string, i.last.to_string]  
    end
  end

end

get_subd = TheSubNetter.new(network_class, ip, subnets)
address = get_subd.ip_class
subnets = get_subd.subnet(address)
ranges = get_subd.ranges(subnets)
ranges.each do |i|
  puts i[0] + "  =>  " + i[1]
end

脚本 B

require 'ipaddress'

class TheSubNetter

  def initialize(network_class, ip, subnets)
    @network_class = network_class
    @ip = ip
    @subnets = subnets
  end

  def ip_class
    if @network_class == "c"
      IPAddress "#{@ip}/24"
    elsif @network_class == "b"
      IPAddress "#{@ip}/16"
    elsif @network_class == "a"
      IPAddress "#{@ip}/8"
    else
      "Error!"
    end
  end

  def subnet(ip)
    subnets = ip.split(@subnets)
  end

  def ranges(subnets)
    bcast = subnets.map do |i|
      i.broadcast
    end
    bcast.map do |i|
      [i.first.to_string, i.last.to_string]  
    end
  end

end

puts "What class network?"
network_class = gets.chomp.to_s.downcase
puts "What is the ip?"
ip = gets.chomp.to_s.downcase
puts "How many subnets?"
subnets = gets.chomp.to_i

get_subd = TheSubNetter.new(network_class, ip, subnets)
address = get_subd.ip_class
subnets = get_subd.subnet(address)
ranges = get_subd.ranges(subnets)
ranges.each do |i|
  puts i[0] + "  =>  " + i[1]
end
4

1 回答 1

0

您希望您的代码按概念依赖性排序,我的意思是;“信息从何而来”和“信息如何使用”。

在开发过程中,类内容在概念上依赖于第一块代码——块是信息的来源,类是该信息的使用。然后,第二个块的含义取决于(可能)不断变化的类 - 再次,信息的来源和使用它。因此,在开发过程中将类定义放在块之间是有意义的。

在生产过程中,第二个块含义取决于第一个块,并且类完全独立于任何一个,正在完成:它现在是静态的 - 不变;你知道它在做什么。因此,块需要在一起,并且类需要在“其他地方”:信息的来源,已知的转换,信息的使用。

基本上,一旦课程完成,它就是“库代码”,并且去往“库代码”总是去的地方:看不见。顶部、底部或其他文件。

于 2013-06-10T00:02:21.170 回答