1
  1. 如何定义几个多态构造函数和函数,如

    function Add( x, y : Integer ) : Integer;
    begin
        Add := x + y
    end;
    
    function Add( s, t : String ) : String;
    begin
        Add := Concat( s, t )
    end;
    
    begin
        Writeln(Add(1, 2));
        Writeln(Add('Hello, ', 'World!'));
    end.
    

我只能通过案例决定来做到这一点吗

A<-setRefClass(Class = "A"
              ,fields = list(var1="character")
              ,methods = list(setFields=A.setFields
                             ,initialize=function(var1) {
                                if(isClass(var1,"B"))
                                   .self$var1<-as.character(var1$getFields("var1"))                                  
                                else{
                                  .self$var1<-as.character(var1)
                                }
                                .self
                              })
)
  1. 如何将函数式编程与面向对象编程相结合。因此,如果我调用函数 getFields(vecB),其中 vecB 是一个向量或对象列表 B。返回应该是每个对象的值?

     B.getFields<-function(...,values){ 
       vars<-mget(names(.refClassDef@fieldClasses), envir = attr(.self, ".xData"))
       if(missing(values)) 
         return(vars)
       if(length(vars)==1)
         return(vars[[1]])
      return(vars[names(vars) %in% values])
      }
    
         B<-setRefClass(Class = "B"
                   ,fields = list(var1 = "character")
                     )
    
  2. 如何调试例如从 A 类初始化的函数?我试过

    A$trace("initialize")
    a<-A$new("ABC")
    initial<-a$initialize
    trace(initial,browser,where=A)
    

    但它不起作用。

4

2 回答 2

4
  1. 使用 S4 泛型和方法进行多态性

    setGeneric("Add", function(x, y) standardGeneric("Add"))
    setMethod(Add, c("numeric", "numeric"), function(x, y) x + y)
    setMethod(Add, c("character", "character"), function(x, y) paste0(x, y))
    

    所以

    > Add(1, 2)
    [1] 3
    > Add("hello ", "world")
    [1] "hello world"
    > Add("hello ", 2)
    Error in (function (classes, fdef, mtable)  : 
      unable to find an inherited method for function 'Add' for signature '"character", "numeric"'
    

    在参考类中使用这个泛型的一个想法是

    A <- setRefClass("A",
        fields=list(x="ANY"),
        methods=list(
          getX=function() {
              .self$x
          }, setX=function(x) {
              .self$x <- x
              .self
          }, addX=function(y) {
              setX(Add(getX(), y))
          }, show=function() {
              cat("class:", class(.self), "\nx:", getX(), "\n")
          }))
    

    针对功能程序样式进行适当的调度:

    setMethod(Add, c("A", "ANY"), function(x, y) x$addX(y))
    setMethod(Add, c("A", "A"), function(x, y) x$addX(y$getX()))
    

    (也许对于函数式编程,实现$addX()as更有意义A(.self, x=Add(x$getX(), y)),即创建 x 的克隆?)以允许

    > Add(A(x=1), A(x=2))
    class: A 
    x: 3 
    > Add(A(x="hello "), "world")
    class: A 
    x: hello world 
    > A(x=2)$addX(3)
    class: A 
    x: 5 
    

    虽然不是A(x=1)$addX(A(x=2))

  2. 有关返回字段值的一种方法,请参见此答案:

    B = setRefClass("B", fields=c(var1="list", var2="character"),
        methods=list(getFields=function(values) {
            flds = names(getRefClass()$fields())
            if (!missing(values))
                flds = flds[flds %in% values]
            result = setNames(vector("list", length(flds)), flds)
            for (fld in flds)
                result[[fld]] = .self[[fld]]
            result
        }))
    

    以功能方式调用的一种方法需要单独的实现,例如,

    setGeneric("getFields", function(x, ...) standardGeneric("getFields"))
    setMethod(getFields, "B", function(x, ...) x$getFields(...))
    setMethod(getFields, "list", function(x, ...) lapply(x, getFields, ...))
    
  3. 您的 A 类示例不完整。

    A <- setRefClass("A", methods=list(initialize=function(...) {
        message("hello A")
        callSuper(...)
    }))
    

    进而

    > A$trace("initialize", browser)
    Tracing reference method "initialize" for class "A"
    [1] "initialize"
    > A()
    Tracing .Object$initialize(...) on entry 
    Called from: eval(expr, envir, enclos)
    Browse[1]> n
    debug: {
        message("hello A")
        callSuper(...)
    }
    Browse[2]> n
    debug: message("hello A")
    Browse[2]> 
    
于 2013-09-11T23:18:04.390 回答
0

这是之前关于 R 中的多态性的讨论:R中函数多态性的建议做法是什么?

连接字符串的方法是使用粘贴。

paste("Hello, ","world",sep="")
于 2013-09-11T22:05:35.890 回答