​牧​原​二​面​

news2024/10/7 22:09:35

1. 请尽可能详细地说明,假设你正在开发的React前端项目中,涉及到不同权限的角色使用,需要实现对路由和组件的细粒度权限控制。路由使用的是React Router路由守卫。请详细说明你的思路。你的回答中不要写出示例代码。

在React前端项目中实现基于角色的细粒度权限控制,特别是涉及到路由和组件的访问权限,是一个复杂但非常重要的任务。以下是详细的思路和步骤:

1. 定义角色和权限

首先,你需要明确系统中有哪些角色以及每个角色拥有哪些权限。例如:

  • 管理员(Admin):可以访问所有页面和功能。
  • 编辑者(Editor):可以编辑内容,但不能管理用户。
  • 访客(Guest):只能浏览公开内容。

2. 创建权限配置文件

创建一个配置文件(如permissions.js),在其中定义每个角色对应的权限列表。例如:

// permissions.js
export const roles = {
  Admin: ['viewDashboard', 'editContent', 'manageUsers'],
  Editor: ['viewDashboard', 'editContent'],
  Guest: ['viewPublicContent']
};

3. 集成React Router

使用React Router来管理路由,并结合自定义的路由守卫来实现权限控制。

3.1 创建高阶组件(HOC)

创建一个高阶组件(Higher-Order Component, HOC),用于包裹需要权限控制的组件。这个HOC会检查当前用户的角色是否有权限访问该组件。

3.2 路由守卫

在路由配置中使用这个HOC来保护特定的路由。例如:

import { Route, Redirect } from 'react-router-dom';
import { checkPermission } from './permissions';

const ProtectedRoute = ({ component: Component, roles, ...rest }) => {
  const userRole = getCurrentUserRole(); // 获取当前用户的角色

  return (
    <Route
      {...rest}
      render={(props) =>
        checkPermission(userRole, roles) ? (
          <Component {...props} />
        ) : (
          <Redirect to="/unauthorized" />
        )
      }
    />
  );
};

4. 实现权限检查逻辑

permissions.js中实现checkPermission函数,用于检查当前用户的角色是否有权限访问某个组件或路由。

export const checkPermission = (userRole, requiredRoles) => {
  if (!requiredRoles) return true; // 如果没有指定角色,则默认允许访问
  return requiredRoles.includes(userRole);
};

5. 应用权限控制

在路由配置中使用ProtectedRoute来保护需要权限控制的页面。

import { BrowserRouter as Router, Switch, Route } from 'react-router-dom';
import ProtectedRoute from './ProtectedRoute';
import Dashboard from './Dashboard';
import EditContent from './EditContent';
import ManageUsers from './ManageUsers';
import PublicContent from './PublicContent';

const AppRouter = () => {
  return (
    <Router>
      <Switch>
        <ProtectedRoute path="/dashboard" component={Dashboard} roles={['Admin', 'Editor']} />
        <ProtectedRoute path="/edit-content" component={EditContent} roles={['Admin', 'Editor']} />
        <ProtectedRoute path="/manage-users" component={ManageUsers} roles={['Admin']} />
        <Route path="/public-content" component={PublicContent} />
        <Route path="/unauthorized" component={UnauthorizedPage} />
        <Redirect from="/" to="/dashboard" exact />
      </Switch>
    </Router>
  );
};

6. 动态权限更新

如果用户的角色可能会在运行时发生变化(例如,通过管理员操作提升用户权限),你需要确保权限检查逻辑能够动态响应这些变化。可以通过监听全局状态管理库(如Redux)中的角色变化来实现。

7. 测试和调试

最后,确保对所有可能的角色和权限组合进行充分的测试,以验证权限控制逻辑的正确性。

通过上述步骤,你可以实现一个基于角色的细粒度权限控制系统,确保不同角色的用户只能访问他们被授权的资源。

2. 请尽可能详细地说明,前端实现虚拟列表的思路。你的回答中不要写出示例代码。

在前端实现虚拟列表(Virtual List)是一种优化长列表渲染性能的有效方法。虚拟列表的核心思想是只渲染视口(viewport)内的元素,而不是一次性渲染整个列表。以下是实现虚拟列表的详细思路:

1. 确定视口和滚动容器

  • 视口(Viewport):用户当前可见的部分。
  • 滚动容器(Scroll Container):包含整个列表的容器,用户可以在其中滚动查看不同部分的内容。

