B、B+树和vue部分知识

提示:文章写完后,目录可以自动生成,如何生成可参考右边的帮助文档

文章目录


前言


一、B、B+树

B和B+树都是多叉搜索树,B树的非叶子节点有key也有值,B+树的非叶子节点只有key没有值,这样他就能放下更多索引值,从而减小树的高度。树的高度是由阶决定的,阶是一个数的分支个数:

索引1 key1 索引2 key2 索引3 key3 索引4 key4 索引n-1 keyn-1 索引n

节点里key的个数等于他的孩子节点数减1,即key=m-1;

每个节点最小孩子数m/2向上取整,最大m个孩子,key等于孩子数减一。

B+树是通过双向链表将叶子节点串起来,这样范围查找就比较方便。

在比较好的情况下,B树可以一次查询就返回(因为非叶子节点有data,可以提前命中),但是B+树要走到底;在比较差的情况下,双方都是走到底,但是B+树因为放了更多的索引,索引范围更大,树相对矮,所以IO更少。

二、vue

vue是尤雨溪用javascript写的前端组件。

vue2是选项式组件,vue3是响应式组件,vue主要是管理doc,比如i++后视图层会立即变化,不用手动写doc.get;vue3是vue在vue2的改动上进行的,因为vue2如果增加了新的property则需要$set,并且vue2也不能感知数组索引的变化。他们的实现原理是javascript的"对象元编程",vue2来自于ES5,vue3来自于ES6,vue2的核心是Object.defineProperty,它会将data里的属性包起来,通过拦截数据的变化动态渲染(控制get和set),vue3的核心是Proxy,他不直接操作对象,而是包裹后拦截所有操作,在vue3中,为了兼容大型项目和TypeScript还改了格式,将相关逻辑写到一起而不是按固定格式分开。

typescript 复制代码
// Vue 3 组合式 (Composition API)
import { ref, computed, onMounted } from 'vue'

export default {
  setup() {
    // 逻辑块 1:计数器
    const count = ref(0)
    const double = computed(() => count.value * 2)
    function increment() { count.value++ }

    // 逻辑块 2:用户状态
    const user = ref(null)
    function fetchUser() { /* ... */ }

    onMounted(() => { console.log('挂载了') })

    // 返回给模板使用
    return { count, double, increment, user }
  }
}
typescript 复制代码
// Vue 2 选项式 (Options API)
export default {
  data() {          // 放数据
    return { count: 0 }
  },
  methods: {        // 放方法
    increment() { this.count++ }
  },
  computed: {       // 放计算属性
    double() { return this.count * 2 }
  },
  mounted() {       // 放生命周期
    console.log('挂载了')
  }
}

总结

以前一直很苦恼于响应式和选项式,并且觉得vue就是html+css+javascript没有自己的语法,现在大概明白了他做了什么事。

相关推荐
书中枫叶1 小时前
我用 Vue3 写了一个 Chrome 步骤录制插件:自动截图、本地存储、一键导出教程
前端·vue.js
叶落阁主1 小时前
Vue3 中如何设计一套好用的 Icon 和 IconPicker 组件
前端·vue.js·icon
kungggyoyoyo2 小时前
从0开发一套geo优化软件:数据模型与API设计
前端·vue.js·后端
hai3152475432 小时前
结构化编程:AI工业化编程的探索
数据结构·自然语言处理·硬件工程·动态规划·集成学习
数据法师2 小时前
Alger Music Player 技术深度解析:基于 Electron + Vue 3 的开源网易云第三方客户端
vue.js·electron·开源
2401_868534783 小时前
2026年5月系统分析
数据结构·python·tornado
协享科技3 小时前
Vue 3 实现抖音式卡片滑动交互:从零到完整方案
前端·vue.js·交互·ai编程·英语·自考英语
_xaboy3 小时前
开源Vue组件FormCreate通过 JSON 生成TinyVue表单
前端·vue.js·低代码·开源·json·表单设计器
袋鼠云数栈4 小时前
数栈 V7.0 多模态数据智能平台:打造 AI-Ready 的企业数据底座
大数据·数据结构·数据库·人工智能·数据治理·多模态