基于微信小程序的医院预约挂号系统的设计与实现

news2025/2/9 5:53:40

在这里插入图片描述

hello hello~ ,这里是 code袁~💖💖 ,欢迎大家点赞🥳🥳关注💥💥收藏🌹🌹🌹

🦁作者简介:一名喜欢分享和记录学习的在校大学生
💥个人主页:code袁的博客
💥 个人QQ:2647996100
🐯 个人wechat:code8896
code袁系列专栏导航
1.《毕业设计与课程设计》本专栏分享一些毕业设计的源码以及项目成果。🥰🥰🥰
2.《微信小程序开发》本专栏从基础到入门的一系开发流程,并且分享了自己在开发中遇到的一系列问题。🤹🤹🤹
3.《vue开发系列全程线路》本专栏分享自己的vue的学习历程。

非常期待和您一起在这个小小的互联网世界里共同探索、学习和成长。💝💝💝 ✨✨ 欢迎订阅本专栏 ✨✨ 

在这里插入图片描述

文章目录

        • 1.前言介绍
        • 2.功能设计
        • 3、功能实现
        • 4、开发技术简介
        • 5、系统物理架构
        • 6、库表设计
        • 7、关键代码
        • 优质作品集
        • 8、源码获取

基于微信小程序的医院预约挂号小程序

1.前言介绍

在这个争分夺秒的时代,健康需求与便捷就医的渴望从未如此强烈,挂号预约小程序应需而生,承载着革新就医体验的使命。
过往,就医挂号常常令人头疼不已。上班族忙碌于工作,请假排队挂号难上加难,宝贵的时间在等待中悄然流逝;老年人身体不便,还要在医院的长龙中艰难站立,疲惫不堪。挂号预约小程序的出现,彻底改变了这一困境。
它仿若一条无形却高效的纽带,紧密连接起患者与医疗机构。轻点手机屏幕,海量医疗资源尽在掌握。各大医院的科室介绍细致入微,让患者能依据自身病症精准定位所需;医生排班一目了然,专家号不再遥不可及,可按需预约心仪时段。不仅节省了现场排队的时间,还避免了盲目就医,使诊疗过程更具针对性。
同时,小程序背后依托强大的技术支撑,实时整合更新号源信息,确保数据精准无误。从挂号到就诊提醒,全程贴心服务,无缝对接每一个就医环节。它致力于优化就医流程,让医疗服务触手可及,真正为每一位使用者开启轻松、高效、有序的就医新篇章,成为守护健康之路的得力助手。

2.功能设计

挂号预约小程序功能设计聚焦用户就医痛点,旨在打造一站式便捷就医平台。
用户注册登录后,进入简洁直观的主界面。顶部搜索栏支持模糊搜索,输入常见病症,如 “胃痛”“发热”,即刻弹出关联科室与推荐医生,精准匹配就医需求。下方分类导航栏清晰划分 “综合医院”“专科医院”“社区诊所” 等板块,方便用户按需求筛选。每家医院详情页展示科室分布、设备设施、交通路线,还设有患者口碑评分,助力用户全方位了解。
挂号板块独具匠心,日历视图直观呈现医生一周出诊安排,绿色标识空闲时段,点击即可选择。支持分时段精确预约,精细到 15 分钟间隔,满足不同用户时间规划。预约时,系统自动关联医保信息,实现线上医保结算,减轻费用负担。
个人中心功能完备,“我的预约” 实时跟踪挂号状态,临近就诊推送提醒,可一键查看详细就诊信息,包括诊室位置、医生介绍。“病历管理” 允许用户上传过往病历,方便医生快速查阅病史,做出精准诊断。此外,设有 “健康资讯” 专栏,定期推送疾病预防、康复护理知识,提升用户健康素养。互动社区供患者交流就医心得,为小程序持续优化提供反馈,各功能协同发力,让就医轻松无忧。

在这里插入图片描述

3、功能实现

