12道前端知识题目深入浅出下JavaScript

news2025/1/11 5:06:44

在这里插入图片描述

文章目录

  • 1. 原型和原型链
  • 2. 作用域和闭包
  • 3. 高阶函数和函数式编程
  • 4. 异步编程和Promise、async/await
  • 5. 正则表达式
  • 6. 对象属性描述符和代理
  • 7. ES6+新特性如模板字符串、解构赋值、箭头函数、let/const等
  • 8. 设计模式和架构模式
    • 设计模式
    • 架构模式
  • 9. 性能优化技巧和调试技巧
    • 1. 性能优化技巧
    • 2. 调试技巧
  • 10. Node.js和NPM
  • 11. 浏览器工作原理和调试技巧
    • 浏览器的工作原理
    • 浏览器调试技巧
  • 12. Web安全知识,如XSS、CSRF等攻击
    • 1. XSS攻击(跨站脚本攻击)
    • 2. CSRF攻击(跨站请求伪造)
    • 3. 点击劫持攻击

1. 原型和原型链

原型与原型链是JavaScript面向对象编程的核心概念之一。

首先我们来介绍一下原型

  • JavaScript中,每个对象都有一个原型。
  • 原型可以理解为对象的模板或者蓝图,描述了对象应该具有的属性和方法
  • 如果对象本身没有某个属性或方法,JavaScript引擎就会在这个对象的原型链上查找,直到找到这个属性或方法为止。
  • 换句话说,对象的原型就是该对象的父对象,而引擎在查找属性或方法时会逐级查找父对象的原型,直到原型链的顶端为止。

原型链是由原型组成的一条链,它是JavaScript实现继承的重要机制。

当我们调用对象的某个属性或方法时,JavaScript引擎会首先查找对象本身是否有这个属性或方法
如果没有,就会在对象的原型上查找。如果原型也不存在该属性或方法,引擎就会在原型的原型上查找,依次类推,直到查找到Object.prototype为止。

JavaScript中,对象和函数都可以拥有原型。
每个函数都有一个prototype属性,指向该函数的原型对象。
而对象的原型可以通过Object.getPrototypeOf()方法或者__proto__属性来获取。
我们可以通过给函数的原型对象添加属性和方法,来让该函数所创建的对象都拥有这些属性和方法。
另外,我们还可以通过修改对象的原型对象来修改该对象的原型链,从而实现继承等高级特性。

下面给出一个简单的案例,演示对象、构造函数、原型和原型链的关系:

// 定义一个构造函数
function Person(name, age) {
  this.name = name;
  this.age = age;
}

// 给Person的原型对象添加方法
Person.prototype.sayHello = function() {
  console.log('Hello, my name is ' + this.name + ', and I am ' + this.age + ' years old.');
};

// 新建一个Person对象
var person = new Person('Tom', 20);

// 调用Person对象的方法
person.sayHello(); // 输出:"Hello, my name is Tom, and I am 20 years old."

// 修改Person的原型对象
Person.prototype.job = 'programmer';

// 查看person对象的原型链
console.log(person.__proto__); // 输出:Person { job: 'programmer', sayHello: [Function] }
console.log(person.__proto__.__proto__); // 输出:Object {}

在上面的例子中,我们通过定义一个构造函数Person和给它的原型对象添加方法和属性,创建了一个Person对象,利用原型链实现了方法的继承,并演示了对象的原型和原型链是JavaScript面向对象编程的核心概念之一。

2. 作用域和闭包

作用域和闭包同样是JavaScript中的核心概念。

作用域指的是代码中变量和函数的可见范围
JavaScript中有全局作用域和局部作用域两种。在全局作用域中定义的变量和函数在整个程序中都可以访问到,而在局部作用域(函数作用域或块级作用域)中定义的变量和函数只能在该作用域内访问。

变量查找时采用就近原则,即从内到外查找,最终找到全局作用域。

