কেন রুবির ব্যক্তিগত এবং সুরক্ষিত উভয় পদ্ধতি রয়েছে?


141

আমি এই নিবন্ধটি পড়ার আগে , আমি ভেবেছিলাম রুবিতে অ্যাক্সেস নিয়ন্ত্রণ এইভাবে কাজ করেছে:

  • public- যে কোনও অবজেক্ট (যেমন Obj.new.public_method) দ্বারা অ্যাক্সেস করা যায়
  • protected - কেবলমাত্র অবজেক্টের মধ্যে থেকেই, পাশাপাশি যে কোনও সাবক্লাস থেকে অ্যাক্সেস করা যেতে পারে
  • private - সুরক্ষিত হিসাবে একই, তবে পদ্ধতিটি সাবক্লাসে বিদ্যমান নেই

যাইহোক, এটি প্রদর্শিত হয় protectedএবং privateএকই কাজ করে, আপনি privateকোনও স্পষ্টর গ্রহণকারী (যেমন self.protected_methodকাজ করে, তবে self.private_methodতা করেন না) দিয়ে পদ্ধতিগুলি কল করতে পারবেন না তা বাদ দিয়ে ।

এর মূল কথা কি? যখন এমন দৃশ্য আছে যখন আপনি আপনার পদ্ধতিটি সুস্পষ্ট রিসিভারের সাথে কল করতে চান না?


3
সমস্ত দৃষ্টান্তের ক্ষেত্রে যদি অন্য প্রতিটি দৃষ্টান্তের Objectব্যক্তিগত পদ্ধতিগুলিকে কল করার অনুমতি দেওয়া হয় তবে Objectপছন্দ মতো জিনিসগুলি বলা সম্ভব হত 5.puts("hello world")
sepp2k

উত্তর:


161

protected পদ্ধতিগুলি সংজ্ঞায়িত শ্রেণি বা এর উপশ্রেণীর যে কোনও উদাহরণ দ্বারা কল করা যেতে পারে।

privateপদ্ধতিগুলি কেবল কলিং অবজেক্টের মধ্যে থেকেই কল করা যায়। আপনি সরাসরি অন্য উদাহরণের ব্যক্তিগত পদ্ধতি অ্যাক্সেস করতে পারবেন না।

এখানে একটি দ্রুত ব্যবহারিক উদাহরণ:

def compare_to(x)
 self.some_method <=> x.some_method
end

some_methodprivateএখানে থাকতে পারে না । এটি অবশ্যই হ'ল protectedকারণ আপনার সুস্পষ্ট রিসিভারগুলিকে সমর্থন করার প্রয়োজন। আপনার সাধারণ অভ্যন্তরীণ সহায়ক পদ্ধতিগুলি সাধারণত সেগুলি হতে পারে privateকারণ তাদের কখনই এ জাতীয় বলা প্রয়োজন না।

এটি লক্ষ করা জরুরী যে এটি জাভা বা সি ++ কাজ করে তার থেকে আলাদা। privateরুবিতে protectedজাভা / সি ++ এর অনুরূপ যে সাবক্লাসে পদ্ধতিতে অ্যাক্সেস রয়েছে। রুবিতে privateজাভাতে আপনার মতো সাবক্লাস থেকে কোনও পদ্ধতির অ্যাক্সেসকে সীমাবদ্ধ করার কোনও উপায় নেই ।

রুবিতে দৃশ্যমানতা মূলত যাইহোক একটি "সুপারিশ" কারণ যেহেতু আপনি সর্বদা কোনও পদ্ধতিতে অ্যাক্সেস পেতে পারেন send:

irb(main):001:0> class A
irb(main):002:1>   private
irb(main):003:1>   def not_so_private_method
irb(main):004:2>     puts "Hello World"
irb(main):005:2>   end
irb(main):006:1> end
=> nil

irb(main):007:0> foo = A.new
=> #<A:0x31688f>

irb(main):009:0> foo.send :not_so_private_method
Hello World
=> nil

