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 一样的可用性

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

也有指针和原始指针

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

相关推荐
小bo波9 小时前
使用Thread子类创建线程 VS 使用Runnable接口创建线程的区别
java·多线程·thread·并发编程·runnable
SamDeepThinking10 小时前
高并发场景下,CompletableFuture与ForkJoinPool该如何取舍?
java·后端·面试
doiito11 小时前
【Agent Harness】Gliding Horse 给 Agent OS 装上双曲空间引擎与默克尔树边云同步
ai·rust·架构设计·系统设计·ai agent
张不才13 小时前
CPU 100% 了怎么办?Java 性能排障的标准化操作
java·后端
shepherd11114 小时前
吞吐量提升 10 倍:高并发大批量数据处理任务的架构演进与性能调优
java·后端·架构
plainGeekDev17 小时前
单例模式 → object 声明
android·java·kotlin
用户2986985301418 小时前
Java 实现 Word 文档文本与图片提取的方法
java·后端
SimonKing18 小时前
铁子,IntelliJ IDEA 2026.1.3来了,升不升?
java·后端·程序员