Rust与Javascript的使用对比

一、常量

Rust Javascript
let const

二、变量

Rust Javascript
let mut let / var

三、常用打印

Rust Javascript
println!("换行"); console.log('hello');
print!("不换行"); console.info('信息');
- console.error('错误');
- console.warn('警告');

四、定义字符串

Rust Javascript
let a = String::from("xxx"); let a = "xxx";

五、定义类json

Rust

复制代码
fn main() {
    let user: User = User {
        username: String::from("Tom"),
        email: String::from("XXX@qq.com"),
        sign_in_count: 9,
        active: true
    };
    println!("{:?}", user);
    println!("{}", user.username);
    println!("{}", user.email);
    println!("{}", user.sign_in_count);
    println!("{}", user.active);
}

// `#[derive(Debug)]` 是 Rust 中的一个属性(attribute),用于自动生成实现 `Debug` trait 的代码。该属性可以应用于结构体、枚举和联合体等类型。
#[derive(Debug)]
struct User {
    username: String,
    email: String,
    sign_in_count: u64,
    active: bool
}

Javascript

复制代码
const user = {
    username: "Tom",
    email: "XXX@qq.com",
    sign_in_count: 9,
    active: true
}

console.log(user)

六、循环中的break

Rust

复制代码
fn main() {
    let arr: [&str; 5] = ["L", "C", "W", "A", "I"];

    let mut i = 0;

    let lo = loop {
        let w = arr[i];

        if w == "W" {
            break i;
        }
        
        i += 1;
    };

    println!("{}", lo);
}

Javascript

复制代码
const arr = ["L", "C", "W", "A", "I"];

let lo = 0

for (let i=0; i < arr.length; i += 1) {
    let w = arr[i];

    if (w == "W") {
        lo = i
        break
    }
};

console.log(lo)

七、条件语句

Rust 中的条件表达式必须是 bool 类型,否则报错

正确的如下

复制代码
fn main() {
    let a = 10;

    if a > 0 {
        println!("a is more than 0")
    }
}

Javascript中的条件表达式则没那么严格

复制代码
const a = 10

if (a) {
    console.log("a is true")
}

后面待续

相关推荐
竹林81812 分钟前
用wagmi v2构建DeFi前端:从连接钱包到读取合约数据的完整实战与避坑指南
前端·javascript
Kinghiee16 分钟前
从零打造生产级前端错误监控 SDK:架构设计与 Vue3 实践
前端·javascript·vue.js·去重·错误捕获·上报·离线持久化
吴声子夜歌25 分钟前
Vue3——元素样式绑定
前端·javascript·vue.js·es6
xingpanvip27 分钟前
PHP+JS+CSS打造动态星盘计算器
javascript·css·php
chimooing30 分钟前
Hermes与OpenClaw的技术碰撞:从JavaScript引擎优化到企业级数据采集的深度解析
开发语言·javascript·ecmascript
Bacon1 小时前
CDP、Puppeteer 与无头浏览器:它们到底什么关系?
前端·javascript·node.js
kyriewen1 小时前
你的网站被“下毒”了?XSS和CSRF:前端安全的两大“毒瘤”
前端·javascript·安全
Hilaku1 小时前
别再用 JSON.parse 深拷贝了,聊聊 StructuredClone
前端·javascript·vue.js
暗不需求1 小时前
手写 instanceof:从原型链聊聊 JS 的实例判断
前端·javascript
小李子呢02111 小时前
前端八股JS---ES6新增内容
开发语言·javascript·ecmascript