2. 计算可见区域

  • 高度计算:确定滚动容器的高度以及每个列表项的平均高度。
  • 偏移量计算:根据滚动位置计算出当前视口内的第一个和最后一个列表项的索引。

3. 动态渲染

  • 初始渲染:根据计算的可见区域,只渲染视口内的列表项。
  • 滚动更新:监听滚动事件,当用户滚动时,重新计算可见区域并更新渲染内容。

4. 占位元素

  • 占位符(Placeholder):为了保持滚动条的正确显示和滚动体验的一致性,需要为未渲染的列表项设置占位符。这些占位符的高度应与实际列表项的高度相匹配。

5. 缓存机制

  • 缓存已渲染项:对于已经渲染过的列表项,可以进行缓存,以便在用户滚动回之前的位置时能够快速显示,而不是重新创建。

6. 性能优化

  • 节流和防抖:对滚动事件进行节流(throttle)或防抖(debounce)处理,以减少事件处理函数的调用频率,提高性能。
  • 避免强制同步布局:在更新DOM时,注意避免触发浏览器的强制同步布局(Forced Synchronous Layout),这会导致性能问题。

7. 兼容性和可访问性

  • 兼容性:确保虚拟列表在不同的浏览器和设备上都能正常工作。
  • 可访问性:考虑到屏幕阅读器等辅助技术,确保虚拟列表的内容对所有用户都是可访问的。

8. 边界情况处理

  • 空列表:当列表为空时,应有适当的处理方式。
  • 快速滚动:处理用户快速滚动时的性能问题,确保不会出现卡顿或空白区域。

9. 测试和调试

  • 单元测试:编写单元测试来验证虚拟列表的核心功能。
  • 集成测试:在实际应用环境中测试虚拟列表的性能和稳定性。

通过以上步骤,可以实现一个高效的前端虚拟列表,显著提升用户体验和应用性能。

3. 请尽可能详细地说明,前端性能优化的方向。你的回答中不要写出示例代码。

前端优化是一个多方面的过程,旨在提高网页的性能、用户体验以及开发效率。以下是一些主要的前端优化方向:

一、速度和时间上的优化

  1. 减少HTTP请求

    • 合并CSS和JavaScript文件。
    • 使用CSS Sprites合并小图标。
    • 利用浏览器缓存机制。
  2. 优化资源加载

    • 压缩和最小化CSS、JavaScript和HTML文件。
    • 使用CDN分发静态资源。
    • 实施懒加载(Lazy Loading)策略,按需加载资源。
  3. 代码分割与按需加载

    • 利用Webpack等工具进行代码分割。
    • 异步组件加载,减少首屏渲染时间。
  4. 优化图片和多媒体

    • 使用适当的图片格式(如WebP)。
    • 图片压缩和裁剪以减少文件大小。
    • 利用响应式图片技术。
  5. 服务器端渲染(SSR)和静态站点生成(SSG)

    • 减少客户端渲染时间,加快首屏显示速度。
    • 提高SEO效果,因为搜索引擎可以直接抓取渲染后的页面内容。
  6. 使用Service Workers进行离线缓存

    • 实现应用的离线访问能力。
    • 加速重复访问时的页面加载速度。
  7. 优化CSS选择器和布局

    • 避免过于复杂的CSS选择器。
    • 使用Flexbox和Grid布局优化页面结构。
  8. 减少重绘和回流

    • 批量修改DOM样式,使用CSS类代替内联样式。
    • 利用DocumentFragment进行批量DOM操作。

二、用户体验流畅上的优化

  1. 动画和过渡效果优化

    • 使用硬件加速的CSS属性(如transform和opacity)。
    • 避免在动画中使用触发回流的属性。
  2. 交互反馈及时响应

    • 确保按钮点击和其他交互有即时视觉反馈。
    • 使用骨架屏(Skeleton Screen)提升加载时的用户体验。
  3. 减少用户等待焦虑

    • 显示加载指示器或进度条。
    • 提供友好的错误处理和重试机制。
  4. 优化表单验证和提交流程

    • 实施即时客户端验证,减少无效提交。
    • 设计简洁明了的表单布局和标签说明。
  5. 适配多种设备和屏幕尺寸

    • 响应式设计,确保网站在不同设备上都能良好展示。
    • 考虑触控操作和屏幕阅读器的兼容性。
  6. 优化导航结构和信息架构

    • 设计直观易懂的网站导航。
    • 合理分组和组织内容,便于用户快速找到所需信息。
  7. 无障碍访问(Accessibility)

    • 遵循WCAG等无障碍设计准则。
    • 提供足够的对比度、清晰的文本标签以及键盘导航支持。

