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

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

也有指针和原始指针

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

相关推荐
workflower10 分钟前
易用性和人性化需求
java·python·测试用例·需求分析·big data·软件需求
小灵不想卷43 分钟前
LangChain4 初体验
java·langchain·langchain4j
忍者必须死1 小时前
ConcurrentHashMap源码解析
java
顾北121 小时前
SpringCloud 系列 04:Gateway 断言 / 过滤器 / 限流 一站式落地指南
java·开发语言·数据库
闻哥1 小时前
23种设计模式深度解析:从原理到实战落地
java·jvm·spring boot·设计模式·面试
wuqingshun3141591 小时前
java创建对象的方式
java·开发语言
求知摆渡1 小时前
Spring AI 多模型对话 Demo 实战:OpenAI/Ollama 一套接口、Redis 会话记忆、SSE 流式输出、AOP 日志打点
java·spring
米羊1211 小时前
Struts 2 漏洞(下)
java·后端·struts
HEU_firejef1 小时前
实战篇(一)BitMap实现签到功能
java·redis
java1234_小锋1 小时前
Java高频面试题:讲一下 ZooKeeper 的持久化机制?
java·zookeeper·java-zookeeper