9
আহ, ঠিক আছে যা অনেক বেশি অর্থবোধ করে। আমার ভুল বোঝাবুঝি চিন্তা থেকে এসেছিলেন privateবনাম protectedএকটি উপশ্রেণী একটি পদ্ধতি উত্তরাধিকারী পারে কিনা কি ছিল, কিন্তু এটি আসলে যেখানে পদ্ধতি থেকে বলা যেতে পারে সম্বন্ধে। ধন্যবাদ!
কাইল স্ল্যাটারি

3
সুরক্ষিত না থাকলেও ডকুমেন্টেশন জেনারেট করার সময় আরডিওর দ্বারা ব্যক্তিগত পদ্ধতিগুলি ডিফল্টরূপে উপেক্ষা করা হয়। এগুলি অন্তর্ভুক্ত করতে আপনি সর্বদা - সমস্ত পতাকা ব্যবহার করতে পারেন।
জাজোরেস

তবে আপনি যদি সত্যিই এটি ব্যক্তিগত চান, আপনি কি ওভাররাইড করতে পারবেন না send?
সাইওস

78

পার্থক্য

  • যে কেউ আপনার সর্বজনীন পদ্ধতিতে কল করতে পারেন।
  • আপনি আপনার সুরক্ষিত পদ্ধতিগুলিতে কল করতে পারেন বা আপনার শ্রেণির অন্য সদস্য (বা বংশধর শ্রেণি) বাইরে থেকে আপনার সুরক্ষিত পদ্ধতিগুলিতে কল করতে পারেন। আর কেউ পারে না।
  • কেবলমাত্র আপনি আপনার ব্যক্তিগত পদ্ধতিগুলিতে কল করতে পারেন, কারণ সেগুলি কেবলমাত্র একটি অন্তর্নিহিত রিসিভারের সাথে কল করা যেতে পারে selfএমনকি আপনি কল করতে পারবেন না self.some_private_method; আপনাকে অবশ্যই প্রচ্ছন্ন private_methodসাথে কল করতে হবে self
    • আইজিইএল উল্লেখ করেছেন: "তবে একটি ব্যতিক্রম রয়েছে you আপনার যদি ব্যক্তিগত পদ্ধতি বয়স = থাকে তবে স্থানীয় ভেরিয়েবলগুলি থেকে পৃথক করার জন্য আপনি নিজের সাথে এটি কল করতে পারেন (এবং করতে হবে)"।
    • যেহেতু রুবি 2.7self রিসিভার স্পষ্ট হতে পারে, self.some_private_methodঅনুমোদিত হয়। (রানটাইম মানটি সমান হলেও, অন্য যে কোনও সুস্পষ্ট রিসিভারটি এখনও অনুমোদিত নয় self))

রুবিতে, এই পার্থক্যগুলি কেবলমাত্র একজন প্রোগ্রামার থেকে অন্য প্রোগ্রামের পরামর্শ। অ-সর্বজনীন পদ্ধতিগুলি বলার একটি উপায় "" আমি এটি পরিবর্তন করার অধিকার সংরক্ষণ করি; এটির উপর নির্ভর করি না। " তবে আপনি এখনও এর ধারালো কাঁচি পান sendএবং আপনার পছন্দ মতো কোনও পদ্ধতিতে কল করতে পারেন।

একটি সংক্ষিপ্ত টিউটোরিয়াল

# dwarf.rb
class Dwarf
  include Comparable

  def initialize(name, age, beard_strength)
    @name           = name
    @age            = age
    @beard_strength = beard_strength
  end

  attr_reader :name, :age, :beard_strength
  public    :name
  private   :age
  protected :beard_strength

  # Comparable module will use this comparison method for >, <, ==, etc.
  def <=>(other_dwarf)
    # One dwarf is allowed to call this method on another
    beard_strength <=> other_dwarf.beard_strength
  end

  def greet
    "Lo, I am #{name}, and have mined these #{age} years.\
       My beard is #{beard_strength} strong!"
  end

  def blurt
    # Not allowed to do this: private methods can't have an explicit receiver
    "My age is #{self.age}!"
  end