三、开发效率和可维护性优化

  1. 模块化与组件化开发

    • 利用React、Vue等框架的组件化特性。
    • 实现代码复用和模块解耦。
  2. 采用现代前端工具链

    • 使用ESLint和Prettier规范代码风格。
    • 自动化构建流程,如Gulp或Webpack配置。
  3. 版本控制与管理

    • 利用Git等版本控制系统跟踪变更。
    • 编写清晰的提交信息和分支管理策略。
  4. 持续集成与持续部署(CI/CD)

    • 自动化测试和部署流程,加快迭代速度。
    • 监控应用性能并及时反馈问题。
  5. 文档和注释规范

    • 编写详尽的项目文档和使用指南。
    • 在关键代码处添加注释说明意图和逻辑。

综上所述,前端优化是一个涵盖多个层面的综合性任务,需要开发者从技术实现到用户体验再到开发流程等多个角度进行全面考量和改进。

4. 口述算法:Javascript树型数据扁平化

function flatten(tree) {
    let flatArray = [];
    // 递归函数用于遍历树并添加节点到数组中
    function flattenRecursive(nodes) {
        nodes.forEach((node) => {
            flatArray.push(node);
            if (node.children && node.children.length) {
                flattenRecursive(node.children);
            }
        });
    }
    // 从树的根节点开始递归
    flattenRecursive([tree]);
    return flatArray;
}
 
// 示例树结构
const tree = {
    value: "node1",
    children: [
        { value: "node2", children: [{ value: "node4", children: [] }, { value: "node5", children: [] }] },
        { value: "node3", children: [] }
    ]
};
 
// 使用flatten函数
const flatTree = flatten(tree);
console.log(flatTree); // 输出: [{ value: "node1" }, { value

5. 请尽可能详细地说明,关于前端CSS样式的优化的措施。你的回答中不要写出示例代码。

前端CSS样式的优化是提升网页性能和用户体验的关键环节。以下是一些详细的CSS样式优化措施:

一、减少CSS文件大小

  1. 压缩CSS代码

    • 移除不必要的空格、换行和注释。
    • 使用工具如CSSNano、YUI Compressor等进行自动压缩。
  2. 合并CSS文件

    • 将多个CSS文件合并成一个,减少HTTP请求次数。
    • 在构建过程中自动化这一流程。
  3. 使用CSS预处理器

    • 利用Sass、Less等预处理器进行变量定义、嵌套和混合(Mixins)等,以提高代码复用性和可维护性。

二、优化CSS选择器

  1. 简化选择器结构

    • 避免使用过于复杂或深层次的CSS选择器,以提高渲染效率。
    • 尽量使用ID选择器和类选择器,它们具有较高的优先级且易于浏览器解析。
  2. 避免使用通配符和否定伪类

    • 通配符(*)会导致全页面元素遍历,影响性能。
    • 否定伪类(如:not())可能增加选择器的复杂性。

三、提高CSS渲染性能

  1. 避免强制同步布局

    • 在JavaScript中修改样式时,尽量避免触发浏览器的重排(Reflow)和重绘(Repaint)。
    • 批量修改样式或使用DocumentFragment进行DOM操作。
  2. 利用GPU加速

    • 使用transform、opacity等属性触发硬件加速,提升动画流畅度。
    • 注意避免在动画中改变布局相关的属性,如width、height、margin等。

四、优化CSS加载策略

  1. 关键CSS内联

    • 将首屏渲染所需的关键CSS直接内联到HTML中,减少首次渲染时间。
    • 非关键CSS则可通过异步加载或延迟加载来处理。
  2. 使用媒体查询进行条件加载

    • 根据设备特性或屏幕尺寸加载不同的CSS样式表。
    • 利用@media规则实现响应式设计,优化不同场景下的显示效果。

五、增强CSS可维护性

  1. 命名规范与模块化

    • 采用BEM、SMACSS等命名约定,提升代码的可读性和可维护性。
    • 将CSS划分为多个模块或组件,便于团队协作与管理。
  2. 注释与文档

    • 在关键样式处添加注释,说明其用途和注意事项。
    • 编写详细的样式文档,帮助团队成员快速理解和使用样式库。

