比方說,我有一個R6類Person
:變化的R6類的子類初始化方法
library(R6)
Person <- R6Class("Person",
public = list(name = NA, hair = NA,
initialize = function(name, hair) {
self$name <- name
self$hair <- hair
self$greet()
},
greet = function() {
cat("Hello, my name is ", self$name, ".\n", sep = "")
})
)
如果我想創建一個子類,其initialize
方法應該是一樣的,除了加入多一個變量來self
我將如何做到這一點?
我試過如下:
PersonWithSurname <- R6Class("PersonWithSurname",
inherit = Person,
public = list(surname = NA,
initialize = function(name, surname, hair) {
Person$new(name, hair)
self$surname <- surname
})
)
然而,當我創建PersonWithSurname
類中的字段name
和hair
是NA
的新實例,即Person
類的默認值。
PersonWithSurname$new("John", "Doe", "brown")
Hello, my name is John.
<PersonWithSurname>
Inherits from: <Person>
Public:
clone: function (deep = FALSE)
greet: function()
hair: NA
initialize: function (name, surname, hair)
name: NA
surname: Doe
在Python
我會做到以下幾點:
class Person(object):
def __init__(self, name, hair):
self.name = name
self.hair = hair
self.greet()
def greet(self):
print "Hello, my name is " + self.name
class PersonWithSurname(Person):
def __init__(self, name, surname, hair):
Person.__init__(self, name, hair)
self.surname = surname
其實在Python,你應該使用'超()',而不是父類的名字。這可以防止錯誤。 –