96SEO 2026-02-19 10:06 0
。

对于Rust语言#xff0c;虽然历史没有C、和python历史悠远#xff0c;但是它的优点可以说是非常的多#xff0c;既继承了C运行速度#xff0c;还拥有了Java…
专栏简介本专栏作为Rust语言的入门级的文章目的是为了分享关于Rust语言的编程技巧和知识。
对于Rust语言虽然历史没有C、和python历史悠远但是它的优点可以说是非常的多既继承了C运行速度还拥有了Java的内存管理就我个人来说还有一个优点就是集成化的编译工具cargo语句风格和C极其相似所以说我本人还是比较喜欢这个语言特此建立这个专栏作为学习的记录分享。
日常分享每天努力一点不为别的只是为了日后能够多一些选择选择舒心的日子选择自己喜欢的人
所有权这个特性时Rust独有的前面第一章我们说了Rust语言集合了Cjava的优点而为了解决C中垃圾无法回收容易造成内存泄漏的特点Rust中提出了所有权这个概念。
所以说认识所有权才是掌握Rust的必不可少的部分。
学习过c和java的人应该知道在这两种语言中c需要开发者自己分配和释放内存这种情况下很多开发者会在使用了内存而不释放导致内存泄漏。
而Java则是解决了这种问题他采用的是垃圾回收机制在程序运行的时候自动的寻找不再使用的内存。
而Rust使用的则是所有权管理简单的来说就是在程序编译时就会进行规格检查提前检测出可能会存在内存泄漏等问题。
其实这个有点和微软公司下的visual
提到栈很多人应该能想到数据结构中的栈栈的特点就是“先进后出”栈的内存是连续的存放数据总是按照顺序方式存入而在栈中存入的数据必须是大小固定的且已经知道的在C中在开辟内存空间的时候一般都是在栈上开辟的所以必须要指明数据类型以此来告诉系统开辟的空间是固定且已知大小的。
我们定义的指针则是在堆区因为我们是不知道具体的内存大小的只能分配一个足够大的内存空间。
。
堆是缺乏组织的当向堆放入数据时你要请求一定大小的空间。
内存分配器memory
allocator在堆的某处找到一块足够大的空位把它标记为已使用并返回一个表示该位置地址的
所以说当我们定义数据的内存大小不会变的时候就在栈区开辟空间如果不确定会不会改变数据的大小则在堆区开辟空间。
所有者owner。
值在任一时刻有且只有一个所有者。
当所有者变量离开作用域这个值将被丢弃。
记住和其他语言一样变量所有者值只在对应的作用域起作用超出作用域则无法使用。
这里我们将String类型提出来单独讲解其实是因为String类型有点独特它是可变的不再是固定的所以说将String类单独提出来讲解而不是归于字面值。
String类型的数据被分配在堆区所以大小可以随时变化。
大家可以去官网查看这里就不过多介绍至于String类型中函数的调用方法会在后面将到。
前面说了String类型是在堆区上分配内存的最开始系统并不知道你需要多大的内存就分配一个很大的内存空间
第一个部分是我们完成在获取字面值的时候就请求分配内存这在任何一门语言中均适用。
第二部分就需要根据不同语言的特性来进行操作了。
比如说Java有垃圾回收机制他会记录并清除不再使用的内存我们不需要太多的关心内存。
然而像CPython这种没有垃圾回收机制的语言需要自己去释放比如说C中的析沟函数会在类创建并使用完毕后自动释放内存这是由于析沟函数自动调用了drop函数。
对于一些变量我们也需要人为的去释放使用drop或者delete函数。
但是在Rust中当变量离开他所在的作用域的时候就会自动释放。
Rust自动调用了特殊的函数drop函数也可以自己手动调用。
如上述例子先定义了一个变量s1然后绑定到数值5上再定义一个变量s2绑定到s1上也就是说两个变量的值都是5.由于他们在定义的时候就已经指明了数值大小所以这两个变量存放在栈区所以是按照顺序存放。
两个变量都有效。
那如果是存放在堆区的又该如何
上述例子运行你会发现报错了显示s1值不存在这是为什么我们先来介绍一下String类型的数据的概念然后在来解释这个问题。
一个指向存放字符串内容内存的指针一个长度和一个容量。
这一组数据存储在栈上。
右侧则是堆上存放内容的内存部分。
也就是说只拷贝了栈上的数据而堆上的数据则没有被拷贝两个变量共同指向堆区数值。
回到上面的问题为什么s1会不存在这是由于如果s1存在那么将有两个变量同时拥有同一个字面值在离开作用域时系统会自动调用drop函数这时就会出现两个变量都会被释放就出现了二次释放double
free的错误。
这是不被允许的。
所以Rust在s2绑定到s1上时就将s1清除。
从而不能再使用。
和其他语言一样Rust也提供了克隆的方法。
可以理解为深拷贝将堆区的数据也拷贝一份。
这里的一个例子两个变量都是在栈上所以他们的数据之间进行的是拷贝两个变量都可以存在。
可以实现copy的数据类型有
将值传递给函数与给变量赋值的时候原理极为相似。
所以向函数传递值可能会移动或者复制。
//x进入函数里但是x是i32的所以是复制进来后面继续有效.println!({},
s3takes_and_gives_back_ownership(s2);
//s1,s2,s3均离开作用域不起作用但s2已被移走不会发生什么。
somethingString::from(something);
something;//返回something并移出给调用的函数
takes_and_gives_back_ownership(a_String:String)-String
上面两个例子都是在说明所有权问题一个值只能有一个所有者所以上面不同的函数不同的数据类型之间使用的是不同的方法有的是移动有的是克隆。
在这一点上一定要注意区分。
(num,s2)string_length(s1);println!({}
string_length(s:String)-(usize,String)
引用reference像一个指针因为它是一个地址我们可以由此访问储存于该地址的属于其他变量的数据。
上面函数中“s”表示的是建立一个引用指向s的数据值但是并不拥有它也就不会有所有权这个东西。
所以在离开作用域后对原本的数据值没什么影响。
s);println!({},s);println!(position
String::from(Successfull!);return
上面的代码就是一个可变引用的实现我们可以看到可变引用就是在引用前加一个mut关键字。
上面我们说过引用只是暂时借用数据并不拥有所有权所以一个变量被创建了可变引用的时候他只能被创建一次否则会报错这是由于当你创建了多个可变引用的时候他们都可以更改原本的数据这个时候系统就不会知道那一个改变在前面那一个在后面。
就会出现混乱。
两个或更多指针同时访问同一数据。
至少有一个指针被用来写入数据。
没有同步数据访问的机制。
除了不能同时拥有多个可变引用还不能同时存在可变与不可变引用。
举个简单的例子你有一个玩具有人来借然后会原样还回但是有人却改变了他的模样你还回去的玩具和他的不一样是不是就会出现矛盾。
sln;println!({},{},{},m1,m2,m3);
在具有指针的语言中很容易通过释放内存时保留指向它的指针而错误地生成一个
pointer所谓悬垂指针是其指向的内存可能已经被分配给其它持有者。
相比之下在
中编译器确保引用永远也不会变成悬垂状态当你拥有一些数据的引用编译器确保数据不会在其引用之前离开作用域。
}这里出现了报错这是由于s在离开作用域后就失去了作用不再有任何的作用所以引用肯定也没作用了。
允许你引用集合中一段连续的元素序列而不用引用整个集合。
slice
worldfirst_world(s);println!({},
}看上面,上面的这段代码表示的是找到空格的所在位置,对于这个函数使用了很多的库函数才求出索引值那么有没有简单方法
这里我们必须提到字符串slice在Python中我们可以直接使用索引值求的字符串中的部分字符串而在Rust中也有这种机制
}和Python一样他的索引方式也有很多比如s[..3],s[..],s[2..]他们分别表示的是从0下标开始到3位置从0开始到尾部结束从2开始到结束。
前面我们说过字符串字面值和String的区别字符串字面值是不可变的这是由于字符串字面值的数据类型就是str。
aSlice_from(mun);println!({},a);
就跟我们想要获取字符串的一部分那样我们也会想要引用数组的一部分。
我们可以这样做
语言提供了跟其他系统编程语言相同的方式来控制你使用的内存但拥有数据所有者在离开作用域后自动清除其数据的功能意味着你无须额外编写和调试相关的控制代码。
所以说只要知道Rust语言的特有机制学起来就会简单很多。
作为专业的SEO优化服务提供商,我们致力于通过科学、系统的搜索引擎优化策略,帮助企业在百度、Google等搜索引擎中获得更高的排名和流量。我们的服务涵盖网站结构优化、内容优化、技术SEO和链接建设等多个维度。
| 服务项目 | 基础套餐 | 标准套餐 | 高级定制 |
|---|---|---|---|
| 关键词优化数量 | 10-20个核心词 | 30-50个核心词+长尾词 | 80-150个全方位覆盖 |
| 内容优化 | 基础页面优化 | 全站内容优化+每月5篇原创 | 个性化内容策略+每月15篇原创 |
| 技术SEO | 基本技术检查 | 全面技术优化+移动适配 | 深度技术重构+性能优化 |
| 外链建设 | 每月5-10条 | 每月20-30条高质量外链 | 每月50+条多渠道外链 |
| 数据报告 | 月度基础报告 | 双周详细报告+分析 | 每周深度报告+策略调整 |
| 效果保障 | 3-6个月见效 | 2-4个月见效 | 1-3个月快速见效 |
我们的SEO优化服务遵循科学严谨的流程,确保每一步都基于数据分析和行业最佳实践:
全面检测网站技术问题、内容质量、竞争对手情况,制定个性化优化方案。
基于用户搜索意图和商业目标,制定全面的关键词矩阵和布局策略。
解决网站技术问题,优化网站结构,提升页面速度和移动端体验。
创作高质量原创内容,优化现有页面,建立内容更新机制。
获取高质量外部链接,建立品牌在线影响力,提升网站权威度。
持续监控排名、流量和转化数据,根据效果调整优化策略。
基于我们服务的客户数据统计,平均优化效果如下:
我们坚信,真正的SEO优化不仅仅是追求排名,而是通过提供优质内容、优化用户体验、建立网站权威,最终实现可持续的业务增长。我们的目标是与客户建立长期合作关系,共同成长。
Demand feedback