六、兼容性与适配性考虑

  1. 跨浏览器测试

    • 确保CSS在不同浏览器中均能正确渲染,处理潜在的兼容性问题。
    • 使用Autoprefixer等工具自动添加浏览器前缀。
  2. 响应式设计与断点设置

    • 合理规划响应式设计的断点,以适应不同屏幕尺寸和设备类型。
    • 测试各断点下的布局和样式表现,确保用户体验的一致性。

综上所述,前端CSS样式的优化涉及多个方面,包括文件大小管理、选择器优化、渲染性能提升、加载策略改进以及可维护性和兼容性考量。通过综合应用这些措施,可以显著提升网页的整体性能和用户体验。

6. 假设你是正在面试校园招聘前端开发工程师的候选人,面试官让你详细讲一讲你对于这个岗位的优势和劣势是什么?如何技术提升自己?

在面试前端开发工程师岗位时,面试官可能会要求你详细说明自己的优势和劣势,以及你计划如何技术提升自己。以下是对这些问题的回答:

优势

  • 技术基础扎实:我掌握了HTML、CSS和JavaScript等前端开发的基础技能,并熟悉了React、Vue等主流框架。
  • 项目经验:我有多个项目经验,包括页面优化、组件封装和性能优化等,能够独立完成复杂的前端任务。
  • 团队协作和沟通能力:我能够与团队成员有效沟通,共同解决问题,并在团队中发挥积极作用。
  • 持续学习:我具备强烈的学习意愿,能够快速掌握新技术,适应前端领域的快速发展。

劣势

  • 新技术掌握不足:虽然我对现有技术掌握较好,但对于一些新兴技术如WebAssembly、PWA等了解不够深入。
  • 时间管理:在处理多个任务时,有时难以有效管理时间,可能导致部分任务延期。

技术提升方法

  • 深入学习新技术:通过阅读文档、参加在线课程和实际项目实践,加深对WebAssembly、PWA等新技术的理解和应用。
  • 参与开源项目:通过参与开源项目,与社区成员交流,提升自己的技术水平和解决问题的能力。
  • 定期复习和总结:定期回顾所学知识,总结项目经验,形成自己的技术文档,便于日后查阅和复习。

通过上述方法,我相信能够不断提升自己的技术水平,更好地适应前端开发工程师岗位的需求。

7. 假设你是正在面试校园招聘前端开发工程师的候选人,面试官让你详细讲一讲你认为一个合格且优秀的前端开发工程师是怎么样的?核心竞争力是什么?如何努力?

面试回答:

尊敬的面试官,您好!对于“一个合格且优秀的前端开发工程师”的理解,我认为应该具备以下几个方面的特质和能力:

一、合格的前端开发工程师特质

  1. 扎实的基础知识

    • 熟练掌握HTML、CSS和JavaScript等前端基础知识。
    • 对前端工程化、组件化开发有一定了解。
  2. 良好的编码习惯

    • 编写清晰、可读性强且易于维护的代码。
    • 遵循一定的编码规范和最佳实践。
  3. 快速学习能力

    • 能够迅速掌握新技术并融入实际工作中。
    • 关注行业动态,保持与时俱进的知识更新。
  4. 基本的调试与性能优化能力

    • 能够有效利用浏览器开发者工具进行问题排查。
    • 对页面加载速度和用户体验有基本的认识和优化策略。
  5. 团队协作能力

    • 能够与其他团队成员有效沟通,协同完成任务。
    • 理解并遵循项目的整体开发流程和规范。

二、优秀的前端开发工程师特质

  1. 深厚的技术功底

    • 不仅满足于基础知识的掌握,还深入探究框架原理及底层实现。
    • 对前端领域的多个方面(如UI设计、交互逻辑、数据处理等)都有较全面的了解。
  2. 创新思维与解决问题的能力

    • 能够针对复杂问题提出创新的解决方案。
    • 在遇到技术瓶颈时,能够主动寻求突破并付诸实践。
  3. 出色的架构设计能力

    • 能够根据项目需求设计合理的前端架构,提升开发效率和维护性。
    • 熟悉模块化、组件化及服务化的开发模式。
  4. 强烈的用户体验意识

    • 始终将用户体验放在首位,关注细节并不断优化页面表现。
    • 具备良好的审美能力和交互设计感。
  5. 持续自我提升的动力

    • 不断挑战自己,追求卓越,乐于接受新的挑战和学习机会。
    • 积极参与开源项目或个人项目实践,丰富实战经验。