系统登录功能是程序必不可少的功能,在登录页面必填的数据有两项,一项就是账号,另一项数据就是密码,当管理员正确填写并提交这二者数据之后,管理员就可以进入系统后台功能操作区。下图就是管理员登录页面。

在这里插入图片描述
在这里插入图片描述
目管理页面提供的功能操作有:科室管理,职位管理,医生管理,用户管理等
在这里插入图片描述
在这里插入图片描述
下面是医生管理端

在这里插入图片描述
在这里插入图片描述
小程端部分页面展示
在这里插入图片描述

在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述

在这里插入图片描述
在这里插入图片描述

在这里插入图片描述

4、开发技术简介

本节介绍场馆预约平台用到的一些技术和开发环境的简介,用到开发技术主要包括:
(1)前端用到Element UI组件库和Vue框架
(2)后端用到Node
(3)包管理器Npm
(4)中间件Express
(5)数据库MySQL
系统开发环境主要是:前端开发工具Vscode,Hbuilder、操作系统Win10、CPU i5-9300H、内存8G。

5、系统物理架构

自习室系统的物理架构主要有:管理端和用户端,其中管理端主要是基于Vue和Element UI,用户端主要基于安卓、微信小程序和H5自习室系统的物理建构图

在这里插入图片描述

6、库表设计

在这里插入图片描述

