Rust unix domain socket

先用起来再说

rust 复制代码
use std::io::prelude::*;
use std::os::unix::net::UnixStream;

fn main() {
    let mut stream: UnixStream;
    let mut buffer = vec![0u8; 4096];
    match UnixStream::connect("/tmp/hello.world.serv") {
        Ok(handle) => {
            stream = handle;
            match stream.write_all("cmd=read".as_bytes()) {
                Ok(_) => {
                    println!("send to unix domain socket successfully");
                    match stream.read(&mut buffer) {
                        Ok(_) => {
                            println!("read uds buffer okay");
                            //This step change utf8 code for recv buffer
                            println!("Content:{:?}", String::from_utf8(buffer));
                        }
                        Err(error) => println!("read uds buffer errors {:?}", error),
                    }
                }
                Err(error) => println!("{:?}", error),
            }
        }
        Err(error) => {
            println!("{:?}", error)
        }
    };
}

编写rust 不是看编译时报错,而是更重要的是关注,lsp 返回的语法错误,只要又错误,大概率是不会编译成功的

rust使用了C的连接器,但是丰富了C 的库,从项目中的小组件开始迭代

除非,linux 驱动有crates 否则不建议使用 unsafe 去调用

rust 复制代码
use std::io::prelude::*;
use std::os::unix::net::UnixStream;

#[allow(unused_mut)]
#[allow(non_snake_case)]
fn main() {
    let mut stream: UnixStream;
    let mut buffer = vec![0u8; 4096];
    let mut cmd = ["cmd=para_list", "cmd=read"];
    let mut cmdVec = cmd.to_vec();

    for it in cmdVec.iter_mut() {
        if *it == "cmd=para_list" {
            *it = "cmd=para_all_list";
        } else if it == &"cmd=read" {
            *it = "cmd=read_all_cache";
        }
    }

    println!("new static str vec: {:?}", cmdVec);
    match UnixStream::connect("/tmp/uds.network.serv") {
        Ok(handle) => {
            stream = handle;
            match stream.write_all("cmd=read".as_bytes()) {
                Ok(_) => {
                    println!("send to unix domain socket successfully");
                    match stream.read(&mut buffer) {
                        Ok(_) => {
                            println!("read uds buffer okay");
                            //This step change utf8 code for recv buffer
                            println!("Content:{:?}", String::from_utf8(buffer));
                        }
                        Err(error) => println!("read uds buffer errors {:?}", error),
                    }
                }
                Err(error) => println!("{:?}", error),
            }
        }
        Err(error) => {
            println!("{:?}", error)
        }
    };
}

和python 一样的可用性

也有引用和解引用,但是用起来就比较麻烦

也有指针和原始指针

不考虑复杂的过程宏和装饰器的作用大差不差

相关推荐
架构师沉默2 小时前
别又牛逼了!AI 写 Java 代码真的行吗?
java·后端·架构
后端AI实验室7 小时前
我把一个生产Bug的排查过程,交给AI处理——20分钟后我关掉了它
java·ai
凉年技术9 小时前
Java 实现企业微信扫码登录
java·企业微信
狂奔小菜鸡10 小时前
Day41 | Java中的锁分类
java·后端·java ee
hooknum10 小时前
学习记录:基于JWT简单实现登录认证功能-demo
java
程序员Terry10 小时前
同事被深拷贝坑了3小时,我教他原型模式的正确打开方式
java·设计模式
NE_STOP10 小时前
MyBatis-缓存与注解式开发
java
AI智动派10 小时前
从 Python 到 Rust:深入解析 LLM Agent 工具调用的内存安全与异步并发重构实践
rust
_朱志鹏11 小时前
Rust练手项目1--minigrep
rust
码路飞11 小时前
不装 OpenClaw,我用 30 行 Python 搞了个 QQ AI 机器人
java