三、核心竞争力

我认为前端开发工程师的核心竞争力主要体现在以下几个方面:

  • 技术深度与广度并存:既要有扎实的专业基础,又要能够跨界融合,解决复杂问题。

  • 快速适应变化的能力:前端技术更新迅速,能够快速拥抱变化并转化为实际生产力至关重要。

  • 优秀的沟通与协作能力:在团队中发挥桥梁作用,促进技术交流与项目推进。

四、如何努力成为优秀的前端开发工程师

  1. 持续学习

    • 定期阅读技术文档和博客,参加线上线下技术研讨会。
    • 深入研究开源框架源码,理解其设计思想及实现细节。
  2. 实践锻炼

    • 积累实际项目经验,不断复盘总结,形成自己的方法论。
    • 尝试不同类型的项目,拓宽技术视野和应用场景。
  3. 交流分享

    • 积极参与技术社区讨论,与他人交流心得体会。
    • 定期撰写技术博客或教程,巩固所学同时帮助他人成长。
  4. 健康生活与心态

    • 保持良好的生活习惯和工作节奏,注重劳逸结合。
    • 保持积极乐观的心态,勇于面对挑战和压力。

综上所述,我认为一个合格且优秀的前端开发工程师应该是技术全面、思维敏捷、注重用户体验且持续进步的个体。通过不断努力和学习,我相信自己能够朝着这个方向不断迈进。感谢您的聆听!

8. 请尽可能详细地说明,前端中React和Vue的组件都有key这个属性,有什么区别。有什么应用场景。你的回答中不要写出示例代码。

在前端开发中,React和Vue都使用key属性来帮助管理组件列表的渲染,尤其是在列表项可能发生变化时。key属性是React和Vue中用于追踪列表中每个元素的唯一标识符,以便在重新渲染时能够高效地更新DOM。以下是React和Vue中key属性的详细说明及其区别和应用场景:

React中的key属性

在React中,key是一个特殊的字符串属性,主要用于列表渲染中。当React更新DOM时,它会尽可能地复用现有的DOM元素,以提高性能。key属性帮助React识别哪些元素被更改、添加或删除。

  • 作用

    • 提高列表渲染的性能。
    • 帮助React识别哪些元素发生了变化,从而只更新必要的部分。
  • 使用场景

    • 当渲染一个由对象数组构成的列表时。
    • 当列表中的元素顺序可能会改变时。
    • 当列表中的元素可能会被添加或删除时。
  • 注意事项

    • key应该是唯一且稳定的,通常使用数据的唯一ID。
    • 避免使用数组索引作为key,因为当列表顺序变化时,索引可能会导致错误的DOM更新。

Vue中的key属性

Vue同样使用key属性来优化列表渲染过程。Vue通过key来跟踪每个节点的身份,从而重用和重新排序现有元素。

  • 作用

    • 确保组件正确地重用和重新渲染。
    • 在列表更新时保持组件的状态(如输入框的值)。
  • 使用场景

    • v-for指令渲染列表时使用。
    • 当需要强制Vue重新渲染组件或元素时。
    • 在动态组件<component :is="...">中使用,以确保正确的组件实例被重用。
  • 注意事项

    • key应该是唯一的,通常使用唯一ID或者确保在列表中唯一的属性。
    • 在某些情况下,如表单输入组件,使用key可以帮助Vue识别并保持每个输入的状态。

React与Vue中key属性的区别

  • 语法和上下文

    • 在React中,key是直接作为JSX元素的一个属性存在。
    • 在Vue中,key通常与v-for指令一起使用,并作为指令的一个参数。
  • 对组件状态的影响

    • 在React中,如果不使用key,可能会导致组件的不必要重渲染,但不会影响组件内部的状态。
    • 在Vue中,key的使用更加严格,因为它直接影响Vue的虚拟DOM算法和组件状态的保持。
  • 性能优化

    • React依赖于key来优化DOM的diff过程,减少不必要的DOM操作。
    • Vue则利用key来确保组件的正确重用和状态的持续维护。

总的来说,无论是React还是Vue,key属性都是为了提高列表渲染的性能和准确性。开发者应该根据具体的框架特性和业务需求来合理使用key属性。

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

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

相关文章