闭包是指有权访问另一个函数作用域中变量的函数
JavaScript中的函数可以作为值传递,当一个函数被嵌套在另一个函数中时,嵌套的内部函数就可以访问外部函数的变量。这种机制在函数式编程中非常强大,因为它允许我们将函数作为参数传递并且在函数内部访问它们的状态。

闭包是JavaScript强大的函数式编程特性之一。

在实际应用中,作用域和闭包经常结合使用。

通过闭包,我们可以在一个函数中定义变量和函数,并返回一个闭包函数,使得这些变量和函数在闭包函数执行时仍然保存着它们的状态,从而实现JavaScript中的高阶函数,这是JavaScript中相当强大的特性之一。

下面是一个简单的示例,演示作用域和闭包的使用:

// 全局作用域
var globalVar = 'global';

function outerFunction() {
  // 函数作用域
  var outerVar = 'outer';

  function innerFunction() {
    // 函数作用域
    var innerVar = 'inner';

    // 闭包
    console.log(innerVar + ' ' + outerVar + ' ' + globalVar);
  }

  return innerFunction;
}

// 返回闭包函数
var closure = outerFunction();

// 执行闭包函数
closure(); // 输出:"inner outer global"

在上面的示例中,我们定义了三个作用域:全局作用域、outerFunction函数作用域和innerFunction函数作用域。我们在innerFunction函数中使用了闭包特性访问了外部函数的变量,实现了变量跨作用域访问的功能。

3. 高阶函数和函数式编程

高阶函数和函数式编程是JavaScript中的高级编程特性,也是JavaScript语言的优势之一。

高阶函数是指可以接收函数作为参数,并且/或者返回一个函数作为结果的函数。它们可以让函数更具有灵活性和可重用性。高阶函数常常会在函数式编程中发挥重要作用。

函数式编程是一种编程范式,它将函数视为一等公民(first-class citizen),强调程序员编写可以接受其他函数作为输入并返回函数作为输出的函数。函数式编程强调作为纯函数的模块化和可组合的设计,试图避免程序状态的可变性和副作用,以提高程序的可读性、可维护性和可重用性。

下面是一个直观的例子,演示了函数式编程和高阶函数的应用:

// 定义一个函数,判断一个数字是否是奇数
function isOdd(num) {
  return num % 2 !== 0;
}

// 定义一个高阶函数,接收一个要过滤的数组和一个过滤函数作为参数
function filter(arr, fn) {
  var result = [];

  for (var i = 0; i < arr.length; i++) {
    if (fn(arr[i])) {
      result.push(arr[i]);
    }
  }

  return result;
}

// 定义一个数组
var arr = [1, 2, 3, 4, 5];

// 使用高阶函数过滤数组中的奇数
var filteredArr = filter(arr, isOdd);

console.log(filteredArr); // 输出:[1, 3, 5]

在上面的例子中,我们定义了一个isOdd函数,判断一个数字是否是奇数。我们还定义了一个filter高阶函数,接收一个数组和一个过滤函数作为参数,返回一个满足条件的新数组。最后,我们使用filter函数过滤了原数组中的奇数,得到新数组[1, 3, 5]。

该例子是函数式编程在JavaScript中的一个简单应用,以及使用高阶函数可灵活编写可重复使用的代码的一个示例。这些思想可以帮助我们简化复杂的问题,减少错误,并更好地利用计算机的处理能力

4. 异步编程和Promise、async/await

异步编程是JavaScript中的重要概念之一。

在JavaScript中,异步编程是指允许程序在等待某些操作完成的同时继续执行其他操作,从而提高程序的性能和响应速度。

JavaScript 中的异步编程通常有三种方式:

  • 回调函数
  • Promise
  • async/await。

Promise 是 ES6 中引入的一种新的异步编程方式,在实践中被广泛应用,它提供了一种更好的方式来组织异步代码。

一个 Promise 表示一个尚未完成的异步操作,它可以有三种状态:

  • pending(等待中)
  • resolved(完成)
  • rejected(异常)

在Promise中可以通过 then() 方法来指定resolved状态的处理程序,通过 catch() 方法来指定rejected状态的处理程序。

