Compare smol-hyper and hyper-futures for impl Read

Compare smol-hyper and hyper-futures for impl Read

(Jin Qing’s Column, Nov., 2024)

Hyper uses tokio’s AsyncRead/Write trait not the futures-0.3 one.
See: https://github.com/hyperium/hyper/issues/2024

There are at least 3 ways to implement hyper Read/Write for futures_io::AsyncRead/Write:

  • smol-hyper: FuturesIo implements hyper I/O traits for futures-io implementors.
    • download: 45K
  • hyper-futures: Compatibility layer for futures to use AsyncRead and AsyncWrite traits with hyper
    • download: 1413
  • tokio_util::compat + hyper_util::rt::tokio:
    • first use tokio_util to implement tokio IO
    • then use TokioIo to implement hyper’s IO traits

Prefer smol-hyper or hyper-futures because they are directly.
The implementation of smol-hyper and hyper-futures are very similar.
Following is the comparison of impl Read.

smol-hyper

Revision: 4d6916333055d25896ddcd52ef6ff33af717e0e2
Author: Dependency Dog <renovate@notgull.net>
Date: 24.10.19 8:15:03
Message:
chore(deps): update rust crate hyper to v1.5.0
impl<T: futures_io::AsyncRead + ?Sized> hyper::rt::Read for FuturesIo<T> {
    #[inline]
    fn poll_read(
        self: Pin<&mut Self>,
        cx: &mut Context<'_>,
        mut buf: ReadBufCursor<'_>,
    ) -> Poll<io::Result<()>> {
        // Fill the read buffer with initialized data.
        let read_slice = unsafe {
            let buffer = buf.as_mut();
            buffer.as_mut_ptr().write_bytes(0, buffer.len());
            slice::from_raw_parts_mut(buffer.as_mut_ptr() as *mut u8, buffer.len())
        };

        // Read bytes from the underlying source.
        let n = match self.get_pin_mut().poll_read(cx, read_slice) {
            Poll::Ready(Ok(n)) => n,
            Poll::Ready(Err(e)) => return Poll::Ready(Err(e)),
            Poll::Pending => return Poll::Pending,
        };

        // Advance the buffer.
        unsafe {
            buf.advance(n);
        }

        Poll::Ready(Ok(()))
    }
}

hyper-futures

Revision: faeab613dc6a30a4439e0e29eedc13cd20693f63
Author: AlexSherb <alex.sherbinin.andr@gmail.com>
Date: 24.1.12 2:08:13
Message:
Removed dbg! calls. Version changed to 0.1.1
impl<T: AsyncRead + AsyncWrite> hyper::rt::Read for AsyncReadWriteCompat<T> {
    fn poll_read(
        self: Pin<&mut Self>,
        cx: &mut Context<'_>,
        mut buf: hyper::rt::ReadBufCursor<'_>,
    ) -> Poll<Result<(), std::io::Error>> {
        let buf_slice: &mut [u8] = unsafe { std::mem::transmute(buf.as_mut()) };
        match self.project().inner.poll_read(cx, buf_slice) {
            Poll::Ready(bytes_read) => {
                let bytes_read = bytes_read?;
                unsafe {
                    buf.advance(bytes_read);
                }
                Poll::Ready(Ok(()))
            }
            Poll::Pending => Poll::Pending,
        }
    }
}
使用雅可比椭圆函数为Reissner平面有限应变梁提供封闭形式解(Matlab代码实现)内容概要:本文介绍了如何使用雅可比椭圆函数为Reissner平面有限应变梁问题提供封闭形式的解析解,并结合Matlab代码实现该求解过程。该方法能够精确描述梁在大变形条件下的非线性力学行为,适用于几何非线性强、传统线性理论失效的工程场景。文中详细阐述了数学建模过程,包括基本假设、控制方程推导以及利用雅可比椭圆函数进行积分求解的技术路线,最后通过Matlab编程验证了解的准确性与有效性。; 适合人群:具备一定固体力学、非线性结构分析基础,熟悉Matlab编程的研究生、博士生及科研人员,尤其适合从事结构力学、航空航天、土木工程等领域中大变形问题研究的专业人士; 使用场景及目标:① 掌握Reissner梁理论在有限应变条件下的数学建模方法;② 学习雅可比椭圆函数在非线性微分方程求解中的实际应用技巧;③ 借助Matlab实现复杂力学问题的符号计算与数值验证,提升理论与仿真结合能力; 阅读建议:建议读者在学习前复习弹性力学与非线性梁理论基础知识,重点关注控制方程的推导逻辑与边界条件的处理方式,同时动手运行并调试所提供的Matlab代码,深入理解椭圆函数库的调用方法与结果可视化流程,以达到理论与实践深度融合的目的。
评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值