10.6 Signatures and overloading

博客介绍了方法、实例构造函数、索引器和运算符的签名组成,明确其不包含的部分。阐述了签名是类、结构体和接口中成员重载的机制,还指出 out 和 ref 参数修饰符在签名匹配中的规则,以及因签名相同导致编译错误的情况。
its formal parameters, considered in the order left to right. The signature
of a method
specifically does not include the return type, nor does it include the
params modifier that may be
specified for the right-most parameter.
?The signature of an instance constructor consists of the type and kind
(value, reference, or output) of
each of its formal parameters, considered in the order left to right. The
signature of an instance
constructor specifically does not include the params modifier that may be
specified for the right-most
parameter.
?The signature of an indexer consists of the type of each of its formal
parameters, considered in the order
left to right. The signature of an indexer specifically does not include
the element type, nor does it
include the params modifier that may be specified for the right-most
parameter.
?The signature of an operator consists of the name of the operator and the
type of each of its formal
parameters, considered in the order left to right. The signature of an
operator specifically does not
include the result type.
Signatures are the enabling mechanism for overloading of members in
classes, structs, and interfaces:
?Overloading of methods permits a class, struct, or interface to declare
multiple methods with the same
name, provided their signatures are unique within that class, struct, or
interface.
?Overloading of instance constructors permits a class or struct to declare
multiple instance constructors,
provided their signatures are unique within that class or struct.
?Overloading of indexers permits a class, struct, or interface to declare
multiple indexers, provided their
signatures are unique within that class, struct, or interface.
?Overloading of operators permits a class or struct to declare multiple
operators with the same name,
provided their signatures are unique within that class or struct.
Although out and ref parameter modifiers are considered part of a
signature, members declared in a single
type cannot differ in signature solely by ref and out. A compile-time error
occurs if two members are
Chapter 10 Basic concepts
79
declared in the same type with signatures that would be the same if all
parameters in both methods with out
modifiers were changed to ref modifiers. For other purposes of signature
matching (e.g., hiding or
overriding), ref and out are considered part of the signature and do not
match each other. [Note: This
restriction is to allow C# programs to be easily translated to run on the
Common Language Infrastructure
(CLI), which does not provide a way to define methods that differ solely in
ref and out. end note]
[Example: The following example shows a set of overloaded method
declarations along with their
signatures.
interface ITest
{
void F(); // F()
void F(int x); // F(int)
void F(ref int x); // F(ref int)
void F(out int x); // F(out int) error
void F(int x, int y); // F(int, int)
int F(string s); // F(string)
int F(int x); // F(int) error
void F(string[] a); // F(string[])
void F(params string[] a); // F(string[]) error
}
Note that any ref and out parameter modifiers (?7.5.1) are part of a
signature. Thus, F(int), F(ref
int), and F(out int) are all unique signatures. However, F(ref int) and
F(out int) cannot be
declared within the same interface because their signatures differ solely
by ref and out. Also, note that the
return type and the params modifier are not part of a signature, so it is
not possible to overload solely based
on return type or on the inclusion or exclusion of the params modifier. As
such, the declarations of the
methods F(int) and F(params string[]) identified above, result in a
compile-time error. end example]
### 数字签名在信息技术安全中的应用 数字签名是一种用于验证数据真实性和完整性的重要工具[^1]。通过使用公钥基础设施 (PKI),发送方可以创建唯一的数字指纹来证明文件或消息未被篡改。 #### 实现过程 为了确保真实性,数字签名利用了加密哈希函数和非对称密钥算法: 1. 发送者计算待签署文档的消息摘要; 2. 使用私钥对该摘要进行加密形成签名; 3. 将原始文档连同签名称为已签名的数据包传输给接收端; 接收者可以通过以下方式验证签名的有效性: - 利用发送者的公开密钥解密收到的签名得到原摘要; - 对接收到的内容重新计算其哈希值并与上述恢复出来的摘要对比; - 如果两者一致,则表明该信息确实来自声称的身份并且未曾改动过。 对于代码签名而言,开发者会为其发布的软件附加一个由受信任证书颁发机构(CA)认证过的电子凭证。这不仅能够确认程序出处合法可靠,而且有助于操作系统决定是否允许执行特定应用程序,在一定程度上提高了系统的安全性[^3]。 ```python from cryptography.hazmat.primitives.asymmetric import rsa, padding from cryptography.hazmat.primitives import hashes def create_signature(private_key, message): signature = private_key.sign( message, padding.PSS( mgf=padding.MGF1(hashes.SHA256()), salt_length=padding.PSS.MAX_LENGTH ), hashes.SHA256() ) return signature def verify_signature(public_key, message, signature): try: public_key.verify( signature, message, padding.PSS( mgf=padding.MGF1(hashes.SHA256()), salt_length=padding.PSS.MAX_LENGTH ), hashes.SHA256() ) print("The signature is valid.") except Exception as e: print(f"The signature is invalid: {e}") ```
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值