以下是一个使用 Promise 的示例,从服务器获取一个 JSON 对象:

fetch('/api/data.json')
  .then(response => response.json())
  .then(data => console.log(data))
  .catch(error => console.log(error));

async/await 是ES7 中引入的一种新的异步编程方式,它允许程序在异步操作完成前暂停执行,并使用类似同步代码的方式来处理异步代码。async/await 基于 Promise,通过 async 函数和 await 关键字实现。async/await 能够更简单、更清晰地描述异步代码,避免回调函数地狱。

以下是一个使用 async/await 的示例:

async function getData() {
  try {
    const response = await fetch('/api/data.json');
    const data = await response.json();
    console.log(data);
  } catch(error) {
    console.log(error);
  }
}

getData();

在上面的代码中,使用 async 关键字定义了一个异步函数 getData,该函数使用 await 关键字暂停程序的执行,直到获取 JSON 数据。在 try/catch 块中,使用 await 关键字等待异步操作完成,并从服务器获取请求的数据。如果出现错误,将在 catch 块中捕获它。

总之,异步编程和 Promise、async/await 是现代JavaScript中非常重要的概念和特性,不仅可以提高程序的性能和响应速度,还可以使代码更易于处理异步操作。

5. 正则表达式

正则表达式是一种用于匹配字符串中模式的工具,它可以对字符串进行分割、搜索、替换等操作,是现代计算机语言中不可或缺的一部分。

JavaScript 中,正则表达式通过 RegExp 对象来实现,它们可以使用直接量定义(/pattern/)或者通过 RegExp 构造函数来创建。正则表达式采用一种基于特定字符集的语法,可以使用一些特殊字符来表示某些特殊模式,如字符集、量词、分组等等。

以下是一些常用的正则表达式语法:

  • 字符集:用 [] 括起来表示一组可能出现的字符。例如,[aeiou] 表示匹配任意一个元音字母。
  • 特殊字符集:用特殊参数表示字符集。例如,\d 表示匹配任意数字字符,\w 表示匹配任意单词字符。
  • 量词:用 {n,m} 表示出现次数的区间,用 ? 表示可选的0或1次,用 * 表示可选的0或多次,用 + 表示至少出现一次。
  • 定位符:用 ^ 表示匹配行首,$ 表示匹配行尾。
  • 分组:用 () 表示分组,可以将子表达式分组,以便便捷地处理这些子表达式。

以下是一些示例正则表达式:

  • 匹配Email地址的正则表达式:/^[a-z0-9]+([-_.][a-z0-9]+)*@[a-z0-9]+([-_.][a-z0-9]+)*\.[a-z]{2,}$/i
  • 匹配中国大陆手机号的正则表达式:/^1[3-9]\d{9}$/
  • 匹配HTML标签的正则表达式:/<[^>]+>/g

JavaScript 中,可以使用正则表达式的函数进行字符串匹配,如 String.prototype.match()String.prototype.replace()RegExp.prototype.test() 等等。这些函数可以对字符串进行分割、搜索、替换等操作,非常便捷。

正则表达式是JavaScript中非常重要的工具和语言特性,可以为我们解决许多字符串处理的问题,但它也会带来一些复杂性,因此需要仔细学习和运用。

6. 对象属性描述符和代理

对象属性描述符是用于描述 JavaScript 对象属性特性的对象,它定义了属性的行为和操作方式

属性描述符包含以下属性:

  • configurable:该属性是否可以被改变或者属性描述符是否可以被删除。
  • enumerable:该属性是否可以被遍历。
  • value:属性的当前值,可以是任何 JavaScript 类型。
  • writable:该属性是否可以被改变。
  • get:一个函数,该函数会返回属性的值。
  • set:一个函数,该函数会设置属性的值。

以下是一个示例代码,展示了如何使用对象属性描述符:

const person = {};
Object.defineProperty(person, 'name', {
  value: 'John',
  writable: false,
  enumerable: true,
  configurable: false
});

// 这里无法修改 name 属性的值,因为 writable 为 false
person.name = 'Mike';