end

require 'irb'; IRB.start

তারপরে আপনি দৌড়ে ruby dwarf.rbগিয়ে এটি করতে পারেন :

gloin = Dwarf.new('Gloin', 253, 7)
gimli = Dwarf.new('Gimli', 62,  9)

gloin > gimli         # false
gimli > gloin         # true

gimli.name            # 'Gimli'
gimli.age             # NoMethodError: private method `age'
                         called for #<Dwarf:0x007ff552140128>

gimli.beard_strength # NoMethodError: protected method `beard_strength'
                        called for #<Dwarf:0x007ff552140128>

gimli.greet          # "Lo, I am Gimli, and have mined these 62 years.\
                           My beard is 9 strong!"

gimli.blurt          # private method `age' called for #<Dwarf:0x007ff552140128>

8
সুন্দর ব্যাখ্যা! তবে একটি ব্যতিক্রম আছে। আপনার যদি কোনও ব্যক্তিগত পদ্ধতি থাকে age=, আপনি selfএটিকে স্থানীয় ভেরিয়েবলগুলি থেকে পৃথক করার জন্য কল করতে পারেন (এবং করতে হবে) ।
আইজিএল

যদি আপনি একটি সুরক্ষিত পদ্ধতি "অভিবাদন" করেন তবে আপনি একটি gimli.greet করতে পারবেন না কেন? যেহেতু গিমলি বামন শ্রেণীর সদস্য, সুতরাং এই পদ্ধতিটি হয়রানি না করে কল করা উচিত নয়?
জোয়েসি

@JoeyC কারণ যখন আপনি কি gimli.greet, gimliআহ্বানকারী, কিন্তু রিসিভার নয়। কলারটি হ'ল "শীর্ষ-স্তরের সম্পাদন পরিবেশ", এটি আসলে একটি অ্যাড-হক উদাহরণ Object। এটি চেষ্টা করুন:ruby -e 'p self; p self.class'
কেলভিন

52

রুবিতে ব্যক্তিগত পদ্ধতি:

যদি কোনও পদ্ধতি রুবিতে ব্যক্তিগত হয় তবে এটি সুস্পষ্ট গ্রহণকারী (বস্তু) দ্বারা কল করা যায় না। এটি কেবল স্পষ্টভাবে কল করা যেতে পারে। এটিকে ক্লাস দ্বারা বর্ণিত হয়েছে পাশাপাশি এই শ্রেণীর উপশ্রেণী দ্বারাও এটি স্পষ্টভাবে বলা যেতে পারে।

নিম্নলিখিত উদাহরণগুলি এটি আরও ভালভাবে বর্ণনা করবে:

1) বেসরকারী পদ্ধতির শ্রেণিকামের সাথে একটি প্রাণী শ্রেণি

class Animal
  def intro_animal
    class_name
  end
  private
  def class_name
    "I am a #{self.class}"
  end
end

এক্ষেত্রে:

n = Animal.new
n.intro_animal #=>I am a Animal
n.class_name #=>error: private method `class_name' called

2) এম্ফবিয়ান নামক একটি প্রাণীর একটি উপক্লাস:

class Amphibian < Animal
  def intro_amphibian
    class_name
  end 
end 

এক্ষেত্রে:

  n= Amphibian.new
  n.intro_amphibian #=>I am a Amphibian
  n.class_name #=>error: private method `class_name' called

আপনি দেখতে পাচ্ছেন, ব্যক্তিগত পদ্ধতিগুলি কেবল অন্তর্নিহিতভাবে বলা যেতে পারে। এগুলি সুস্পষ্ট গ্রহণকারীদের দ্বারা কল করা যায় না। একই কারণে, সংজ্ঞায়িত শ্রেণীর শ্রেণিবিন্যাসের বাইরে ব্যক্তিগত পদ্ধতিগুলি কল করা যায় না।