全球IP归属地查询-IP地址查询-IP城市查询-IP地址归属地-IP地址解析-IP位置查询-IP地址查询API接口-IP查询城市-IP解析城市

IP地址查询接口是指能够返回IP地址相关信息的网络接口&#xff0c;其返回的信息通常包括IP地址的归属地&#xff08;如国家、省份、城市等&#xff09;、运营商信息以及其他技术细节。以下是一些常见的IP地址查询接口及其特点&#xff1a; 一、国内IP地址查询接口 百度IP地址查…

Burp Suite为何能抓到HTTPS的明文流量,Wireshark可以吗,公司电脑的加密流量也是被监控了吗?

在前期博文《万字图文详解HTTPS协议通信过程&#xff0c;结合抓包实战解析带你一次看透HTTPS&#xff01;》中&#xff0c;我们知悉HTTPS通信内容是用会话密钥加密的&#xff0c;但不少细心的读者存在疑问&#xff1a;为何对于使用HTTPS协议的站点&#xff0c;在Burp Suite中拦…

5.人员管理模块(以及解决运行Bug)——帝可得管理系统

目录 前言一、页面修改表单展示修改 二、新增对话框修改三、修改对话框修改修改时展示创建时间 四、解决页面展示错误五 、 解决【java.lang.NullPointerException: null】 Bug 前言 提示&#xff1a;本篇完成人员管理模块的开发&#xff0c;具体需求、修改代码的路径和最终效…

2024年国庆节有哪些必囤的好物?搜罗到了五款超实用的数码好物!

​今年国庆节好多商家推出了一系列促销的活动&#xff0c;以庆祝这一重要节日。在这举国欢腾的日子里&#xff0c;除了享受假期带来的闲暇时光&#xff0c;也是时候犒劳一下自己&#xff0c;添置一些实用的数码用品了。为此&#xff0c;我特别为您搜罗到了五款超实用的数码好物…

考研笔记之操作系统(四) - 文件管理

文件管理 1. 简介1.1 前情回顾1.2 文件的属性1.3 文件内部数据的组织方式1.4 操作系统向上提供的文件功能1.5 文件应如何放在外存 2. 文件的逻辑结构2.1 无结构文件2.2 有结构文件2.2.1 顺序文件2.2.2 索引文件2.2.3 索引顺序文件2.2.4 多级索引顺序文件 3. 文件目录3.1 基本概…

PCIe配置篇(1)——如何进行配置操作(一)

一、功能的唯一标识——BDF 首先我们简单回顾一下总线&#xff08;Bus&#xff09;、设备&#xff08;Device&#xff09;、功能&#xff08;Function&#xff09;这几个概念&#xff1a; 功能&#xff08;function&#xff09;&#xff1a;是PCI设备中独立的功能单元&#xff…

文心一言 VS 讯飞星火 VS chatgpt (364)-- 算法导论24.3 6题

六、给定有向图 G ( V , E ) G(V,E) G(V,E)&#xff0c;每条边 ( u , v ) ∈ E (u,v)∈E (u,v)∈E 有一个关联值 r ( u , v ) r(u,v) r(u,v) &#xff0c;该关联值是一个实数&#xff0c;其范围为 0 ⩽ r ( u , v ) ⩽ 1 0⩽r(u,v)⩽1 0⩽r(u,v)⩽1 &#xff0c;其代表的意…

Sleuth、Zipkin学习

系列文章目录 JavaSE基础知识、数据类型学习万年历项目代码逻辑训练习题代码逻辑训练习题方法、数组学习图书管理系统项目面向对象编程&#xff1a;封装、继承、多态学习封装继承多态习题常用类、包装类、异常处理机制学习集合学习IO流、多线程学习仓库管理系统JavaSE项目员工…

去掉最大最小值的部门平均薪水

有员工薪资表t3_salary,包含员工ID(emp_id)&#xff0c;部门ID(depart_id)&#xff0c;薪水(salary),请计算去除最高最低薪资后的平均薪水&#xff1b;&#xff08;每个部门员工数不少于3人&#xff09; CREATE TABLE t3_salary (emp_id bigint,depart_id bigint,salary decima…

使用springCache实现缓存

简介 这个springCache貌似jdk8或者以上才可以 cache最好加在controller层,毕竟返回给前端的数据,在这一步才是最完整的,缓存controller的数据才有意义配置 导入依赖 <dependency><groupId>org.springframework.boot</groupId><artifactId>spring-bo…

