github.com/yinchengtsinghua/golang-Eos-dpos-Ethereum@v0.0.0-20190121132951-92cc4225ed8e/rpc/doc.go (about)

     1  
     2  //此源码被清华学神尹成大魔王专业翻译分析并修改
     3  //尹成QQ77025077
     4  //尹成微信18510341407
     5  //尹成所在QQ群721929980
     6  //尹成邮箱 yinc13@mails.tsinghua.edu.cn
     7  //尹成毕业于清华大学,微软区块链领域全球最有价值专家
     8  //https://mvp.microsoft.com/zh-cn/PublicProfile/4033620
     9  //版权所有2015 Go Ethereum作者
    10  //此文件是Go以太坊库的一部分。
    11  //
    12  //Go-Ethereum库是免费软件:您可以重新分发它和/或修改
    13  //根据GNU发布的较低通用公共许可证的条款
    14  //自由软件基金会,或者许可证的第3版,或者
    15  //(由您选择)任何更高版本。
    16  //
    17  //Go以太坊图书馆的发行目的是希望它会有用,
    18  //但没有任何保证;甚至没有
    19  //适销性或特定用途的适用性。见
    20  //GNU较低的通用公共许可证,了解更多详细信息。
    21  //
    22  //你应该收到一份GNU较低级别的公共许可证副本
    23  //以及Go以太坊图书馆。如果没有,请参见<http://www.gnu.org/licenses/>。
    24  
    25  /*
    26  包RPC提供通过网络访问对象的导出方法的权限
    27  或其他I/O连接。创建服务器实例后,可以注册对象,
    28  使其从外部可见。遵循特定的导出方法
    29  可以远程调用约定。它还支持发布/订阅
    30  模式。
    31  
    32  满足以下条件的方法可用于远程访问:
    33   -必须导出对象
    34   -必须导出方法
    35   -方法返回0、1(响应或错误)或2(响应和错误)值
    36   —方法参数必须导出或内置类型
    37   -方法返回值必须导出或内置类型
    38  
    39  示例方法:
    40   func(s*calcservice)add(a,b int)(int,error)
    41  
    42  当返回的错误不是nil时,将忽略返回的整数,错误为
    43  发送回客户端。否则,返回的整数将发送回客户机。
    44  
    45  接受指针值作为参数支持可选参数。例如。
    46  如果我们想在一个可选的有限域中做加法,我们可以接受一个mod
    47  参数作为指针值。
    48  
    49   func(s*calservice)add(a,b int,mod*int)(int,错误)
    50  
    51  可以使用2个整数和一个空值作为第三个参数调用此rpc方法。
    52  在这种情况下,mod参数将为零。或者可以用3个整数来调用,
    53  在这种情况下,mod将指向给定的第三个参数。因为可选
    54  参数是rpc包还将接受2个整数作为
    55  争论。它将把mod参数作为nil传递给rpc方法。
    56  
    57  服务器提供了接受ServerCodec实例的servedec方法。它将
    58  从编解码器读取请求,处理请求并将响应发送回
    59  使用编解码器的客户端。服务器可以同时执行请求。响应
    60  可以按顺序发送回客户端。
    61  
    62  使用JSON编解码器的示例服务器:
    63   类型计算器服务结构
    64  
    65   func(s*计算器服务)添加(a,b int)int
    66   返回A+B
    67   }
    68  
    69   func(s*calculatorservice)div(a,b int)(int,error)
    70   如果B==0 {
    71    返回0,errors.new(“被零除”)。
    72   }
    73   返回A/B,NIL
    74   }
    75  
    76   计算器:=新建(CalculatorService)
    77   服务器:=newserver()
    78   server.registername(“计算器”,计算器)
    79  
    80   l,:=net.listenunix(“unix”,&net.unixaddr net:“unix”,name:“/tmp/calculator.sock”)
    81   对于{
    82   c,:=l.acceptUnix()。
    83   编解码器:=v2.newjsoncodec(c)
    84   go server.servedec(编解码器)
    85   }
    86  
    87  包还通过使用订阅支持发布订阅模式。
    88  被视为符合通知条件的方法必须满足以下条件:
    89   -必须导出对象
    90   -必须导出方法
    91   -第一个方法参数类型必须是Context.Context
    92   —方法参数必须导出或内置类型
    93   -方法必须返回元组订阅,错误
    94  
    95  示例方法:
    96   func(s*blockchainservice)newblock(ctx context.context)(订阅,错误)
    97    …
    98   }
    99  
   100  订阅在以下情况下被删除:
   101   -用户发送取消订阅请求
   102   -用于创建订阅的连接已关闭。这可以启动
   103     通过客户端和服务器。服务器将在发生写入错误或
   104     缓冲通知队列太大。
   105  **/
   106  
   107  package rpc