// 演示枚举属性
for (let key in person) {
  console.log(key, person[key]); // 输出 name John
}

在上面的示例代码中,我们定义了一个 person 对象,并在其上使用了属性描述符。设置了 name 属性的值为 John,同时指定了该属性为不可修改和不可配置的,并且可枚举。我们试图修改 name 属性的值,但因为设置了 writable 属性为 false,所以无法修改其值。

对象代理是另一个重要的概念,它允许我们在对象和其上的属性被访问或修改之前拦截这些操作。

这种使用代理对象的技术可以用于实现关于验证、日志记录、属性组合和数据绑定等功能。

以下是一个展示对象代理的示例代码:

var numbers = [1, 2, 3];
var proxy = new Proxy(numbers, {
  get(target, prop) {
    console.log(`Getting ${prop}...`);
    return target[prop];
  },
  set(target, prop, value) {
    console.log(`Setting ${prop}...`);
    target[prop] = value;
  }
});

console.log(proxy[0]); // 输出 Getting 0... 1
proxy[1] = 10; // 输出 Setting 1...
console.log(proxy); // 输出 [1, 10, 3]

在上面的示例代码中,我们首先定义了一个普通的数组,然后创建了一个代理对象。代理对象中定义了 get() 和 set() 方法,用于拦截读取和修改操作。当代理对象被读取和修改时,将分别调用 get() 和 set() 方法。

对象属性描述符和代理是JavaScript 中非常强大的工具和概念,因为它们可以让我们在代码中向对象增加更多的灵活性和兼容性,并帮助我们更好地定义和控制对象。但是,每个工具和概念都有其局限性,并需要小心地使用。

7. ES6+新特性如模板字符串、解构赋值、箭头函数、let/const等

ES6+带来了许多新特性,下面列举其中一些比较常用的:

