草庐IT

tonic-Rust

全部标签

linux - 将 Rust 应用程序从 Linux 交叉编译到 Windows

基本上,我在Linux上开发时尝试将最简单的代码编译到Windows。fnmain(){println!("Hello,andbye.")}我通过搜索互联网找到了这些命令:rustc--target=i686-w64-mingw32-gccmain.rsrustc--target=i686_pc_windows_gnu-Clinker=i686-w64-mingw32-gccmain.rs遗憾的是,它们都不起作用。它给了我一个关于stdcrate丢失的错误$rustc--target=i686_pc_windows_gnu-Clinker=i686-w64-mingw32-gccmai

build - 链接大型库时是否可以加快 Rust 编译?

我在嵌入Servo时遇到了很长的连续构建时间作为我的二进制文件的一部分。例如,使用这个tutorialforembeddingServo,在初始构建完成后,对我的代码的任何修改都需要40秒以上才能在第四代四核i7上重建二进制文件:这是Cargo的示例输出:❯cargobuildFinisheddev[unoptimized+debuginfo]target(s)in0.1secs❯touchsrc/main.rs❯cargobuildCompilingservo-embedding-examplev0.1.0Finisheddev[unoptimized+debuginfo]targe

formatting - 如何打印具有所有可用精度的 Rust float ?

我正在为sin三角函数实现CORDIC算法。为了做到这一点,我需要硬编码/计算一堆反正切值。现在我的函数似乎可以工作(由WolframAlpha验证)到打印的精度,但我希望能够打印我的f32。我该怎么做?fngenerate_table(){letpi:f32=3.1415926536897932384626;letk1:f32=0.6072529350088812561694;//1/kletnum_bits:uint=32;letnum_elms:uint=num_bits;letmul:uint=1 最佳答案 使用precis

rust - 为什么编译器声称来自更高级别特征绑定(bind)的关联类型没有实现 `Display` ,即使它应该实现?

我正在构建一个实现字符串连接的库;也就是说,打印由分隔符分隔的容器的所有元素。我的基本设计如下所示:usestd::fmt;#[derive(Debug,Clone,PartialEq,Eq)]pubstructJoin{container:Container,sep:Sep,}implfmt::DisplayforJoinwherefor&'aContainer:IntoIterator,for::Item:fmt::Display,Sep:fmt::Display,{fnfmt(&self,f:&mutfmt::Formatter)->fmt::Result{letmutiter=

【Rust 日报】2023-1-24 toml 发布 v0.6 版本

toml发布v0.6版本toml近日发布了v0.6版本,解决了几个现有问题,并确保其符合TOML1.0合规性测试,而这些改进,都要归功于toml_edit。在此之前,toml_edit已经成为了cargo当中的唯一TOML解析器,而将toml平滑迁移到toml_edit也就顺利成章了。作者还列举了几点此次更新对于toml和toml_edit使用者的影响,详细内容请参考原文: https://epage.github.io/blog/2023/01/toml-vs-toml-edit/使用Rust开发简单数据库-part2这是 使用Rust开发简单数据库 系列的第二节教程,第一节中,作者讲述了如

【Rust 日报】2023-1-24 toml 发布 v0.6 版本

toml发布v0.6版本toml近日发布了v0.6版本,解决了几个现有问题,并确保其符合TOML1.0合规性测试,而这些改进,都要归功于toml_edit。在此之前,toml_edit已经成为了cargo当中的唯一TOML解析器,而将toml平滑迁移到toml_edit也就顺利成章了。作者还列举了几点此次更新对于toml和toml_edit使用者的影响,详细内容请参考原文: https://epage.github.io/blog/2023/01/toml-vs-toml-edit/使用Rust开发简单数据库-part2这是 使用Rust开发简单数据库 系列的第二节教程,第一节中,作者讲述了如

ruby - Rust Vec 到带有 FFI 段错误的 Ruby 数组

我试图返回一个可以从外部rust函数转换为Ruby数组的结构,但是当我尝试调用结构#to_a方法时,我得到了一个段错误。uselibc::size_t;#[repr(C)]pubstructArray{len:libc::size_t,data:*constlibc::c_void,}implArray{fnfrom_vec(mutvec:Vec)->Array{vec.shrink_to_fit();letarray=Array{data:vec.as_ptr()as*constlibc::c_void,len:vec.len()aslibc::size_t};mem::forget

Rust入门(三):内存与指针

Rust内存回收所有程序都必须管理其运行时使用计算机内存的方式。一些语言中具有垃圾回收机制,比如说java;一些语言需要程序员手动分配和释放内存,比如说c;rust采用了第三种方式,使用所有权管理系统来管理内存Rust内存分配rust的栈和堆都是代码在运行时可供使用的内存,它们的结构不同。栈中的所有数据都必须占用已知且固定的大小堆是缺乏组织的,当向堆放入数据时,你要请求一定大小的空间。内存分配器在堆的某处找到一块足够大的空位,把它标记为已使用,并返回一个表示该位置地址的指针,然后将该指针存储在栈,因为这个指针是固定大小的。入栈比在堆上分配内存要快,无需为存储新数据去搜索内存空间;访问堆上的数据

Rust入门(三):内存与指针

Rust内存回收所有程序都必须管理其运行时使用计算机内存的方式。一些语言中具有垃圾回收机制,比如说java;一些语言需要程序员手动分配和释放内存,比如说c;rust采用了第三种方式,使用所有权管理系统来管理内存Rust内存分配rust的栈和堆都是代码在运行时可供使用的内存,它们的结构不同。栈中的所有数据都必须占用已知且固定的大小堆是缺乏组织的,当向堆放入数据时,你要请求一定大小的空间。内存分配器在堆的某处找到一块足够大的空位,把它标记为已使用,并返回一个表示该位置地址的指针,然后将该指针存储在栈,因为这个指针是固定大小的。入栈比在堆上分配内存要快,无需为存储新数据去搜索内存空间;访问堆上的数据

Rust 中类似 Golang 的延迟

在Go中,可以使用defer关键字在当前函数返回时执行一个函数,类似于其他语言中传统的finally关键字。无论整个函数体发生什么,这对于清理状态都很有用。这是Go博客中的一个示例:funcCopyFile(dstName,srcNamestring)(writtenint64,errerror){src,err:=os.Open(srcName)iferr!=nil{return}defersrc.Close()dst,err:=os.Create(dstName)iferr!=nil{return}deferdst.Close()returnio.Copy(dst,src)}如何在