7、关键代码
// pages/pay/payList.js
const {getUserReservation,updateRservation} =require('../../api/user')
Page({

  /**
   * 页面的初始数据
   */
  data: {
   list:[],
   stars: [0, 1, 2, 3, 4],
   normalSrc: '../../image/index/ZS1.png',//未选中状态
   selectedSrc: '../../image/index/ZS.png',//选中状态
   key: 0,//评分
   qrImg:[]
  },

  /**
   * 生命周期函数--监听页面加载
   */
  onLoad(options) {
      this.getList()
  },
  getList(){
    getUserReservation({phone:wx.getStorageSync('userInfo').phone}).then(res=>{
        this.setData({
            list:res.data
        })
    })
  },
  godetail(e){
      let value=e.currentTarget.dataset.value
      wx.navigateTo({
        url: './registrationDetail?value='+JSON.stringify(value),
      })
  },
  gocomment(){
     wx.showModal({
       title: '评价',
       editable:true,
       placeholderText:'请输入评价',
       complete: (res) => {
         if (res.confirm) {
           let data={

           }
         }
       }
     }) 
  },
  selectServer: function (e) {
    console.log(e)
    var key = e.currentTarget.dataset.key
    if (this.data.key == 1 && e.currentTarget.dataset.key == 1) {//当有一颗星的时候再次点击取消选中
        key = 0;
    }
    console.log("得" + key + "分")
    this.setData({
        key: key
    })
},

// pages/userInfo/userInfo.js
const {updataUser} =require('../../api/user')
Page({

  /**
   * 页面的初始数据
   */
  data: {
    username:"",
    imgUrl:"",
    password:"",
    userInfo:{},
  },

  /**
   * 生命周期函数--监听页面加载
   */
  onLoad(options) {
    this.setData({
        userInfo:wx.getStorageSync('userInfo'),
        username:wx.getStorageSync('userInfo').username,
        password:wx.getStorageSync('userInfo').password,
        imgUrl:wx.getStorageSync('userInfo').imgUrl
    })
  },
  username(e){
      this.setData({
        username:e.detail.value
      })
  },
  /**
   * 生命周期函数--监听页面初次渲染完成
   */
  onReady() {

  },

  /**
   * 生命周期函数--监听页面显示
   */
  onShow(){
    this.setData({
      userInfo:wx.getStorageSync('userInfo'),
      status:wx.getStorageSync('status'),
    })
  },
  updataPassword(){
      wx.showModal({
        title: '修改密码',
        editable:true,
        placeholderText:"输入新密码",
        complete: (res) => {
          if (res.confirm) {
              if(res.content){
                this.setData({
                    password:res.content
                })
              }else{
                  wx.showToast({
                    title: '密码不能为空哦',
                    icon:'none'
                  })
              }
          }
        }
      })
  },
  changImg(res){
    let that=this
    wx.chooseImage({
      count: 1,
      sizeType: ['original', 'compressed'],
      sourceType: ['album', 'camera'],
      success (res) {
        var imgsFile = res.tempFilePaths[0];
        that.setData({
            imgUrl:imgsFile
        })
        wx.uploadFile({
          filePath: imgsFile,
          name: 'file',
          url: 'http://localhost:3000/upload/upload',
          success: res => {
           that.data.userInfo.imgUrl=JSON.parse(res.data).url
          }
        })
      }
      
    })
  },
  gosubmit(){
      let data={
          id:this.data.userInfo.id,
          username:this.data.username,
          password:this.data.password,
          imgUrl:this.data.userInfo.imgUrl
      }
      updataUser(data).then(res=>{
       if(res.code==200){
        let userInfo=wx.getStorageSync('userInfo')
        userInfo.username=this.data.username
        userInfo.password=this.data.password
        userInfo.imgUrl=this.data.userInfo.imgUrl
        wx.setStorageSync('userInfo', userInfo)
        wx.showToast({
            title: res.msg,
            icon:'none'
          })
       }
    })
  },
<template>
  <div class="messge">
    <el-dialog title="提示" :visible.sync="dialogVisible" width="40%">
      <!-- 弹窗信息 -->
      <el-form
        ref="form"
        :model="form"
        :rules="rules"
        :inline="true"
        :before-close="handleClose"
        label-width="80px"
      >
        <el-form-item label="名称" prop="username">
          <el-input v-model="form.username" placeholder="医生名称"></el-input>
        </el-form-item>
        <el-form-item label="擅长领域" prop="skill">
          <el-input v-model="form.skill" placeholder="擅长领域"></el-input>
        </el-form-item>
        <el-form-item label="挂号费" prop="price">
          <el-input v-model="form.price" placeholder="挂号费"></el-input>
        </el-form-item>
        <el-form-item label="简介" prop="desc">
          <el-input v-model="form.desc" placeholder="医生简介"></el-input>
        </el-form-item>
        <el-form-item label="所属科室" prop="id">
          <el-select v-model="form.office_id" placeholder="请选择">
            <span></span>
            <el-option
              v-for="item in options"
              :key="item.id"
              :label="item.name"
              :value="item.id"
            >
            </el-option>
          </el-select>
        </el-form-item>
        <el-form-item label="所属职称" prop="id">
          <el-select v-model="form.work_id" placeholder="请选择">
            <span></span>
            <el-option
              v-for="item in optionswork"
              :key="item.id"
              :label="item.name"
              :value="item.id"
            >
            </el-option>
          </el-select>
        </el-form-item>

        <el-form-item label="医生肖像">
          <commonUpload :initial-image-url="form.imgUrl"></commonUpload>
        </el-form-item>
      </el-form>
      <!-- 表单提交 -->
      <span slot="footer" class="dialog-footer">
        <el-button @click="cancle">取 消</el-button>
        <el-button type="primary" @click="submit">确 定</el-button>
      </span>
    </el-dialog>

    <div class="manage-hander">
      <!-- 添加按钮 -->
      <el-button type="primary" @click="handleAdd">+ 新增</el-button>
    </div>
    <!-- 表格 -->
    <div class="common-table">
      <el-table
        :data="tableData"
        stripe
        height="90%"
        border
        style="width: 100%"
      >
        <el-table-column prop="username" label="医生名称" align="center">
        </el-table-column>
        <el-table-column prop="imgUrl" label="肖像" align="center">
          <template slot-scope="scope">
            <el-image
              style="width: 150px; height: 100px"
              :src="scope.row.imgUrl"
              :preview-src-list="[scope.row.imgUrl]"
            >
            </el-image>
          </template>
        </el-table-column>
        <el-table-column prop="skill" label="擅长领域" align="center">
          <template slot-scope="scope">
            <span class="content">{{ scope.row.skill }}</span>
          </template>
        </el-table-column>
        <el-table-column prop="price" label="挂号费" align="center">
        </el-table-column>
        <el-table-column label="所属科室" prop="office_id">
          <template slot-scope="scope">
            <span v-for="item in options" :key="item.id">
              <span v-if="scope.row.office_id === item.id">
                {{ item.name }}
              </span>
            </span>
          </template>
        </el-table-column>
        <el-table-column label="所属职称" prop="office_id">
          <template slot-scope="scope">
            <span v-for="item in optionswork" :key="item.id">
              <span v-if="scope.row.work_id === item.id">
                {{ item.name }}
              </span>
            </span>
          </template>
        </el-table-column>
        <el-table-column label="评级" align="center">
          <template slot-scope="scope">
            <el-rate
              v-model="scope.row.garden"
              disabled
              show-score
              text-color="#ff9900"
            >
            </el-rate>
          </template>
        </el-table-column>
        <el-form-item label="简介" prop="desc" align="center">
          <el-input v-model="form.desc" placeholder="医生简介"></el-input>
        </el-form-item>
        <el-table-column prop="addr" label="操作" align="center">
          <template slot-scope="scope">
            <el-button
              type="primary "
              size="mini"
              @click="handleEdit(scope.row)"
              >编辑</el-button
            >
            <el-button
              type="danger"
              size="mini"
              @click="handleDelete(scope.row)"
              >删除</el-button
            >
          </template>
        </el-table-column>
      </el-table>
      <!-- 分页组件 -->
      <el-pagination
        class="page"
        layout="prev, pager, next"
        :total="total"
        @current-change="handlePage"
      >
      </el-pagination>
    </div>
  </div>
</template>

<script>
import commonUpload from "@/components/commonUpload.vue";
import {
  getOffice,
  getDoctor,
  addDoctor,
  detelDoctor,
  updateDoctor,
  getWork,
} from "@/api/index";
// import { allAdmin } from "@/api/reservation";
export default {
  name: "User",
  data() {
    return {
      dialogVisible: false,
      // 表单字段
      form: {
        username: "",
        skill: "",
        imgUrl: "",
        desc: "",
        garden: "",
        price: "",
        office_id: "",
      },
      value: "3",
      // 表單校驗
      rules: {
        username: [{ required: true, message: "请输入医生名称" }],
        openTime: [{ required: true, message: "请输入实验室开发时间" }],
        address: [{ required: true, message: "请输入实验室地址" }],
        desc: [{ required: true, message: "请输入实验室简介" }],
      },
      options: [
        {
          id: "",
          name: "",
        },
      ],
      optionswork: [
        {
          id: "",
          name: "",
        },
      ],
      // 表单数据
      tableData: [],
      total: 0, //页面的总条数
      modelType: 0, //0表示是新增的弹窗 ,1表示的是编辑
      userFrom: {
        username: "",
      },
    };
  },
  components: {
    commonUpload,
  },
  methods: {
    // 提交
    submit() {
      if (this.modelType == 0) {
        this.$refs.form.validate((value) => {
          // 校验为真
          if (value) {
            this.form.imgUrl = this.$store.state.upload.imgUrl;
            addDoctor(this.form).then((res) => {
              // console.log(res);
              this.$message.success("添加成功");
            });
            this.$refs.form.resetFields();
            this.dialogVisible = false;
            this.getList();
          }
        });
      } else {
        this.$refs.form.validate((value) => {
          // 校验为真
          if (value) {
            updateDoctor(this.form).then((res) => {
              this.$message.success("修改成功");
            });
            this.$refs.form.resetFields();
            this.dialogVisible = false;
            this.getList();
          }
        });
      }
    },
    handle(e) {
      console.log();
      // let id = res.id;
      this.$confirm("要修改用户权限吗?", "提示", {
        confirmButtonText: "确定",
        cancelButtonText: "取消",
        type: "warning",
      }).then((res) => {
        privalUser(e).then((res1) => {
          console.log(res1.data.data);
          this.$message.success(res1.data.data.msg);
        });
      });
    },
    // 关闭弹窗
    handleClose() {
      this.$refs.form.resetFields();
      this.dialogVisible = false;
    },
    // 点击取消按钮
    cancle() {
      this.handleClose();
    },
    // 表单的编辑
    handleEdit(res) {
      this.modelType = 1;
      this.dialogVisible = true;
      // 注意到对当前的数据进行深度拷贝
      this.form = JSON.parse(JSON.stringify(res));
    },
    //表单的删除
    handleDelete(res) {
      // let id = res.id;
      this.$confirm("此操作将永久删除该文件, 是否继续?", "提示", {
        confirmButtonText: "确定",
        cancelButtonText: "取消",
        type: "warning",
      })
        .then(() => {
          // 调用删除接口
          var that = this;
          detelDoctor(res).then((res) => {
            that.$message({
              type: "success",
              message: res.data.data.msg,
            });
          });
          this.getList();
        })
        .catch(() => {
          this.$message({
            type: "info",
            message: "已取消删除",
          });
        });
    },
    // 新增数
    handleAdd() {
      (this.modelType = 0), (this.dialogVisible = true);
      this.form = {};
    },
    getOpstions() {
      getOffice().then((res) => {
        this.options = res.data.data;
      });
      getWork().then((res) => {
        this.optionswork = res.data.data;
      });
    },
    // 查询数据
    handleSearch() {
      searchUser(this.userFrom).then((res) => {
        console.log(res.data.data);
        this.tableData = res.data.data.data;
        // this.getList();
      });
    },
    //分页
    handlePage(val) {
      console.log(val);
    },
    // 获取数据
    getList() {
      // 采用封装的api接口方法
      getDoctor().then((res) => {
        this.tableData = res.data.data;
      });
    },
  },
  // 挂载
  mounted() {
    this.getList();
    this.getOpstions();
  },
};
</script>

<style lang="less">
.messge {
  height: 90%;
  .common-table {
    position: relative;
    height: calc(100% - 62px);
    .page {
      position: absolute;
      bottom: 0;
      right: 20px;
    }
    .content {
      display: -webkit-box;
      -webkit-box-orient: vertical;
      -webkit-line-clamp: 3;
      overflow: hidden;
    }
  }
  .manage-hander {
    display: flex;
    justify-content: space-between;
    align-items: center;
  }
}
.el-table .cell {
  img {
    height: 50rpx;
  }
}
</style>

优质作品集

1.基于微信小程序的图书馆预约系统的设计与实现
2.基于微信小程序的实验室预约系统的设计与开发
3.基于微信小程序的番茄时钟的设计与实现(课设&毕设)
4.基于微信小程序的自习室预约系统的设计与实现
5.基于Uni-app的体育场馆预约系统的设计与实现
6.基于微信小程序的在线答题小程序设计与实现

8、源码获取

大家点赞、收藏、关注、评论啦 、查看👇🏻获取联系方式👇🏻

在这里插入图片描述

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/2295094.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

仅128个token达到ImageNet生成SOTA性能!MAETok:有效的扩散模型的关键是什么?(卡内基梅隆港大等)

论文链接&#xff1a;https://arxiv.org/pdf/2502.03444 项目链接&#xff1a;https://github.com/Hhhhhhao/continuous_tokenizer 亮点直击 理论与实验分析&#xff1a;通过实验和理论分析建立了潜空间结构与扩散模型性能之间的联系。揭示了具有更少高斯混合模型&#xff08;G…

示例:JAVA调用deepseek

近日&#xff0c;国产AI DeepSeek在中国、美国的科技圈受到广泛关注&#xff0c;甚至被认为是大模型行业的最大“黑马”。在外网&#xff0c;DeepSeek被不少人称为“神秘的东方力量”。1月27日&#xff0c;DeepSeek应用登顶苹果美国地区应用商店免费APP下载排行榜&#xff0c;在…

Linux系统命令无法使用(glib库相关问题)

1.背景描述 Yum强制安装了一些软件&#xff0c;安装软件成功无报错&#xff0c;完成后不久突然发现系统出问题了&#xff0c;所有的命令无法使用了&#xff0c;如ls、mv、cat等基本命令报错。 relocation error&#xff1a; /lib64/libpthread.so.0: symbol_libc_dl_error_tsd …

电脑黑屏按什么键恢复?电脑黑屏的解决办法

电脑黑屏的原因有很多&#xff0c;可能是硬件、软件、系统或者病毒等方面造成的。那么&#xff0c;当我们遇到电脑黑屏时&#xff0c;应该怎么做呢&#xff1f;有没有什么快捷的方法可以恢复正常呢&#xff1f;本文将为您介绍一些常见的电脑黑屏情况及其解决办法。 一、电脑开机…

思翼遥控器疑问?

1.地面端与遥控端对频&#xff0c;地面端选择数传2为串口&#xff0c;天空端的UART2通过USB转TTL模块连接电脑&#xff0c;通过串口助手观察得有1Hz输出帧&#xff08;开启遥控器APP时间段为10Hz&#xff09;&#xff0c;共21字节&#xff0c;请问&#xff0c;这个是什么含义&a…

anaconda中可以import cv2,但是notebook中cv2 module not found

一、问题 anaconda中成功import cv2 但是jupyter notebook中却无法导入cv2 二、排查 anaconda中使用python路径如下&#xff1a; jupyter notebook中使用python路径如下&#xff1a; 可以发现路径不一致。 三、解决 ①查看可用的kernel ②选中想要修改的kernel&#xff0c;打…

如何解决 Linux 文件系统挂载失败的问题

当遇到Linux文件系统挂载失败的问题时&#xff0c;您可以通过以下步骤来解决问题&#xff1a; 解决方法&#xff1a; 检查挂载点&#xff1a; 确保要挂载的目标文件系统存在&#xff0c;并且挂载点是正确的。检查挂载点是否已经被其他文件系统占用。 检查文件系统状态&#x…

PHP填表统计预约打卡表单系统小程序

&#x1f4cb; 填表统计预约打卡表单系统——专属定制&#xff0c;信息互动新纪元 &#x1f4ca; 填表统计预约打卡表单系统&#xff0c;一款专为现代快节奏生活量身打造的多元化自定义表单统计小程序&#xff0c;集信息填表、预约报名、签到打卡、活动通知、报名投票、班级统…

PAT乙级( 1009 说反话 1010 一元多项式求导)C语言版本超详细解析

1009 说反话 给定一句英语&#xff0c;要求你编写程序&#xff0c;将句中所有单词的顺序颠倒输出。 输入格式&#xff1a; 测试输入包含一个测试用例&#xff0c;在一行内给出总长度不超过 80的字符串。字符串由若干单词和若干空格组成&#xff0c;其中单词是由英文字母&#x…

LVSNAT服务搭建

LVSNAT实验环境搭建 在虚拟机上&#xff0c;我的NAT模式ip划分为&#xff1a;172.25.254.0 仅主机模式IP为&#xff1a;192.168.0.0 拓补图如下 配置服务&#xff1a;LVS服务端添加两个网卡&#xff0c;分别为NAT模式和仅主机模式 LVS服务端配置&#xff1a; systemctl st…

apisix网关ip-restriction插件使用说明

ip-restriction插件可以在网关层进行客户端请求ip拦截。 当然了&#xff0c;一般不推荐使用该方法&#xff0c;专业的事专业工具做。建议有条件&#xff0c;还是上防火墙或者waf来做。 官方文档&#xff1a;ip-restriction | Apache APISIX -- Cloud-Native API Gateway whit…

html 列动态布局

样式说明&#xff1a; /* 列动态布局&#xff0c;列之间以空格填充 */ li {display: flex;/* flex-direction: column; */justify-content: space-between; }

C++小等于的所有奇数和=最大奇数除2加1的平方。

缘由 三种思路解题&#xff1a;依据算术推导得到一个规律&#xff1a;小等于的所有奇数和等于最大奇数除以2加1的平方。将在后续发布&#xff0c;总计有十种推导出来的实现代码。 int a 0,aa 1,aaa 0;cin >> a; while (aa<a) aaa aa, aa 2;cout << aaa;i…

政采云业务网关实践:使用 Higress 统一替代 APISIX/Kong/Istio Ingress

作者&#xff1a;政采云基础架构团队技术专家 朱海峰&#xff08;片风&#xff09; 业务网关项目背景 由于一些历史的背景&#xff0c;政采云平台在网关建设上遇到一些问题&#xff1a; 容器网关配置较多&#xff0c;配置方式多样&#xff0c;运维压力较大&#xff1a; 配置…

【嵌入式 Linux 音视频+ AI 实战项目】瑞芯微 Rockchip 系列 RK3588-基于深度学习的人脸门禁+ IPC 智能安防监控系统

前言 本文主要介绍我最近开发的一个个人实战项目&#xff0c;“基于深度学习的人脸门禁 IPC 智能安防监控系统”&#xff0c;全程满帧流畅运行。这个项目我目前全网搜了一圈&#xff0c;还没发现有相关类型的开源项目。这个项目只要稍微改进下&#xff0c;就可以变成市面上目前…

C语言:深入了解指针4(超级详细)

看之前必须得掌握有一定指针的知识&#xff0c;不然会看不懂&#xff0c;如果有不懂的可以看我博客 指针1&#xff0c;指针2&#xff0c;指针3 这三个讲了指针全部的基础知识超级详细&#xff0c;这篇只要是讲一些指针练习题也是非常详细 1. sizeof和strlen的对⽐ 1. 基本定义…

CEF132 编译指南 Windows 篇 - 拉取 CEF 源码 (五)

1. 引言 获取 CEF 132 源码是开始编译工作的前提和关键步骤。在完成 depot_tools 的安装和配置后&#xff0c;我们需要通过正确的方式下载和同步 CEF 的源代码。由于 CEF 项目依赖于 Chromium 的大量组件&#xff0c;因此源码的获取过程需要特别注意同步策略和版本管理&#x…

DeepSeek与llama本地部署(含WebUI)

DeepSeek从2025年1月起开始火爆&#xff0c;成为全球最炙手可热的大模型&#xff0c;各大媒体争相报道。我们可以和文心一言一样去官网进行DeepSeek的使用&#xff0c;那如果有读者希望将大模型部署在本地应该怎么做呢&#xff1f;本篇文章将会教你如何在本地傻瓜式的部署我们的…

让万物「听说」:AI 对话式智能硬件方案和发展洞察

本文整理自声网 SDK 新业务探索组技术负责人&#xff0c;IoT 行业专家 吴方方 1 月 18 日在 RTE 开发者社区「Voice Agent 硬件分享会」上的分享。本次主要介绍了 AI 对话式智能硬件的发展历程&#xff0c;新一波 AI 浪潮所带来的创新机遇、技术挑战以及未来的展望。 在语音交…

Day38-【13003】短文,二叉树,完全二叉树,二叉树的顺序存储,和链式存储

文章目录 第二节 二叉树二叉树的定义及重要性质n个结点&#xff0c;能组合成多少个不同的二叉树满二叉树、完全二叉树完全二叉树的性质二叉树的性质二叉树的结点数完全二叉树的高度 二叉树的存储顺序存储方式链式存储方式二叉链表的程序实现二叉链表空指针域计算 第二节 二叉树…