为什么说Rust是对自闭症谱系人士友好的编程语言?
程序员圈子里Rust常常以学习路线陡峭而闻名。就我自己的个人理解来说之所以说它“学习路线陡峭”很大程度上都来源于以下三点Rust有很多语法糖而且官方把这些语法糖给设置成了默认的最佳实现的语法还写进了教程。最经典的就是for循环语句。Rust的for循环公式如下所示for 变量 in 变量{结构体语句;}看着和别的编程语言没啥区别对吧但实际上去掉官方的语法糖for循环语句的完整代码是这样的——for 变量 in 变量.into_iter(){结构体语句;}.into_iter()其实是一个迭代器。在for循环语句这个例子中你可以理解为将C/C里面的手动for循环for(i1;i数字;i)给自动化了。.into_iter()的其他使用场景的例子let nums vec![1, 2, 3]; //创建了“一箱苹果”赋值给nums// 不需要管和是什么想象成“给苹果换个箱子”就行了let sum: i32 nums.into_iter().map(|x| x 1).sum();// 连苹果带箱子都是我的了拿来吧你println!({:?}, nums);// 报错nums 已经被 .into_iter() move移动给 sum 了箱子空了。这个例子就引入了第二个学习路线陡峭的原因——所有权和借用。这大概是Rust初学者和Rust编译器搏斗的头等原因。就比如这个案例如果你是学其他编程语言的恐怕根本无法理解“为什么nums赋值给sum之后nums就不可用了”。其实背后的原因很好理解只是其他编程语言太宠开发者了。想象你有一支这支在所有权上属于你但是你把借给了我那么使用权就在我手里了。别的编程语言是先把复制一份再借给我于是在程序员眼里“先复制一份再借出去”就成了天经地义的事情。可是Rust为了内存安全则把事情的真相赤裸裸地显示了出来。“显式展示”确实也是Rust的设计哲学。在Rust中就连变量的类型和长短都必须展示出来哪怕程序员不写rust-anylazer这个IDE插件也会自动推算出来。没有插件编译器在做边界检查的时候也会做的。在C/C中整型就是整型可是在Rust中整型也分无符号的u8、u16、u32、u64和有符号的i8、i16、i32、i64。第三个原因生命周期。生命周期说白了就是作用域它决定了一个变量能够存活到什么地方。它难就难在它是一个十分抽象的概念它甚至不如代码那样可以显示在屏幕上被人眼看见而且极易和上面的所有权和借用混淆。说实话我到现在都没有完全理解生命周期这个概念。我只记住了两个关于生命周期的知识点带有符号意味着这个变量可以活到程序结束{}内的变量出了这个范围就死。对应的在这个范围内就一直活着。既然Rust的学习路径如此陡峭那为什么Rust依然是对自闭症谱系人士最友好的编程语言呢在此之前我们首先需要知道什么是自闭症自闭症有哪些症状。在这里我找了一个科研领域的AI服务搜索语料全是国内外的论文输出结果保证权威。这是它给我的结果自闭症谱系障碍Autism Spectrum Disorder, ASD是一种起病于早期发育阶段的神经发育障碍其症状主要体现在两大核心维度并常伴有多种共病表现。核心症状一、社交沟通与社会交往障碍这是ASD最具标志性的特征。患者在社会互动中表现出持续性的困难包括缺乏目光接触和非言语交流能力难以理解面部表情、肢体语言等社交线索无法建立与年龄相符的同伴关系对与他人交往缺乏兴趣难以参与互动性活动共同注意力joint attention缺失不会主动分享兴趣或情感体验也难以对他人的呼唤做出回应二、局限、重复的行为、兴趣或活动RRBs这是定义ASD的另一核心维度具体表现为重复刻板行为如反复摇摆身体、拍手或对旋转物体表现出异常迷恋兴趣范围极度狭窄对特定非功能性物品或话题表现出异常执着对环境变化的强烈抵触坚持固定的日常程序和仪式化行为微小的改变可能引发显著的情绪反应常见伴随症状与共病ASD患者还常伴有多种生理与心理层面的困难类别具体表现语言障碍语言发育迟缓或缺失部分患者终身无功能性语言感觉处理异常对声音、触觉、光线等感官刺激过度敏感或反应不足情绪与心理问题焦虑、抑郁、情绪波动剧烈、攻击性或自伤行为睡眠与胃肠问题睡眠节律紊乱、胃肠功能紊乱等躯体症状适应功能受损日常生活适应能力普遍低于同龄人且与神经层面的感觉辨别能力下降有关认知与注意力问题可能合并注意缺陷多动障碍ADHD、执行功能障碍等症状的异质性与个体差异需要特别强调的是ASD是一个谱系概念。每位患者的症状组合、严重程度和功能水平差异极大——从需要大量支持的重度患者到能够独立生活但在社交中仍面临挑战的轻度个体跨度非常广。正因如此现代临床实践强调高度个性化的评估与干预方案。作者注这也就意味着并不是所有的自闭症谱系人士都会包含上述症状。有极度关注细节的自闭症谱系人士也有完全不在乎细节的自闭症谱系人士有感官敏感的自闭症谱系人士也有感官不敏感的自闭症谱系障碍人士。还有如果他自己不说你完全看不出来他是自闭症的患者。此外部分ASD个体尤其是女性可能使用伪装camouflaging策略掩盖其社交困难导致漏诊或晚诊。因此美国儿科学会建议在18个月和24个月龄时进行标准化筛查以实现早期识别和干预。关键相关术语中文别名孤独症英文Autism Spectrum Disorder (ASD)诊断工具ADOS-2自闭症诊断观察量表、ADI-R自闭症诊断访谈修订版神经多样性视角当代倡导将自闭症视为人类神经多样性的自然表现形式关注支持与接纳而非治愈自闭症的核心诊断标准之一是“受限的、重复的行为模式、兴趣或活动”Restricted and Repetitive Behaviors, RRBs其中确实包含对常规、程序和可预测性的强烈偏好。这种偏好并非源于对“规则”本身的病态迷恋而是个体应对一个对其而言高度不可预测、感官过载且社交线索模糊的世界所发展出的一种适应性策略。对于许多自闭症人士来说固定的日程、明确的程序和清晰的规则能够提供一种至关重要的安全感和控制感减少因环境不确定性而引发的焦虑。例如在家庭和学校环境中结构化的日常安排和一致的行为期望能显著降低他们的压力水平并提升其功能表现。这种对可预测性的需求常被外界误解为刻板或固执。然而从神经认知的角度看这反映了自闭症个体信息处理方式的独特性。他们可能更倾向于采用“自下而上”的加工策略即依赖具体的细节而非整体的上下文来理解世界。在这种模式下明确的规则和程序充当了组织复杂信息的脚手架帮助他们构建对环境的理解框架。因此与其说是“痴迷”不如说这是一种认知上的必要支撑。之所以说“Rust对自闭症谱系人士友好”本质上是因为这门编程语言契合了自闭症谱系人士的一些特质。Rust的语法难吗确实难甚至值得研究一个代码当中每一个符号的含义。但是相比于Rust契合自闭症谱系障碍的特质的有点似乎语法复杂又不算什么缺点了。不过需要提前声明的是由于“神经多样性”是一个光谱每个人的大脑都是独一无二的对于自闭症谱系障碍人士来说也是一样。因此这个自闭症患者喜欢Rust的理由不代表另一个自闭症患者就一定认同这个自闭症患者喜欢Rust不代表那个自闭症患者就不会讨厌Rust——毕竟Rust的语法还是一个很高的门槛如果自闭症患者不掌握语法的规律或者心态上没有看开很容易出现情绪崩溃的情况。根据我自己学习Rust的主观体验来说Rust对自闭症谱系人士友好的地方主要体现在以下地方。正好最近由于工作需要同时也在学习Java的springboot正好也拿来对比一下。变量显式声明。上文在“显式展示”时提到过这是Rust为了安全的设计哲学。正好满足了自闭症谱系人士对于“可预测性”的强烈要求。如果没有可预测性的、明确的、固定的规则自闭症患者往往会“情绪过载”。躺在地上大哭大闹都算轻的症状严重的患者还会出现攻击性行为比如砸东西、打人等。编译器的报错信息足够直观。我觉得这没什么好说的。程序如下use std::collections::{HashMap, HashSet};fn main() {// 结构体let mut v1:Vecstr Vec::new();v1.push(我爱rust);println!({:?},v1);println!(the len is :{},v1.len());let mut v2:Vecstr vec![我爱rust,rust是最好的语言];println!({:?},v2);v2.remove(0); //删除println!({:?},v2);// 查找if v1.contains(我爱rust) {println!(找到了);}else {println!(错误没有找到);}// 赋值v1.push(v2[0]);for item in v1{println!({},item);}let mut hashmapHashMap::new();hashmap.insert(张三, 75);hashmap.insert(李四, 85);hashmap.insert(王五, 90);//查找哈希表.get()方法查找哈希表的值match hashmap.get(王五) {Some(value) println!(王五的成绩是{},value),None println!(没有找到王五的成绩),}//迭代哈希表for (k,v) in hashmap.iter() {println!({}的成绩是{},k,v);}//.contains_key()方法检测哈希表中是否存在指定的键if hashmap.contains_key(张三){println!(找到了涨三的成绩);}else {println!(没有找到张三的成绩);}//remove()方法删除哈希表中的键值对let x hashmap.remove(王五);println!(被删除的值{:?},x);println!(删除后的哈希表的值{:?},hashmap);//测试一下let hashmap2HashMap::new(); //报错的地方缺少muthashmap2.insert(备用钥匙, 5);hashmap2.insert(备用钥匙, 10);hashmap2.insert(车钥匙, 5);hashmap2.insert(车钥匙, 10);println!(哈希表2的值{:?},hashmap2);//hashsetlet mut hashsetHashSet::new();hashset.insert(赵六);hashset.insert(钱七);hashset.insert(孙八);println!(哈希集合的个数{:?},hashset.len());match hashset.get(孙八){Some(value) {println!(匹配{},value);}None {println!(没有匹配到孙八);}}for ietm in hashset.iter() {println!(哈希集合的值{},ietm);}if hashset.contains(王五){println!(找到了王五);}else {println!(没有找到王五);}hashset.remove(孙八);}我觉得但凡学过C/C和Java的开发者几乎都会羡慕这种编译器吧。众所周知C的编译器报错的地方往往真正的错误都不在那。不是需要往上找就是需要在周边范围内排查。而Java的springboot则主打“海量信息战术”将真正的报错淹没在一大堆英文报错信息里你需要往上翻鼠标滚轮滚好几下才能通过几个单词里找到真正的报错原因。而Rust人家早就告诉你了“无法将hashmap2作为可变引用借用因为它未被声明为可变mutable”所以你要做的就是像“help”告诉你的那样在第48行处添加一个mut。添加了mut就意味着hashmap2是一个可变变量是的Rust的变量默认是不可变的也就可以执行下面的操作——添加数据了。强制考虑有可能出现的所有预期情况。如果仔细读过上面的程序的读者会注意到这个地方//第31行查找哈希表.get()方法查找哈希表的值match hashmap.get(王五) {Some(value) println!(王五的成绩是{},value),None println!(没有找到王五的成绩),}Some指的是找到数据的情况。如果是别的语言你不写None不设定“如果出现超出预期的行为”编译器也会让你过大不了无动于衷不做任何行为装作看不见就行了。可是Rust不跟你打这个马虎眼你不处理超出预期的情况编译器直接报错给你看。不信你可以试试把这行代码删了你看会出现啥情况。这也就是逼着你想清楚你到底要干什么你想达成什么样的目的你设想的软件架构到底是长啥样的。对于自闭症患者来说最容易情绪崩溃的就是超出预期的不可预测行为。所以这种可预期的设计反而会让他们安心因为这意味着他们可以知道未来会发生什么。“未来会发生什么”这对于神经典型性人士通俗地说就是所谓的“正常人”来说是个折磨可是对于自闭症患者来说可是非常重要的事。毕竟这也是规则和秩序的一部分。cargo包管理器全自动管理依赖环境。你只需要在Cargo.toml文件里写明项目的依赖在编译时期cargo就会自动帮你下载。不吹不黑springboot也有这样的设计文件名叫pom.xml。只是springboot有一个缺点——高版本兼容低版本。Rust在设计之初就没有版本之间的区别所以你拿1.88编写的Rust程序放到我这个安装了最新的1.93的电脑上也能照常编译。可是springboot和其他Java生态可就没这个好事了这个问题我在毕设的时候也遇到过。Java的版本管理可以用纯“畜”来形容。虽然很多语言都有这个问题但我还是要骂。springboot 2 和springboot 3 那简直就是两个截然不同的框架新maven也不能放在旧springboot里运行因为包的地址改变了。
本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/2494030.html
如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!