1. 模板字符串:用反引号(`)括起来的字符串,可以使用变量、表达式和函数,以更简洁方便的方式创建字符串。

const name = 'Tom';
const age = 18;
console.log(`我的名字是${name},今年${age}`);

2. 解构赋值:用于将对象或数组中的元素提取出来,赋值给变量。这种方式可以提高代码的简洁性和可读性。

// 对象解构赋值
const person = { name: 'Tom', age: 18 };
const { name, age } = person;

// 数组解构赋值
const numbers = [1, 2, 3];
const [, second] = numbers;

3. 箭头函数:一种新的函数定义方式,可以更简短地定义函数。它可以继承父级函数的this、arguments、super等上下文。

const sum = (a, b) => a + b;
const getName = person => person.name;
const getNumber = () => 1;

4. let/const:let声明的变量具有块级作用域,在块级作用域内有效,相比var有更好的变量作用域控制,const声明的常量是不可变的,声明后不能被重新赋值。

let age = 18;
if (age === 18) {
  let firstName = 'Tom';
  const lastName = 'Smith';
}
console.log(firstName); // ReferenceError

5. Promise:用于处理异步操作的一种对象,能够更方便地处理多重回调(callback hell)。

const promise = new Promise((resolve, reject) => {
  setTimeout(() => resolve('成功'), 2000);
});
promise.then(result => console.log(result))
       .catch(error => console.log(error));

以上这些是ES6+中一些比较重要、常用的新特性,它们极大地拓展了JavaScript语言的能力和功能,增强了编程的灵活性和效率,进一步推动了前端技术的发展。

8. 设计模式和架构模式

设计模式和架构模式都是软件开发中的重要概念。

设计模式是一种解决常见问题的模式化思维方式。它通过使用先前已经设计和测试过的方案来解决新的问题,从而提高代码的可维护性和可重用性。设计模式通常包括创建型、结构型和行为型三种类型,如单例模式、工厂模式、适配器模式、观察者模式等等。

架构模式是一种更高级的设计模式,它通过定义系统中主要组件之间的关系和通信来指导软件系统的开发。架构模式旨在实现可扩展性、可重用性、可靠性、可维护性和安全性等特性,是一种广泛用于构建大型软件系统的面向对象设计方法。常见的架构模式有MVC、MVP、MVVM、微服务等等。

以下是一些常见的设计模式和架构模式:

设计模式

  • 单例模式:保证一个类只有一个实例,并提供一个访问该实例的全局点。
  • 工厂模式:将实例化对象的代码移到一个工厂类中,简化了代码的复杂度,避免了客户端直接实例化对象的过程。
  • 原型模式:通过复制现有对象来创建新对象,以避免创建新对象时耗费大量时间或资源。
  • 适配器模式:将一个类的接口转换成客户端所期望的另一种接口,以兼容系统之间的兼容性问题。
  • 观察者模式:定义了一种对象之间的一对多依赖关系,使得每当一个对象状态发生改变时,其所有依赖的对象都会收到通知并自动更新。

架构模式

  • MVC模式:将一个应用程序分为三个部分:Model(模型)、View(视图)和Controller(控制器),分离了业务逻辑和视图逻辑,便于测试和维护。
  • MVP模式:Model、View和Presenter三层相互独立,Presenter作为中间者连接Model和View,使得业务逻辑和视图逻辑分离得更加彻底。
  • MVVM模式:ViewModel作为Model和View之间的联系,负责管理视图状态、与Model交互等等,使得业务逻辑和视图逻辑分离得更加清晰。
  • 微服务:采用一种独立的、分布式的服务单元来开发应用程序,并通过轻量级通信机制进行相互通信,以提高系统的可伸缩性、可维护性和容错性。

总之,设计模式和架构模式都是开发复杂软件系统的重要工具,它们为我们提供了许多有力的思考方式和解决方案,帮助我们更好地构建系统并处理各种问题。

9. 性能优化技巧和调试技巧

性能优化和调试都是前端开发中不可避免的问题,下面列举一些在优化和调试过程中比较常用的技巧:

1. 性能优化技巧

  • 减少 HTTP 请求次数:合并文件、使用精灵图、使用雪碧图、使用字体图标等方式可以减少页面的 HTTP 请求次数。
  • 使用缓存:缓存可以有效提高网站的访问速度,减少服务器负担。
  • 延迟加载:使用懒加载和图片占位符等方式可以延迟页面中某些元素的加载,提高页面的渲染速度。
  • 代码压缩:使用压缩工具对代码进行压缩,可以减少文件大小,加快页面的下载速度。
  • 使用CDN:CDN(内容分发网络)可以加速页面的加载速度,减少服务器负担。

2. 调试技巧

  • 使用控制台:利用浏览器的控制台可以方便地查看 JavaScript 的错误、网络请求和页面元素。
  • 断点调试:在代码中设置断点,可以方便地查看变量的值、代码执行顺序等情况。
  • 代码注释:在关键代码处添加注释,可以更清晰地分析代码的逻辑。
  • 使用浏览器插件:许多浏览器插件可以帮助开发人员进行调试和优化工作,如Chrome浏览器中的Inspection、YSlow、PageSpeed等插件。

以上这些是性能优化和调试过程中比较常用的技巧,但实际上还有许多其他的技巧可以帮助开发人员更好地进行管理和维护代码。

10. Node.js和NPM

Node.js是一个基于Chrome V8引擎构建的JavaScript运行环境,它可以让JavaScript代码在服务器端运行。
Node.js由Ryan Dahl于2009年创建,旨在提供一种轻量级、高效、可扩展的服务器端JavaScript运行环境。
Node.js可以高效地处理I/O操作和与网络相关的任务,并且拥有一个庞大的第三方模块库。

NPM(Node Package Manager)Node.js的官方包管理器,它是一个命令行工具,用于安装和管理Node.js的包和依赖项
NPM可以轻松地将Node.js应用程序打包成一个可复用的模块,并帮助我们在应用程序中添加和更新所需的依赖包和库。

以下是一些Node.js和NPM的常用命令:

  • Node.js命令:
    • node:启动Node.js环境,并执行JavaScript代码
    • npm:包管理工具,用于安装和管理Node.js的包和依赖项
  • NPM命令:
    • npm init:创建新的Node.js应用程序
    • npm install:安装依赖项和包
    • npm uninstall:卸载依赖项和包
    • npm update:更新依赖项和包
    • npm search:搜索和查看Node.js的包
    • npm publish:发布自己的Node.js模块

总之,Node.js和NPM已经成为一种非常流行的Web开发技术,它们为我们提供了一个快速、高效、可靠的开发环境,并使得在服务器端使用JavaScript成为了一种非常简单和方便的方式。

11. 浏览器工作原理和调试技巧

浏览器是Web前端开发中最重要的工具之一,下面简单介绍一下浏览器的工作原理和调试技巧。

浏览器的工作原理

  1. 输入URL:用户在浏览器地址栏中输入URL
  2. 发起请求:浏览器向服务器发送HTTP请求。
  3. 接收响应:服务器向浏览器返回HTTP响应。
  4. 解析HTML:浏览器接收到响应后,开始解析HTML文档。
  5. 构建渲染树:解析HTML文档后,浏览器将文档转换成DOM树,并创建样式和JavaScript,生成渲染树。
  6. 渲染页面:浏览器根据渲染树的信息,将网页渲染出来。

浏览器调试技巧

  1. 使用控制台:利用浏览器的控制台可以进行代码调试、页面分析、错误诊断等操作。
  2. 断点调试:在代码中设置断点,可以方便地查看变量的值、代码执行顺序等情况。
  3. 资源分析:利用资源分析工具可以查看页面中的资源文件,帮助优化页面加载速度和性能。
  4. 元素选择器:利用元素选择器可以选择要修改的元素,快速进行DOM操作。
  5. 性能分析:利用性能分析工具可以分析页面的加载速度、网络请求等性能相关信息,帮助优化代码和页面。
  6. 监听网络请求:利用网络请求跟踪工具可以方便地查看和分析网页请求,以便进行优化和调试。

总之,浏览器是Web前端开发最重要的工具之一,准确地理解浏览器的工作原理,并掌握浏览器调试技巧,可以帮助我们更有效地进行前端开发,提高代码质量和用户体验。

12. Web安全知识,如XSS、CSRF等攻击

Web安全是Web开发中非常重要的一个方面,下面介绍一些Web安全知识包括XSS、CSRF等攻击。

1. XSS攻击(跨站脚本攻击)

攻击者通过向即将在用户浏览器中执行的Web页面注入恶意脚本代码,利用浏览器对于页面内容的信任,达到攻击目的。

主要防御措施:

  • 输入过滤:对用户输入数据进行过滤和校验,防止输入恶意代码。
  • 输出编码:对于用户输入的内容,进行编码,避免解析时产生脚本攻击。

2. CSRF攻击(跨站请求伪造)

攻击者利用受害者在某个站点已经登录的身份,向该站点发起恶意请求,进行非法操作,如删帖、删库等操作

主要防御措施:

  • 验证来源:通过验证请求来源,避免来自非法站点的CSRF攻击。
  • 设置Token:在登录态中,将一个随机值作为Token传递给前端,前端以form表单的形式传递给后台,后台验证该Token有效性,避免CSRF攻击手段。

3. 点击劫持攻击

攻击者通过在网站页面中插入一个透明iframe,覆盖在用户需要点击的网页元素上,实现页面的劫持,欺骗用户盗取用户隐私信息。

主要防御措施:

  • X-FRAME-OPTIONS:在Header中增加X-FRAME-OPTIONS响应头,设置取值为DENY、SAMEORIGIN、ALLOW-FROM等,避免网页被嵌入到非法网站中。

除了上述三种攻击方式,还有许多其他的Web安全问题需要关注和防范,比如SQL注入、文件包含漏洞、信息泄露等等,因此前端开发人员需要不断学习和掌握一些安全的知识,保证Web应用的安全性。

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

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

相关文章

chatgpt赋能python:Python如何持续保存CSV文件

Python如何持续保存CSV文件 如果你需要不断更新数据并将其保存到CSV文件中&#xff0c;Python语言可以轻松完成这个任务。本文将介绍如何使用Python在代码执行的同时&#xff0c;将数据不断写入CSV文件中&#xff0c;实现持续保存的功能。 CSV文件是什么&#xff1f; CSV代表…

chatgpt赋能python:抓包是什么?

抓包是什么&#xff1f; 当我们在浏览器中访问一个网站时&#xff0c;我们的电脑会向网络服务器发送请求并接收响应。这个过程中&#xff0c;有一些工具可以让我们查看和分析这些请求和响应&#xff0c;其中最常用的就是“抓包”。 抓包就是指截获网络通信过程中的数据包并分…

chatgpt赋能python:Python怎么指定循环次数?

Python怎么指定循环次数&#xff1f; Python是一种广泛应用于编程领域的高级编程语言&#xff0c;它具有简单易学、代码可读性强、语言编写规范等诸多优点。其中&#xff0c;循环是Python语法中的重要一环&#xff0c;而如何指定循环次数则是其中一个重要的问题。 什么是循环…

Linux 检测通信路径上的PMTU(路径最大传输单元)

问题描述 终端设备向云端POST数据&#xff0c;数据量较小的没有问题&#xff0c;数据量大的必然出现丢包。网络很通畅&#xff0c;延迟较低。 分析 后来发现&#xff0c;终端到云端的通信路径上某个路由器节点的MTU小于终端的MTU&#xff0c;当终端发出的IP数据包长度大于该…

力扣题库刷题笔记4--寻找两个正序数组的中位数

1、题目如下&#xff1a; 2、个人Python代码实现如下&#xff1a; 代码如下&#xff1a; class Solution: def findMedianSortedArrays(self, nums1: List[int], nums2: List[int]) -> float: nums nums1 nums2 #合并数组 nums.sort() …

java【toString覆写】

笔试题 输出结果&#xff1a;D.func(),num0 解析&#xff1a; 继承的原则&#xff0c;先调用父类的无参构造&#xff0c;因此调用func()函数func() 此方法&#xff0c;new 的是 D 的对象&#xff0c;且被D所重写&#xff0c;触发动态绑定&#xff0c;直接调用D中的func()方法在…

Jupyter Notebook是什么及使用

一、什么是Jupyter Notebook Jupyter项目是一个非盈利的开源项目&#xff0c;源于2014年的python项目&#xff0c; Juptter Notebook&#xff0c;原名IPython Notbook&#xff0c;是IPython的加强网页版&#xff0c;一个开源web应用程序名字源自Julia、Python和R是一款程序员…

CRC校验(1):CRC原理、计算例子和最优多项式的选择

CRC(Cyclic Redundancy Check)&#xff0c;即循环冗余校验&#xff0c;它通过计算生成固定长度的校验码&#xff0c;用于验证数据在传输过程中是否发生了错误或损坏&#xff0c;从而确保数据的完整性。假设我们想把小写字母z发送出去。在Unicode中&#xff0c;z由数字0x7A表示&…

这有可能是国内最有趣的大学生知识交流社区了吧?

WRITE-BUG数字空间&#xff08;http://www.writebug.com&#xff09;内测 WRITE-BUG创建于2019年&#xff0c;创始团队主要来自于清华大学、中国人民大学等国内高校学生。运营至今&#xff0c;已累积100000注册用户&#xff0c;91%是18-24岁在校大学生&#xff0c;覆盖国内绝大…

前端vue基于秋云 ucharts echarts词云图 多重圆弧进度条 弧形进度条

前端vue基于秋云 ucharts echarts词云图 多重圆弧进度条 弧形进度条 进度条 弧形进度条 圆形进度条 词云图&#xff0c; 下载完整代码请访问uni-app插件市场地址:https://ext.dcloud.net.cn/plugin?id13029 效果图如下: #### 使用方法 使用方法 <!-- 关键字 --> &l…

java设计模式之:代理模式

文章目录 简介静态代理动态代理Cglib代理spring中AOP使用代理总结 简介 代理(Proxy)模式是一种结构型设计模式&#xff0c;提供了对目标对象另外的访问方式&#xff1b;即通过代理对象访问目标对象。 这样做的好处是&#xff1a;可以在目标对象实现的基础上&#xff0c;增强额…

注意力机制和Transformer

注意力机制和Transformer 机器翻译是NLP领域中最重要的问题之一&#xff0c;也是Google翻译等工具的基础。传统的RNN方法使用两个循环网络实现序列到序列的转换&#xff0c;其中一个网络&#xff08;编码器&#xff09;将输入序列转换为隐藏状态&#xff0c;而另一个网络&…

【探测器】win10网卡设置巨型帧解决探测器无法成像的问题

【探测器】win10网卡设置巨型帧解决探测器无法成像的问题 1、背景2、解决办法3、补充说明 1、背景 探测器很奇怪的叫法&#xff0c;其实就是相机。 大家在安防领域&#xff0c;智慧工厂&#xff0c;智慧学校、智慧工地等经常会看到海康、大华的网络摄像头&#xff0c; 这些摄像…

软考高级架构师笔记-7信息安全

目录 1. 前言 & 考情分析2. 信息安全1. 信安基础知识2. 信息安全系统的组成框架3. 信息安全技术4. 信息安全的抗攻击技术5. 信息安全的保证体系和评估方法3. 网络安全4. 网络安全协议1. 前言 & 考情分析 前文回顾: 软考高级架构师笔记-1计算机硬件软考高级架构师笔记…

集成测试总结

集成测试 基本概念&#xff1a;将软件集成起来后进行测试。集成测试又叫子系统测试、组装测试、部件测试等。集成测试主要是针对软件高层设计进行测试&#xff0c;一般来说是以模块和子系统为单位进行测试。 集成测试包含的层次&#xff1a; 模块内的集成&#xff0c;主要是测…

【编译、链接、装载六】汇编——目标文件

【编译和链接六】汇编——目标文件 一、目标文件_存储格式1、生成目标文件2、目标文件存储格式3、file查看文件格式 二、查看目标文件的内部结构——objdump三、代码段四、 数据段和只读数据段五、 ELF文件结构描述1、头文件2、段表2.1、重定位表2.2、字符串表2.3、查看重定位表…

信号完整性:反射 初步认识

反射是怎么形成的 信号的反射和互连线的阻抗密切相关。反射的最直接原因是互连线的阻抗发生了突然变化&#xff0c;只要互连线的阻抗不连续的点&#xff0c;该处就会发生反射。 信号是以电磁波的形式在走线中传播的&#xff0c;如果从传统的电路理论角度去看&#xff0c;是无…

ZipList(压缩链表)

基本概述 ZipList 是一种特殊的“双端链表” &#xff0c;由一系列特殊编码的连续内存块组成。可以在任意一端进行压入/弹出操作, 并且该操作的时间复杂度为 O(1)。 基本结构&#xff1a; 各部分所占字节、基本介绍&#xff1a; entry&#xff0c;节点占用字节不固定&#xff0…

计算机图形学与opengl C++版 学习笔记 第9章 天空和背景

目录 9.1 天空盒9.2 天空穹顶9.3 实现天空盒9.3.1 从头开始构建天空盒9.3.2 使用OpenGL立方体贴图 9.4 环境贴图补充说明 对于室外3D场景&#xff0c;通常可以通过在地平线上创造一些逼真的效果&#xff0c;来增强其真实感。当我们极目远眺&#xff0c;目光越过附近的建筑和森林…

【认知提升思维篇】之 心智模式--人类的行为纪元

&#x1f468;‍&#x1f4bb;个人主页&#xff1a;元宇宙-秩沅 &#x1f468;‍&#x1f4bb; hallo 欢迎 点赞&#x1f44d; 收藏⭐ 留言&#x1f4dd; 加关注✅! &#x1f468;‍&#x1f4bb; 本文由 秩沅 原创 &#x1f468;‍&#x1f4bb; 收录于专栏&#xff1a;普本…