随笔记录

C++中的函数调用入参和返回值均会拷贝一份,不管指针还是值,区别的是指针不管怎么拷贝他的值(指向的地址)不变,所以使用指针能够改变原值。

const 值类型和非值类型可以任意赋值,但是const指针类型和非指针类型却不可以,如:

    int it=3;
    const int it_c=it;
    int tt=it_c;

编译通过


    int it=3;
    const int* it_c=⁢
    int *tt=it_c;

编译错误,Error    3    error C2440: 'initializing' : cannot convert from 'const int *' to 'int *'

此时必须通过强制转换来解决:
    int it=3;
    const int* it_c=⁢
    int *tt=(int*)it_c;

引用外部博客:

1. const在函数返回值前:
返回const值,意思指返回的原函数里的变量的初值不能被修改,但是函数
按值返回的这个变量被制成副本,能不能被修改就没有了意义,它可以被赋给任何
的const或非const类型变量,完全不需要加上这个const关键字.但这只对于内部
类型而言(因为内部类型返回的肯定是一个值,而不会返回一个变量,不会作为左
值使用),对于用户自定义类型,返回值是常量是非常重要的,
X Fuction1 () { return X(); }
const X Fuction2 () { return X(); }
如有上面的自定义类X,和函数Fuction1()和Fuction2(),我们进行如下操作时:
Fuction1()=X(1); //没有问题,可以作为左值调用
Fuction2()=X(1); //编译错误,const返回值禁止作为左值调用.因为左值
把返回值作为变量会修改其返回值,const声明禁止这种修改。
返回的类型为const型不能被修改
对于int来说没有什么意义 返回值只能为右值本身就是const

C++标准规定,函数返回值是右值,但是貌似对于用户自定义类型,返回值是可以做左值的,而对于内建类型,如int,只能作为右值。

### Vue 3 和 Vite 实现分包优化性能配置指南 在现代前端开发中,分包是一种有效的技术手段,用于减少初始加载时间并提高 Web 应用程序的整体性能。以下是基于 Vue 3 和 Vite 的分包优化策略。 #### 1. 使用 Rollup 插件实现动态导入 Vite 基于 Rollup 构建,因此可以利用其插件生态来实现按需加载和分包功能。通过 `import()` 动态语法,开发者能够将大文件拆分为多个小模块,在需要时才加载这些模块。这种方式显著减少了首屏渲染的时间[^1]。 ```javascript // 示例代码:组件懒加载 const MyComponent = () => import('./MyComponent.vue'); export default { components: { MyComponent } }; ``` #### 2. 配置 Vite 的 code-splitting 功能 Vite 自动支持 Code Splitting 技术,无需额外安装任何依赖即可启用此特性。只需确保项目中的路由或组件采用了异步引入的方式,则会自动生成对应的 chunk 文件[^4]。 ```javascript // vite.config.js 中开启 rollupOptions 进一步定制打包行为 import { defineConfig } from 'vite'; export default defineConfig({ build: { rollupOptions: { output: { manualChunks(id) { if (id.includes('node_modules')) { return id.toString().split('node_modules/')[1].split('/')[0]; } }, }, }, }, }); ``` #### 3. 结合 Uni-app 路由机制完成页面级分包 如果目标平台涉及多端适配(H5、小程序等),可参考 Uni-app 提供的 pages.json 配置方案来进行更细粒度的控制。例如设置独立入口文件或者指定某些特定路径下的资源作为子包处理[^3]。 ```json { "pages": [ { "path": "index", "style": {} } ], "subPackages": [{ "root": "packageA", // 子包根目录 "pages": [{...}] }] } ``` #### 4. 替换旧版响应式系统带来的优势 相较于 Vue 2 使用 Object.defineProperty 方法监听对象属性的变化,Vue 3 引入 Proxy 对象重构整个观察者模式,不仅解决了深嵌套结构难以追踪的问题,还极大提升了运行效率[^2]。这间接促进了大型应用分割后的流畅体验感。 --- ####
评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值