রুবির সুরক্ষিত পদ্ধতি:

যদি কোনও পদ্ধতি রুবিতে সুরক্ষিত থাকে, তবে এটিকে সংজ্ঞায়িত শ্রেণি এবং এর উপশ্রেণী উভয়ই স্পষ্টভাবে বলা যেতে পারে be অধিকন্তু এগুলি স্পষ্টভাবে প্রাপ্ত প্রাপক দ্বারা কল করা যেতে পারে যতক্ষণ না গ্রহীতা স্ব স্ব বা স্ব শ্রেণীর একই শ্রেণীর থাকে:

1) সুরক্ষিত পদ্ধতি সুরক্ষার সাথে একটি প্রাণী শ্রেণি_আর

class Animal
  def animal_call
    protect_me
  end
  protected
  def protect_me
    p "protect_me called from #{self.class}"
  end  
end

এক্ষেত্রে:

n= Animal.new
n.animal_call #=> protect_me called from Animal
n.protect_me #=>error: protected method `protect_me' called

2) একটি স্তন্যপায়ী শ্রেণি যা প্রাণী বর্গ থেকে উত্তরাধিকারসূত্রে প্রাপ্ত

class Mammal < Animal
  def mammal_call
    protect_me
  end
end 

এক্ষেত্রে

n= Mammal.new
n.mammal_call #=> protect_me called from Mammal

3) একটি উভচর শ্রেণীর পশুর শ্রেণি থেকে প্রাপ্ত (উভয় স্তন্যপায়ী শ্রেণীর মতো)

class Amphibian < Animal
  def amphi_call
    Mammal.new.protect_me #Receiver same as self
    self.protect_me  #Receiver is self
  end   
end

এক্ষেত্রে

n= Amphibian.new
n.amphi_call #=> protect_me called from Mammal
             #=> protect_me called from Amphibian  

৪) গাছ নামে একটি শ্রেণি

class Tree
  def tree_call
    Mammal.new.protect_me #Receiver is not same as self
  end
end

এক্ষেত্রে:

n= Tree.new
n.tree_call #=>error: protected method `protect_me' called for #<Mammal:0x13410c0>

7

জাভাতে একটি ব্যক্তিগত পদ্ধতি বিবেচনা করুন। একে অবশ্যই একই শ্রেণীর মধ্যে থেকে ডেকে আনা যেতে পারে, তবে এটি একই শ্রেণির অন্য একটি উদাহরণ দ্বারাও ডাকা যেতে পারে:

public class Foo {

   private void myPrivateMethod() {
     //stuff
   }

   private void anotherMethod() {
       myPrivateMethod(); //calls on self, no explicit receiver
       Foo foo = new Foo();
       foo.myPrivateMethod(); //this works
   }
}

সুতরাং - যদি কলারটি আমার একই শ্রেণীর আলাদা উদাহরণ হয় - আমার ব্যক্তিগত পদ্ধতিটি আসলে "বাইরের" থেকে অ্যাক্সেসযোগ্য, তাই কথা বলতে। এটি প্রকৃতপক্ষে এটি সমস্ত ব্যক্তিগত বলে মনে হচ্ছে না।

অন্যদিকে রুবিতে, একটি ব্যক্তিগত পদ্ধতি বলতে বোঝানো হয় কেবলমাত্র বর্তমান উদাহরণের জন্য ব্যক্তিগত। সুস্পষ্ট রিসিভারের বিকল্পটি অপসারণ এটিই।

অন্যদিকে, আমার অবশ্যই উল্লেখ করা উচিত যে রুবি সম্প্রদায়ের মধ্যে এই দৃশ্যমানতা নিয়ন্ত্রণগুলি একেবারেই ব্যবহার না করা মোটামুটি সাধারণ বিষয়, রুবি আপনাকে যেভাবেই তাদের চারপাশে যাওয়ার উপায় দেয় তা প্রদত্ত। জাভা বিশ্বের মত নয়, প্রবণতা হ'ল সমস্ত কিছু অ্যাক্সেসযোগ্য করে তোলা এবং অন্যান্য বিকাশকারীদের উপর বিশ্বাস স্থাপন করা যে জিনিসগুলি আপ না করা।


