当前位置: 首页 > article >正文

Vue面试2

1.跨域问题以及如何解决跨域

跨域问题(Cross-Origin Resource Sharing, CORS)是指在浏览器中,当一个资源试图从一个不同的源请求另一个资源时所遇到的限制。这种限制是浏览器为了保护用户安全而实施的一种同源策略(Same-origin policy)。同源指的是协议、域名以及端口号三者都相同。如果这三者中的任何一个不同,那么它们就被认为是不同的源。

解决方案

解决跨域问题的方法有几种:

  • CORS配置:最直接的方式是在服务器端设置适当的CORS头。例如,在Express.js应用中可以通过安装并使用cors中间件来快速实现。

const express = require('express');
const cors = require('cors');
const app = express();app.use(cors());app.get('/data', (req, res) => {res.json({message: 'This is CORS-enabled for all origins!'});
});app.listen(8080, () => console.log('Server running on port 8080'));
  • JSONP:这是一种较老的技术,仅支持GET请求。它的工作原理是动态创建一个<script>标签,并将跨域请求的URL指定为该标签的src属性值。服务器端需要返回一段JavaScript代码,这段代码调用一个客户端预先定义好的回调函数,并以参数的形式传递请求结果。由于现代浏览器支持CORS,这种方法现在较少使用。

  • 使用代理:可以设置一个代理服务器,前端向这个代理服务器发送请求,代理服务器再向目标服务器转发请求并将响应返回给前端。这样就不存在跨域问题了,因为请求都是在同一源内发生的。

在开发环境中,可以通过配置Vue CLI提供的vue.config.js文件来设置代理,以解决开发时的跨域问题。这将使得开发服务器能够转发请求到指定的目标服务器,从而避免了浏览器的同源策略限制。

