- 主题:Rust这语法有点奇葩了:&**
ref/deref traits导致这个有点奇葩的语法
use openssl::bn::BigNum;
let s = -BigNum::from_u32(12345).unwrap();
assert_eq!(&**s.to_dec_str().unwrap(), "-12345");
let little_big = BigNum::from_u32(std::u32::MAX)?;
assert_eq!(*&little_big.num_bytes(), 4);
https://docs.rs/openssl/0.10.12/openssl/bn/struct.BigNum.html#method.to_dec_str
--
FROM 114.245.195.*
封这个openssl库的作者给的例子里的写法。
它的实现里面也是这种写法。
就是把一个大整数格式化为字符串,这个字符串封成OpensslString、OpensslStringRef
foreign_type_and_impl_send_sync! {
type CType = c_char;
fn drop = free;
pub struct OpensslString;
pub struct OpensslStringRef;
}
impl fmt::Display for OpensslString {
fn fmt(&self, f: &mut fmt::Formatter<'_>) -> fmt::Result {
fmt::Display::fmt(&**self, f)
}
}
impl fmt::Debug for OpensslString {
fn fmt(&self, f: &mut fmt::Formatter<'_>) -> fmt::Result {
fmt::Debug::fmt(&**self, f)
}
}
impl Stackable for OpensslString {
type StackType = ffi::stack_st_OPENSSL_STRING;
}
impl AsRef<str> for OpensslString {
fn as_ref(&self) -> &str {
&**self
}
}
impl AsRef<[u8]> for OpensslString {
fn as_ref(&self) -> &[u8] {
self.as_bytes()
}
}
impl Deref for OpensslStringRef {
type Target = str;
fn deref(&self) -> &str {
unsafe {
let slice = CStr::from_ptr(self.as_ptr()).to_bytes();
str::from_utf8_unchecked(slice)
}
}
}
impl AsRef<str> for OpensslStringRef {
fn as_ref(&self) -> &str {
&*self
}
}
impl AsRef<[u8]> for OpensslStringRef {
fn as_ref(&self) -> &[u8] {
self.as_bytes()
}
}
【 在 KEILLY 的大作中提到: 】
: 不能省略?
: 我记得好像有好几个可省略的地方。。
: :
--
FROM 114.245.195.*
pdf里的哪一部分?dot operator?
oreilly的pdf排版和字体很舒服
【 在 KEILLY 的大作中提到: 】
: 关于省略的说法,你自己看一下我附的这个pdf
: [upload=1][/upload]
--
FROM 114.245.195.*
大哥,你这说话打哑谜啊,给个pdf,还不如直接说了
【 在 KEILLY 的大作中提到: 】
: 共3处
: :
: ....................
--
FROM 114.245.195.*
导出一个函数一次搞定这三重?
【 在 beep 的大作中提到: 】
: 这种多重引用、解引用的表达方式,c里面也差不多是这样写的啊
: 不搞& * 运算符那咋搞呢?搞成方法? &**a 改成 a.deref().deref().ref()?感觉更差。。
:
--
FROM 114.245.195.*