9
"রুবি সম্প্রদায়ের মধ্যে এই দৃশ্যমানতা নিয়ন্ত্রণগুলি মোটেও ব্যবহার না করা খুব সাধারণ বিষয়" - এটি সত্য হতে পারে তবে আমি বলব আমাদের সেগুলি ব্যবহার করা উচিত। ধ্রুবকগুলির মতো, তারা হাতকড়া নয়, তবে একটি প্রোগ্রামার থেকে অন্য প্রোগ্রামারের কাছে যোগাযোগ: "আমি আপনাকে এটিকে একা ছেড়ে যাওয়ার পরামর্শ দিই।" আপনি আমার সার্বজনীন পদ্ধতির উপর নির্ভর করতে পারেন; আমি সতর্কতা ছাড়াই আমার ব্যক্তিগত পদ্ধতিগুলি পরিবর্তন করতে পারি, কারণ আমি সেগুলি প্রয়োগের বিশদ বিবেচনা করি।
নাথান লং

অন্যদিকে, রুবিতে, একটি ব্যক্তিগত পদ্ধতি বলতে বোঝানো হয় কেবলমাত্র বর্তমান উদাহরণের জন্য ব্যক্তিগত। ”এটা সত্য নয়। আপনি এখনও দুর্ঘটনাক্রমে আপনার প্যারেন্ট ক্লাস থেকে ব্যক্তিগত পদ্ধতিগুলি ওভাররাইট করতে পারেন (এবং কিছু শ্রেণি এমনকি এটির API এর অংশ হিসাবে এটি তালিকাভুক্ত করে)।
ফ্রাঙ্কলিন ইউ

1
@ ফ্র্যাঙ্কলিনইউ যা লিখেছেন তাতে তার কোনও ফল নেই; রুবির গোপনীয়তা হ'ল ক্লাস নয়, বস্তু সম্পর্কে এবং এটি কল করার পদ্ধতিগুলি সম্পর্কে , তাদের সংজ্ঞা না দেওয়ার বিষয়ে। একটি ব্যক্তিগত পদ্ধতি কেবল একই বস্তুর অন্য পদ্ধতি দ্বারা কল করা যেতে পারে; পদ্ধতিটি কোন শ্রেণিতে সংজ্ঞায়িত করা হয়েছিল তার সাথে এর কোনও সম্পর্ক নেই
ফিলিওমোরি

2

রুবিতে সাবক্লাস দ্বারা ব্যক্তিগত পদ্ধতিগুলি কেন অ্যাক্সেস করা যায় তার একটি অংশ হ'ল ক্লাস সহ রুবির উত্তরাধিকার মডিউলের তুলনায় পাতলা চিনোকেটিংয়ের অন্তর্ভুক্ত - রুবিতে, একটি শ্রেণি, প্রকৃতপক্ষে, এক ধরণের মডিউল যা উত্তরাধিকার প্রদান করে, ইত্যাদি etc.

http://ruby-doc.org/core-2.0.0/Class.html

এর অর্থ হ'ল মূলত একটি সাবক্লাসটি প্যারেন্ট ক্লাসকে "অন্তর্ভুক্ত করে" যাতে কার্যকরভাবে ব্যক্তিগত ক্লাসিক সহ পিতামাতার শ্রেণির কার্যগুলিও সাবক্লাসে সংজ্ঞায়িত হয়।

