Fortran Coder

查看: 8642|回复: 8
打印 上一主题 下一主题

[面向对象] 能不能通过绑定的方法重载函数名?

[复制链接]

1967

帖子

12

主题

5

精华

论坛跑堂

臭石头雪球

F 币
1370 元
贡献
581 点

美女勋章热心勋章星光勋章新人勋章贡献勋章管理勋章帅哥勋章爱心勋章规矩勋章元老勋章水王勋章

楼主
发表于 2018-11-7 11:20:59 | 显示全部楼层
洁癖是一种心理疾病。

绑定的方法只能 v = v%abs()
不能是 v= abs(v)

1967

帖子

12

主题

5

精华

论坛跑堂

臭石头雪球

F 币
1370 元
贡献
581 点

美女勋章热心勋章星光勋章新人勋章贡献勋章管理勋章帅哥勋章爱心勋章规矩勋章元老勋章水王勋章

沙发
发表于 2018-11-7 11:30:24 | 显示全部楼层
把 AbsVect_Fn 设置为 private 就好了。
一般,OOP的模块,都默认 private,然后把需要的 public

也可以双绑定,即绑定类的过程,也 overloading intrinsic function

这样
write(*,'(2dt"(3f6.2)")') abs(a) , a%abs()
都可以使用

[Fortran] 纯文本查看 复制代码
Module VectClass
  Implicit None
  private
  TYPE , public :: Vect
    Real(8) ,Private :: x
    Real(8) ,Private :: y
    Real(8) ,Private :: z 
  Contains
    Procedure :: set
    Procedure,pass(ThisVect),Private :: VectMulScal_Fn , ScalMulVect_Fn , VectMulVect_Fn
    Generic, Public :: operator (*) => VectMulScal_Fn , ScalMulVect_Fn , VectMulVect_Fn
    Procedure :: writef
    Generic :: write(formatted) => writef
    Procedure :: abs => AbsVect_Fn
  End TYPE

  public :: abs
  interface abs
    module procedure AbsVect_Fn
  end interface


contains

  function AbsVect_Fn (ThisVect)
    type(Vect) :: AbsVect_Fn
    class(Vect) :: ThisVect
    AbsVect_Fn = Vect( abs(ThisVect%x) , abs(ThisVect%y) , abs(ThisVect%z) )
  end function AbsVect_Fn

1967

帖子

12

主题

5

精华

论坛跑堂

臭石头雪球

F 币
1370 元
贡献
581 点

美女勋章热心勋章星光勋章新人勋章贡献勋章管理勋章帅哥勋章爱心勋章规矩勋章元老勋章水王勋章

板凳
发表于 2018-11-8 08:45:26 | 显示全部楼层
是的,这就是双绑定。(双绑定是我的一个口语,不是正式说法)
1. type bound procedure :派生类型绑定过程(成员变量)
2. overloading intrinsic function:重载内部函数

1967

帖子

12

主题

5

精华

论坛跑堂

臭石头雪球

F 币
1370 元
贡献
581 点

美女勋章热心勋章星光勋章新人勋章贡献勋章管理勋章帅哥勋章爱心勋章规矩勋章元老勋章水王勋章

地板
发表于 2018-11-16 10:48:43 | 显示全部楼层
procedure :: xx
Generic, Public :: operator (*) =>xx

这种必须绑定派生类型。
您需要登录后才可以回帖 登录 | 极速注册

本版积分规则

捐赠本站|Archiver|关于我们 About Us|小黑屋|Fcode ( 京ICP备18005632-2号 )

GMT+8, 2024-5-16 01:44

Powered by Tencent X3.4

© 2013-2024 Tencent

快速回复 返回顶部 返回列表