module.exports = {devServer: {proxy: {'/api': {target: 'http://your-backend-server.com', // 目标服务器地址changeOrigin: true,pathRewrite: {'^/api': ''  // 重写路径,去掉/api前缀}}}}
}

在这个例子中,所有以/api开头的请求都会被代理到target指定的服务器上 。

2.Vue2中的过滤器

在Vue.js中,过滤器(Filters)主要用于对文本进行格式化操作。虽然从Vue 3开始,官方已经移除了过滤器这一特性,推荐使用计算属性(Computed Properties)或方法(Methods)来替代它们,但在Vue 2中,过滤器仍然是一个有效的功能,尤其是在需要对文本进行简单转换而不修改原始数据的情况下。

本质上,过滤器是定义为函数的形式,接受一个值作为输入参数,然后返回一个新的值。这个过程不会修改原始值,而是基于原始值创建一个新的值用于显示或其他用途。

使用场景
  1. 日期格式化:将ISO格式的日期字符串转换为更易读的形式。
  2. 货币格式化:显示金额时添加货币符号、千位分隔符等。
  3. 大小写转换:如将文本全部转换为大写或小写。
  4. 数字处理:例如,限制小数点后的位数。
  5. 国际化:根据用户语言设置显示不同语言的内容。
实现做法

定义全局过滤器

可以在main.js中定义全局过滤器,这样所有组件都可以使用这些过滤器:

Vue.filter('capitalize', function(value) {if (!value) return '';value = value.toString();return value.charAt(0).toUpperCase() + value.slice(1);
});Vue.filter('currency', function(value) {if (typeof value !== "number") {return value;}var formatter = new Intl.NumberFormat('en-US', {style: 'currency',currency: 'USD',});return formatter.format(value);
});

定义局部过滤器

也可以在单个组件内定义过滤器,仅该组件可以使用:

export default {// ...filters: {capitalize(value) {if (!value) return '';value = value.toString();return value.charAt(0).toUpperCase() + value.slice(1);},currency(value) {if (typeof value !== "number") {return value;}var formatter = new Intl.NumberFormat('en-US', {style: 'currency',currency: 'USD',});return formatter.format(value);}}
}
在模板中使用过滤器

一旦定义了过滤器,就可以在模板中使用管道符号|应用过滤器:

<p>{{ message | capitalize }}</p>
<p>{{ amount | currency }}</p>

3.什么是虚拟dom,如何实现虚拟dom

什么是虚拟DOM?

虚拟DOM(Virtual DOM)是一种编程概念,它指的是在Web应用中,使用JavaScript对象来模拟真实的DOM树。每个虚拟DOM节点对应着真实DOM树中的一个元素。通过这种方式,可以有效地减少直接操作真实DOM的次数,从而提高性能。

虚拟DOM的主要目的是优化用户界面的更新过程。当数据模型发生变化时,不是立即更新真实DOM,而是先更新虚拟DOM。然后通过比较新旧两个虚拟DOM树的差异(这个过程称为Diff算法),找出需要更新的部分,并将这些变化批量地应用到真实DOM上。这样做的好处是可以最小化重绘和回流,提高渲染效率。

如何实现?

①创建虚拟dom:

function createElement(type, props = {}, ...children) {return { type, props, children };
}

②渲染虚拟dom为真实dom:

function render(vnode){...return node
}

③使用diff算法最小化更新

④更新真实dom

4.Vue权限管理

在 Vue 项目中实现权限管理是一个常见的需求,通常涉及路由权限按钮权限接口权限的控制。

①路由权限控制

核心思路是 动态管理路由 和 全局权限校验

路由权限是指根据用户角色或权限动态加载可访问的路由。

实现步骤:

  • 定义路由表

将路由分为公共路由(所有用户可访问)和权限路由(根据用户角色动态加载)。

// publicRoutes.js
export const publicRoutes = [{ path: '/login', component: () => import('@/views/Login.vue') },{ path: '/404', component: () => import('@/views/404.vue') },
];// privateRoutes.js
export const privateRoutes = [{ path: '/dashboard', component: () => import('@/views/Dashboard.vue'), meta: { role: 'admin' } },{ path: '/user', component: () => import('@/views/User.vue'), meta: { role: 'user' } },
];
  • 动态添加路由

根据用户角色从后端获取权限列表,动态添加路由。

import { publicRoutes, privateRoutes } from './routes';
import router from './router';const addRoutes = (role) => {const allowedRoutes = privateRoutes.filter(route => route.meta.role === role);allowedRoutes.forEach(route => router.addRoute(route));
};// 登录成功后调用
addRoutes('admin');
  • 路由守卫

使用 beforeEach 钩子检查用户是否有权限访问目标路由。

router.beforeEach((to, from, next) => {const userRole = localStorage.getItem('userRole'); // 从本地存储获取用户角色if (to.meta.role && to.meta.role !== userRole) {next('/404'); // 无权限则跳转到 404} else {next();}
});
②按钮权限控制

按钮权限是指根据用户角色或权限动态显示或隐藏页面中的按钮。

实现步骤:

  • 自定义指令

创建一个自定义指令 v-permission,用于控制按钮的显示和隐藏。

// main.js
Vue.directive('permission', {inserted(el, binding, vnode) {const userRole = localStorage.getItem('userRole');if (binding.value !== userRole) {el.parentNode.removeChild(el); // 无权限则移除按钮}},
});
  • 使用指令

在按钮上使用 v-permission 指令。

<template><button v-permission="'admin'">管理员按钮</button><button v-permission="'user'">普通用户按钮</button>
</template>
接口权限控制

接口权限是指根据用户角色或权限控制用户能否调用某些接口。

实现步骤:

  • 后端控制

    • 后端接口根据用户角色返回不同的数据或状态码(如 403 无权限)。

  • 前端拦截

    • 在请求拦截器中检查用户权限。

axios.interceptors.request.use((config) => {const userRole = localStorage.getItem('userRole');if (config.url === '/admin/data' && userRole !== 'admin') {return Promise.reject(new Error('无权限访问'));}return config;
});
权限管理的完整流程
  1. 用户登录

    • 用户登录后,后端返回用户角色和权限列表。

    • 前端将角色和权限信息存储在 localStorage 或 Vuex 中。

  2. 动态路由加载

    • 根据用户角色动态加载路由。

  3. 路由守卫

    • 在路由跳转时检查用户权限。

  4. 按钮权限

    • 使用自定义指令控制按钮的显示和隐藏。

  5. 接口权限

    • 在请求拦截器中检查用户权限。

5.SPA首屏加载优化

一、代码优化:减少主包体积

1. 代码分割(Code Splitting)

  • 使用 Webpack 的 SplitChunksPlugin 或 Vite 的自动分割,将代码拆分成多个小块。

2. 路由懒加载

  • 结合动态导入(import())实现按需加载路由组件。

3. Tree Shaking

  • 移除未使用的代码(仅对 ESM 模块有效)。
  • 注意:确保项目使用 ES6 模块语法,并在 package.json 中设置 "sideEffects": false

4. 压缩代码

  • 使用 TerserPlugin 压缩 JS,CssMinimizerPlugin 压缩 CSS。
二、资源优化:减少传输体积

1. 图片压缩与格式优化

  • 使用 WebP 格式替代 PNG/JPG(体积减少 30%~70%)。
  • 工具推荐:
    • Squoosh(在线压缩)
    • ImageMagick(批量处理)
    • vue-lazyload(图片懒加载)

2. 字体文件优化

  • 使用 font-display: swap; 避免字体加载阻塞渲染。
  • 按需加载字体子集(通过 Google Fonts Subset)。

3. 开启 Gzip/Brotli 压缩

  • 服务器配置 Gzip 或 Brotli(比 Gzip 压缩率高 20%)。
三、缓存策略:减少重复加载

1. 强缓存(Cache-Control)

  • 对静态资源(JS/CSS/图片)设置长缓存。

2. 版本号哈希

  • 文件名添加哈希(如 app.3a87f.js),确保内容变更后缓存失效。
四、渲染优化:加速首屏展示

1. 服务端渲染(SSR)

  • 使用 Nuxt.js(Vue) 或 Next.js(React) 实现服务端生成 HTML。
  • 优势:直接返回渲染好的 HTML,减少客户端解析时间。

2. 预渲染(Prerendering)

  • 对静态页面(如营销页)在构建时生成 HTML。
  • 工具推荐:vue-cli-plugin-prerender-spareact-snap

3. 骨架屏(Skeleton Screen)

  • 在数据加载前展示占位图,提升用户体验。
五、网络层优化:加速资源传输

1.资源预加载(Preload/Prefetch)

  • 使用 <link rel="preload"> 提前加载关键资源。

6.回流和重绘

在前端开发中,回流(Reflow) 和重绘(Repaint) 是浏览器渲染机制的关键概念,直接影响页面性能。以下是详细解析:

一、概念区别
  1. 回流(Reflow)

    • 当元素的尺寸、位置、布局等几何属性发生变化时,浏览器需要重新计算元素的几何信息(布局),并更新渲染树。
    • 触发条件:影响页面布局的操作,例如修改宽高、边距、字体大小、DOM结构变化等。
    • 性能消耗:高,可能导致子元素或父元素的连锁回流。
  2. 重绘(Repaint)

    • 当元素的外观属性(如颜色、背景、透明度等)发生变化,但布局未改变时,浏览器仅重新绘制受影响的部分。
    • 触发条件:不影响布局的样式变化,如 colorbackground-colorvisibility 等。
    • 性能消耗:低于回流,但仍需避免高频触发。
二、优化策略:减少回流和重绘

1. 批量 DOM 操作

  • 使用 DocumentFragment 或离线 DOM
    将多次 DOM 修改合并到临时容器中,再一次性插入
const fragment = document.createDocumentFragment();
for (let i = 0; i < 100; i++) {const node = document.createElement("div");fragment.appendChild(node);
}
document.body.appendChild(fragment);
  • 隐藏元素后操作

        通过 display: none 隐藏元素,操作完成后再显示

2. 避免频繁读取布局属性

  • 缓存布局信息

3. 使用 CSS 优化

  • 通过 CSS 类合并样式
  • 使用 transform 和 opacity 实现动画
    这些属性由 GPU 加速处理,避免触发回流/重绘

4. 避免表格布局和复杂选择器

  • 表格布局(display: table)易触发连锁回流。
  • 减少 CSS 选择器嵌套层级,降低样式计算复杂度

7.CSS预编语言

CSS 预处理器(CSS Preprocessor)通过扩展 CSS 的功能,提供了更高效、更灵活的样式编写方式。以下是主流 CSS 预处理器(SassLessStylus)的区别与特点总结。

一、共同特点
  • 变量

    支持定义变量,方便复用和维护样式

$primary-color: #3498db; // Sass
@primary-color: #3498db; // Less
primary-color = #3498db // Stylus
  • 嵌套

        支持嵌套规则,减少代码冗余。

.container {.item {color: red;}
}
  • 混合(Mixins)

        支持定义可复用的样式块。

@mixin border-radius($radius) { // Sassborder-radius: $radius;
}
.box { @include border-radius(10px); }// Less
.alert {font-weight: 700;
}
.highlight(@color: red) {font-size: 1.2em;color: @color;
}
.heads-up {.alert;.highlight(red);
}
  • 导入(Import)

        支持模块化,将样式拆分为多个文件

@import "variables"; // Sass/Less/Stylus
二、对比

三、选择建议
  1. Sass:功能强大,适合复杂项目,推荐使用 .scss 语法。
  2. Less:简单易用,适合小型项目或与 Bootstrap 集成。
  3. Stylus:灵活且功能丰富,适合追求简洁语法的开发者。

 

相关文章:

Vue面试2

1.跨域问题以及如何解决跨域 跨域问题&#xff08;Cross-Origin Resource Sharing, CORS&#xff09;是指在浏览器中&#xff0c;当一个资源试图从一个不同的源请求另一个资源时所遇到的限制。这种限制是浏览器为了保护用户安全而实施的一种同源策略&#xff08;Same-origin p…...

合合信息2025届春季校园招聘全面启动!

世界因你而AI&#xff0c;合合信息2025届春季校园招聘启动&#xff01; 我们是谁&#xff1f; 我们是一家行业领先的人工智能及大数据科技企业 18年深耕AI领域&#xff0c;C端产品与B端服务布局矩阵完善 9.4亿全球累计用户首次下载量&#x1f4a5; 来到这里你能得到什么&a…...

如何利用 Vue 的生命周期钩子进行初始化和清理操作?

一、初始化操作的核心钩子 1. created&#xff08;选项式API&#xff09; export default {data() {return { user: null };},created() {// 适合初始化数据、发起非DOM操作请求this.fetchUser();},methods: {async fetchUser() {const response await fetch(/api/user);thi…...

Excell 代码处理

文章目录 Excell 代码处理cvc格式xlsl格式小结 Excell 代码处理 有时候要对excell进行分析&#xff0c;或者数据的导入导出&#xff0c;这个时候如果可以用代码读写分析操作那么会方便很多 cvc格式 CSV&#xff08;Comma-Separated Values&#xff0c;逗号分隔值&#xff09;是…...

KMP的next数组构建详解

KMP的next数组构建详解 1. next数组的作用 核心功能&#xff1a;在KMP算法中&#xff0c;当模式串与主串发生不匹配时&#xff0c;next数组决定模式串指针回退的位置&#xff0c;避免无效匹配。 定义&#xff1a;next[i]表示子串s[0...i]的最长公共前后缀长度。例如&#xff…...

Docker 的安全配置与优化(二)

Docker 安全优化策略 &#xff08;一&#xff09;多阶段构建优化镜像大小 多阶段构建是 Docker 17.05 版本引入的强大功能&#xff0c;它允许在一个 Dockerfile 中定义多个构建阶段&#xff0c;每个阶段都可以使用不同的基础镜像和依赖项&#xff0c;最终只将必要的文件和依赖…...

shiro代码层面追踪

文章目录 环境漏洞分析硬编码 反序列化Gadget构造 环境 环境搭建&#xff1a;https://blog.csdn.net/qq_44769520/article/details/123476443 漏洞分析 硬编码 shiro是对rememberMe这个cookie进⾏反序列化的时候出现了问题。 相应代码 // // Source code recreated from …...

通信系统中物理层与网络层联系与区别

在通信系统中&#xff0c;物理层和网络层是OSI&#xff08;开放系统互连&#xff09;模型中的两个重要层次&#xff0c;分别位于协议栈的最底层和第三层。它们在功能、职责和实现方式上有显著的区别&#xff0c;但同时也在某些方面存在联系。以下是物理层与网络层的联系与区别的…...

虚拟机网络ssh连接失败,没有网络

vscode进行ssh时连接失败&#xff0c;发现是虚拟机没有网络。 虚拟机ping不通www.baidu.com但可以ping通内网 ping 8.8.8.8ping不通。 sudo dhclient -r ens33 sudo dhclient ens33 ip route show可以了。 20250221记录&#xff1a;不知道是不是重启了虚拟机还是咋了&#…...

已知点矩阵的三个顶点坐标、行列数和行列的间距,计算得出剩余所有点的坐标

已知点矩阵的三个顶点坐标、行列数和行列的间距&#xff0c;计算得出剩余所有点的坐标 计算矩阵中每个点的坐标代码实现案例图调用验证 计算矩阵中每个点的坐标 给定左上角、左下角和右上角三个点的坐标&#xff0c;以及矩阵的行数、列数、行间距和列间距&#xff0c;我们可以…...

Python Cookbook-2.4 从文件中读取指定的行

任务 根据给出的行号&#xff0c;从文本文件中读取一行数据。 解决方案 Python标准库linecache模块非常适合这个任务: import linecache theline linecache.getline(thefilepath, desired_line_number)讨论 对这个任务而言&#xff0c;标准的 linecache 模块是 Python 能…...

go 并发 gorouting chan channel select Mutex sync.One

goroutine // head&#xff1a; 前缀 index&#xff1a;是一个int的指针 func print(head string, index *int) {for i : 0; i < 5; i {// 指针对应的int *indexfmt.Println(*index, head, i)// 暂停1stime.Sleep(1 * time.Second)} }/* Go 允许使用 go 语句开启一个新的运…...

Unity游戏制作中的C#基础(3)加减乘除算术操作符,比较运算符,逻辑与,或运算符

1. 基本算术运算符 算术运算符主要用于对数值类型&#xff08;整型和浮点型&#xff09;进行基本的数学运算。以下是常见的算术运算符及其说明&#xff1a; 运算符描述示例结果加法运算符&#xff0c;用于两个数相加&#xff0c;也可用于字符串连接int a 5 3; string str &…...

深度学习入门--python入门2

以前学的全忘了&#xff0c;现在算是才开始学&#xff0c;有错误&#xff0c;恳请指正。 目录 1.4 Python脚本文件 1.4.1保存为文件 1.4.2 类 1.5 Numpy 1.5.1 导入Numpy 1.5.2 生成Numpy数组 1.5.3 Numpy的算术运算 1.5.4 Numpy的N维数组 1.5.5 广播 1.5.6 访问元素…...

题海拾贝:【枚举】P2010 [NOIP 2016 普及组] 回文日期

Hello大家好&#xff01;很高兴我们又见面啦&#xff01;给生活添点passion&#xff0c;开始今天的编程之路&#xff01; 我的博客&#xff1a;<但凡. 我的专栏&#xff1a;《编程之路》、《数据结构与算法之美》、《题海拾贝》 欢迎点赞&#xff0c;关注&#xff01; 1、题…...

Mac端homebrew安装配置

拷打了一下午o3-mini-high&#xff0c;不如这位博主的超强帖子&#xff0c;10分钟结束战斗 跟随该文章即可&#xff0c;2025/2/19亲测可行 mac 安装HomeBrew(100%成功)_mac安装homebrew-CSDN博客文章浏览阅读10w次&#xff0c;点赞258次&#xff0c;收藏837次。一直觉得自己写…...

Web - JS基础语法与表达式

概述 这篇文章主要介绍了 JavaScript 的基础语法&#xff0c;包括代码书写位置、ERPL 环境、变量&#xff08;命名规则、默认值、初始化&#xff09;、数据类型&#xff08;基本和复杂&#xff0c;及各类型特点、转换&#xff09;、表达式和运算符&#xff08;算数、特殊算数、…...

Python高级语法之selenium

目录&#xff1a; 1、selenium的使用2、selenium元素定位3、selenium使用功能Phantomjs模拟浏览器启动4、selenium使用功能ChromsHandless模拟浏览器启动 1、selenium的使用 2、selenium元素定位 3、selenium使用功能Phantomjs模拟浏览器启动 4、selenium使用功能ChromsHandles…...

AIP-148 标准域

编号148原文链接AIP-148: Standard fields状态批准创建日期2020-10-06更新日期2020-10-06 一些概念在任何API集合中都很常用。对于这些概念&#xff0c;使用统一的标准域名字和行为来表达它们&#xff0c;是非常有用的。 指南 标准域 应当 用于描述其相应概念&#xff0c; 不…...

Docker构建时,设定默认进入的工作目录的方法

在 Docker 中,你可以通过不同的方式来设定容器默认进入的目录,以下针对不同场景分别介绍具体方法: 1. 使用 Dockerfile 设定工作目录 如果你是通过构建镜像的方式来运行容器,那么可以在 Dockerfile 中使用 WORKDIR 指令来设置容器启动时的默认工作目录。以下是具体步骤:…...

2025年3月最新算法-鲸鱼迁徙优化算法Whale Migration Algorithm-附Matlab免费代码

引言 本期介绍了一种基于座头鲸协同迁移行为的创新生物启发式优化方法——鲸鱼迁徙优化算法Whale Migration Algorithm&#xff0c;WMA。该算法于2025年3月最新发表在期刊 Results in Engineering 在本节中&#xff0c;我们概述了开发鲸鱼迁移算法&#xff08;WMA&#xff09;…...

day56 第十一章:图论part06

108.冗余连接 注意init初始化 改进&#xff1a; 其实只有一条边冗余&#xff0c;改为&#xff0c;如果两条边在同一个集合里&#xff0c;就输出&#xff0c;不然加入。 #include <iostream> #include <vector> using namespace std;int n 1005; vector<int>…...

flowable适配达梦数据库

文章目录 适配相关问题无法从数据库产品名称“DM DBMS”中推断数据库类型分析解决 构建ibatis SqlSessionFactory时出错&#xff1a;inStream参数为null分析解决 liquibase相关问题问题一&#xff1a;不支持的数据库 Error executing SQL call current_schema: 无法解析的成员访…...

Jenkins整合Jmeter实现接口自动化测试

&#x1f345; 点击文末小卡片&#xff0c;免费获取软件测试全套资料&#xff0c;资料在手&#xff0c;涨薪更快 一、安装jmeter 下载&#xff1a;http://jmeter.apache.org/download_jmeter.cgi 这里我用了一台Windows安装jmeter用来写接口测试的脚本&#xff0c;启动前修改j…...

高级推理的多样化推理与验证

25年2月来自波士顿大学、NotBadMath.AI、谷歌、哥伦比亚大学、MIT、Intuit公司和斯坦福大学的论文“Diverse Inference and Verification for Advanced Reasoning”。 OpenAI o1、o3 和 DeepSeek R1 等推理 LLM 在数学和编码方面取得重大进展&#xff0c;但仍发现 IMO 组合问题…...

深入理解 MySQL 8 C++ 源码:SELECT MOD(MONTH(NOW()), 2) 的函数执行过程

MySQL 作为最流行的关系型数据库之一&#xff0c;其内部实现机制一直是开发者探索的热点。本文将以一条简单的 SQL 查询 SELECT MOD(MONTH(NOW()), 2) 为例&#xff0c;深入分析 MySQL 8 源码中内置函数 MOD、MONTH 和 NOW 的执行过程&#xff0c;揭示其底层实现逻辑。 一、SQL…...

清华大学:DeepSeek与AI幻觉(31页PDF)

PDF深入探讨了AI幻觉的概念、原因、评测方法及其实用应用&#xff0c;特别是在金融领域的具体案例。首先介绍了AI幻觉的定义&#xff0c;主要包括数据偏差、泛化困境、知识固化和意图误解四种情况&#xff0c;以及这些因素导致AI产出不合理结果的原因。随后&#xff0c;通过音乐…...

AWS云从业者认证题库 AWS Cloud Practitioner(2.21)

题库持续更新&#xff0c;上方二维码查看完整题库&#xff01; 公司希望减少开发人员用于运行代码的物理计算资源,通过启用无服务器架构&#xff0c;哪种服务可以满足该需求? A&#xff1a; Amazon Elastic Compute Cloud (Amazon EC2) B&#xff1a; AWS Lambda C&#xff1a…...

CompletableFuture 使用和源码解读

引言 CompletableFuture 是 Java 8 引入的一个强大的异步编程工具&#xff0c;用于处理异步操作和处理结果。它实现了 Future 和 CompletionStage 接口&#xff0c;提供了丰富的方法来处理异步任务的完成、组合和异常处理。 CompletableFuture本质是对异步线程的返回值…...

C++与Python:两种编程语言的区别

C和Python都是当今编程领域广泛使用的语言&#xff0c;它们各有特色&#xff0c;适用于不同的开发场景。本文将从语言特性、性能、学习难度、应用领域等多个方面探讨C与Python之间的区别。 一、语言特性 类型系统&#xff1a; C&#xff1a;是一种静态类型语言&#xf…...