অন্যান্য প্রোগ্রামিং ল্যাঙ্গুয়েজে, কোনও পদ্ধতিকে কল করার ক্ষেত্রে পিতামাত্ত শ্রেণির শ্রেণিবিন্যাসকে মেথডের নাম বুবল করা এবং পদ্ধতির প্রতিক্রিয়াযুক্ত প্রথম পিতাম শ্রেণীর সন্ধান করা জড়িত। বিপরীতে, রুবিতে, যখন প্যারেন্ট ক্লাসের শ্রেণিবদ্ধতা এখনও রয়েছে, প্যারেন্ট ক্লাসের পদ্ধতিগুলি সরাসরি সাবক্লাসের পদ্ধতিগুলির তালিকায় অন্তর্ভুক্ত রয়েছে।


2

রুবির বিপরীতে জাভা অ্যাক্সেস নিয়ন্ত্রণের তুলনা: যদি জাভাতে পদ্ধতিটি ব্যক্তিগত হিসাবে ঘোষণা করা হয় তবে এটি কেবল একই শ্রেণীর মধ্যে থাকা অন্যান্য পদ্ধতি দ্বারা অ্যাক্সেস করা যেতে পারে। যদি কোনও পদ্ধতি সুরক্ষিত হিসাবে ঘোষিত হয় তবে এটি একই প্যাকেজের মধ্যে থাকা অন্য শ্রেণিগুলির পাশাপাশি ক্লাসের সাবক্লাসগুলি দ্বারা পৃথক প্যাকেজটিতে অ্যাক্সেস করতে পারে। কোনও পদ্ধতি সর্বজনীন হলে তা সবার কাছে দৃশ্যমান। জাভাতে, অ্যাক্সেস নিয়ন্ত্রণের দৃশ্যমানতা ধারণা নির্ভর করে যে এই বর্গগুলি উত্তরাধিকার / প্যাকেজ শ্রেণিবদ্ধের মধ্যে কোথায় রয়েছে।

যদিও রুবিতে, উত্তরাধিকারের স্তরক্রম বা প্যাকেজ / মডিউল ফিট হয় না। কোন জিনিসটি কোনও পদ্ধতির গ্রহণকারী তা এগুলিই।

রুবির একটি ব্যক্তিগত পদ্ধতির জন্য, এটি কখনই সুস্পষ্ট রিসিভারের সাথে কল করা যায় না। আমরা অন্তর্ভুক্ত রিসিভারের সাথে ব্যক্তিগত পদ্ধতিতে (কেবল) কল করতে পারি।

এর অর্থ হ'ল আমরা কোনও শ্রেণীর মধ্যেই এটি প্রাইভেট পদ্ধতিতে কল করতে পারি এবং এটি এই শ্রেণীর সমস্ত সাবক্লাস হিসাবে ঘোষণা করা হয়।

class Test1
  def main_method
    method_private
  end

  private
  def method_private
    puts "Inside methodPrivate for #{self.class}"
  end
end

class Test2 < Test1
  def main_method
    method_private
  end
end

Test1.new.main_method
Test2.new.main_method

Inside methodPrivate for Test1
Inside methodPrivate for Test2

class Test3 < Test1
  def main_method
    self.method_private #We were trying to call a private method with an explicit receiver and if called in the same class with self would fail.
  end
end

Test1.new.main_method
This will throw NoMethodError

শ্রেণীর শ্রেণিবিন্যাসের বাইরে থেকে আপনি কখনই ব্যক্তিগত পদ্ধতিতে কল করতে পারবেন না যেখানে এটি সংজ্ঞায়িত হয়েছিল।

সুরক্ষিত পদ্ধতিটিকে প্রাইভেটের মতোই অন্তর্নিহিত রিসিভারের সাথে কল করা যেতে পারে। অতিরিক্ত সুরক্ষিত পদ্ধতিতে প্রেরণকারী যদি "স্ব" বা "একই শ্রেণীর কোনও বস্তু" হয় তবে একটি সুস্পষ্ট প্রাপক (কেবল) দ্বারাও ডেকে আনা যায়।

 class Test1
  def main_method
    method_protected
  end

  protected
  def method_protected
    puts "InSide method_protected for #{self.class}"
  end
end