业务封装与映射 -- OTUk/ODUk/OPUk开销帧结构

开销是为了保证净荷正常、灵活传送所必须附加的供网络运行、管理和维护&#xff08;OAM&#xff09;使用的字节。 OTN电层开销包括OTUk开销、ODUk开销、OPUk开销、OTUCn开销、ODUCn开销、OPUCn开销和帧对齐开销。 SM开销属于OTU开销&#xff0c;占用3个字节&#xff1b;PM开销…

【HappyCoding 之前,如何做好需求分析?】

“代码没写完&#xff0c;哪有脸睡觉”&#xff1f;代码爱好者们如是说。在工作当中&#xff0c;开发者往往也要担任需求分析的角色&#xff0c;承担一些需求分析设计文档编写等工作&#xff0c;这对于一些刚入行的新手或是一些自我封闭的“代码高手”来说是比较头疼的&#xf…

用Python Turtle绘制天安门技术讲解

概述 Python的Turtle模块是一个简单的绘图库&#xff0c;它允许用户通过简单的命令控制一个小海龟在屏幕上移动&#xff0c;绘制出各种图形。本文将通过一个具体的示例——绘制简化版的天安门&#xff0c;来详细讲解如何使用Turtle模块。 环境准备 确保你的Python环境中已经…

【CF2021E】Digital Village(All Version)

题目 给你一张 n n n 个点 m m m 条边的无向图&#xff0c;有 p p p 个关键点。你需要选择 k k k 个点染黑&#xff0c;使得这 p p p 个关键点到这 k k k 个黑点的代价和最小。定义代价为两点之间边权最大的边的最小值。 你需要求出 k 1,2,…,n 的所有答案 E1 n,m,p&l…

OBOO鸥柏丨数字化展厅液晶拼接屏联动展馆触摸屏查询一体机信息化

在OBOO鸥柏精心雕琢的多媒体展厅展馆解决方案中&#xff0c;鸥柏液晶拼接屏的多屏联动互动技术犹如一条无形的数字科技纽带&#xff0c;OBOO鸥柏巧妙地将多台商用显示设备编织成一幅幅动态共生的视觉盛宴。鸥柏这项技术&#xff0c;不仅仅是简单的显示设备互联&#xff0c;鸥柏…

73.【C语言】C/C++的内存区域划分

1.内存里的几个区域 除了耳熟能详的栈区,堆区,静态区,还有内核空间,内存映射段,数据段,代码段 2.示意图 3.解释 栈区(stack area):局部变量,函数参数,返回数据,返回地址 内存映射段:将文件映射到内存 映射: 如果看过王爽老师的 《汇编语言 第四版》,其中写到了可以操作B800…

【可答疑】基于51单片机的倒车雷达测距(含仿真、代码、报告、演示视频等)

✨哈喽大家好&#xff0c;这里是每天一杯冰美式oh&#xff0c;985电子本硕&#xff0c;大厂嵌入式在职0.3年&#xff0c;业余时间做做单片机小项目&#xff0c;有需要也可以提供就业指导&#xff08;免费&#xff09;~ &#x1f431;‍&#x1f409;这是51单片机毕业设计100篇…

三、数据链路层(下)

目录 3.6以太网 以太网的分类 Mac地址 以太网数据格式 3.7互联网 数据是如何传输的&#xff1f; 3.8以太网、局域网、互联网的区别 总结&#xff1a; 3.9 vlan基本概念与基本原理 Vlan实现 划分 VLAN 例题 3.10广域网及相关协议 ppp协议 PPP协议所满足的要求 P…

【GitHub】上传文件到GitHub

参考视频&#xff1a;手把手教你在github上传文件_哔哩哔哩_bilibili 1.找到文件夹右键&#xff0c;选择open git bash here 2.完成指令 git initgit add *git commit -m "first commit"3.打开该文件夹&#xff0c;打开隐藏文件.git/config 编辑输入邮箱和GitHub用…

关于Qt音乐播放器进度条拖拽无用的问题解决方案

在使用Qt编写音乐播放器的时候&#xff0c;进度条关联播放音乐基本是必须的。那么在设计的过程中你可能会碰到一个奇怪的问题就是拖拽进度条的时候&#xff0c;可能会报错如下&#xff1a; 然后音乐就卡着不动了。。。 connect(ui->volume_toolButton,&VolumeToolBtn::…