class Test2 < Test1
  def main_method
    method_protected # called by implicit receiver
  end
end

class Test3 < Test1
  def main_method
    self.method_protected # called by explicit receiver "an object of the same class"
  end
end


InSide method_protected for Test1
InSide method_protected for Test2
InSide method_protected for Test3


class Test4 < Test1
  def main_method
    Test2.new.method_protected # "Test2.new is the same type of object as self"
  end
end

Test4.new.main_method

class Test5
  def main_method
    Test2.new.method_protected
  end
end

Test5.new.main_method
This would fail as object Test5 is not subclass of Test1
Consider Public methods with maximum visibility

সারসংক্ষেপ

সর্বজনীন: পাবলিক পদ্ধতিতে সর্বাধিক দৃশ্যমানতা রয়েছে

সুরক্ষিত: সুরক্ষিত পদ্ধতিটিকে প্রাইভেটের মতোই অন্তর্নিহিত রিসিভারের সাথে কল করা যেতে পারে। অতিরিক্ত সুরক্ষিত পদ্ধতিতে প্রেরণকারী যদি "স্ব" বা "একই শ্রেণীর কোনও বস্তু" হয় তবে একটি সুস্পষ্ট প্রাপক (কেবল) দ্বারাও ডেকে আনা যায়।

ব্যক্তিগত: রুবিতে কোনও ব্যক্তিগত পদ্ধতির জন্য, এটি কখনই সুস্পষ্ট রিসিভারের সাথে কল করা যায় না। আমরা অন্তর্ভুক্ত রিসিভারের সাথে ব্যক্তিগত পদ্ধতিতে (কেবল) কল করতে পারি। এর অর্থ হ'ল আমরা কোনও শ্রেণীর মধ্যেই এটি প্রাইভেট পদ্ধতিতে কল করতে পারি এবং এটি এই শ্রেণীর সমস্ত সাবক্লাস হিসাবে ঘোষণা করা হয়।


0
First Three types of access specifiers and those define thier scope.
1.Public    ->  Access anywhere out side the class.
2.Private   ->  Can not access outside the class. 
3.Protected ->  This Method not access anywhere this method define 
                scope.

But i have a solution for this problem for all method how to access explain in depth. 

class Test
attr_reader :name
def initialize(name)
  @name = name
end

def add_two(number)
  @number = number 
end

def view_address
  address("Anyaddress")
end

private 
def address(add)
   @add = add
end

protected 
def user_name(name)
  # p 'call method'
  @name = name
end
end

class Result < Test
def new_user
  user_name("test355")
end
end
  1. অবজেক্টের তালিকা
  2. p পরীক্ষা = পরীক্ষা.নিউ ("পরীক্ষা")
  3. p test.name
  4. p টেস্ট.এডিডি_টুই (3)
  5. তালিকাবদ্ধ
  6. p পরীক্ষা.ভিউ_ড্রেস
  7. PR = ফলাফল.নিউ ("")
  8. p r.new_user

কোড সম্পাদনা করার ক্ষেত্রে কিছু সমস্যা। আগের এক পোস্টে দ্বিতীয় শ্রেণির শো। এখন আমি কীভাবে সমস্ত পদ্ধতিতে অ্যাক্সেস করব তা ব্যাখ্যা করছি irst প্রথমটি পরীক্ষার শ্রেণি তৈরি করুন object আমরা মূল অবজেক্টের মাধ্যমে ভিউ_ড্রেস পদ্ধতি অ্যাক্সেস তৈরি করি। এবং সুরক্ষিত পদ্ধতিও উত্তরাধিকার তৈরিতে অ্যাক্সেস করে।
হার্ডিক
আমাদের সাইট ব্যবহার করে, আপনি স্বীকার করেছেন যে আপনি আমাদের কুকি নীতি এবং গোপনীয়তা নীতিটি পড়েছেন এবং বুঝতে পেরেছেন ।
Licensed under cc by-sa 3.0 with attribution required.