Web前端-JavaScript(js表达式)

文章目录

  • JavaScript基础第01天
    • 1.编程语言概述
      • 1.1 编程
      • 1.2 计算机语言
        • 1.2.1 机器语言
        • 1.2.2 汇编语言
        • 1.2.3 高级语言
      • 1.4 翻译器
    • 2.计算机基础
      • 2.1 计算机组成
      • 2.2 数据存储
      • 2.3 数据存储单位
      • 2.4 程序运行
    • 3.初始JavaScript
      • 3.1 JavaScript 是什么
      • 3.2 JavaScript的作用
      • 3.3 HTML/CSS/JS 的关系
      • 3.4 浏览器执行 JS 简介
      • 3.5 JS 的组成
        • **ECMAScript**
        • DOM
        • BOM
      • 3.6 JS 初体验
    • 4.JavaScript注释
      • 4.1 单行注释
      • 4.2 多行注释
    • 5.JavaScript输入输出语句
    • 6.变量的概念
      • 6.1 什么是变量
      • 6.2 变量在内存中的存储
    • 7.变量的使用
      • 7.2 赋值
      • 7.3 变量的初始化
      • 7.4 变量语法扩展
      • 7.5 变量命名规范
      • 7.6 关键字和保留字
        • 关键字
        • 保留字
    • 8.数据类型
      • 8.1 数据类型简介
      • 8.2 简单数据类型
        • 数字型 Number
        • 字符串型 String
        • 布尔型Boolean
        • Undefined和 Null
      • 8.3 获取变量数据类型
      • 8.4 数据类型转换
        • 转换为字符串
        • 转换为数字型
        • 转换为布尔型

JavaScript基础第01天

1.编程语言概述

1.1 编程

  • 编程:
    • 就是让计算机为解决某个问题而使用某种程序设计语言编写程序代码,并最终得到结果的过程。

1.2 计算机语言

  • 计算机语言的种类非常的多,总的来说可以分成机器语言汇编语言高级语言三大类。
1.2.1 机器语言

​ 实际上计算机最终所执行的都是 机器语言,它是由“0”和“1”组成的二进制数,二进制是计算机语言的基础。

image-20230217165446594

1.2.2 汇编语言

汇编语言和机器语言实质是相同的,都是直接对硬件操作,只不过指令采用了英文缩写的标识符,容易识别和记忆。

image-20230217170559708
1.2.3 高级语言

高级语言包括了很多编程语言,常用的有C语言、C++、Java、C#、Python、PHP、JavaScript、Go语言等。

image-20230217170700202

1.4 翻译器

高级语言所编制的程序不能直接被计算机识别,必须经过转换才能被执行,为此,我们需要一个翻译器。翻译器可以将我们所编写的源代码转换为机器语言。

image-20230217170757751

2.计算机基础

2.1 计算机组成

  1. 硬件

    1. CPU
    2. 硬盘
    3. 内存
  2. 软件

    1. QQ
    2. 谷歌浏览器
    image-20230217214311280

2.2 数据存储

  1. 计算机内部使用二进制 0 和 1来表示数据。
  2. 所有数据,包括文件、图片等最终都是以二进制数据(0 和 1)的形式存放在硬盘中的。
  3. 硬盘、内存都是保存的二进制数据。

2.3 数据存储单位

bit < byte < kb < GB < TB<PB<EB<ZB<YB<BB<NB<DB<CB<XB
  • 位(bit): 1bit 可以保存一个 0 或者 1 (最小的存储单位)

  • 字节(Byte):1Byte = 8b 1Byte可以保存一个英文字母或者是1个数字,汉字是2个字节

  • 千字节(KB):1KB = 1024B

  • 兆字节(MB):1MB = 1024KB

  • 吉字节(GB): 1GB = 1024MB

  • 太字节(TB): 1TB = 1024GB

    image-20230217214353660

2.4 程序运行

image-20230217214437671

计算机运行软件的过程:

  1. 打开某个程序时,先从硬盘中把程序的代码加载到内存中
  2. CPU执行内存中的代码

3.初始JavaScript

3.1 JavaScript 是什么

image-20230217214530560

https://baike.baidu.com/item/%E5%B8%83%E5%85%B0%E7%99%BB%C2%B7%E8%89%BE%E5%A5%87/58101949?fr=aladdin&fromtitle=Brendan%20Eich&fromid=561441

  • JavaScript 是世界上最流行的语言之一,是一种运行在客户端的脚本语言 (Script 是脚本的意思)
  • 脚本语言:不需要编译,运行过程中由 js 解释器( js 引擎)逐行来进行解释并执行

3.2 JavaScript的作用

  • 表单动态校验(密码强度检测) ( JS 产生最初的目的 )
  • 网页特效
  • 服务端开发(Node.js)
  • 桌面程序(Electron)
  • 游戏开发(cocos2d-js)

3.3 HTML/CSS/JS 的关系

  1. html:网页的基本结构

  2. css:网页样式美化

  3. js:网页的行为

3.4 浏览器执行 JS 简介

浏览器分成两部分:渲染引擎和 JS 引擎

image-20230217220024303

浏览器本身并不会执行JS代码,而是通过内置 JavaScript 引擎(解释器) 来执行 JS 代码 。

JS 引擎执行代码时逐行解释每一句源码(转换为机器语言),然后由计算机去执行。

3.5 JS 的组成

  1. ECMAScript:Javascript基础语法

  2. DOM:文档对象模型

  3. BOM:浏览器对象模型

  4. ECMAScript
     	ECMAScript 是由ECMA 国际( 原欧洲计算机制造商协会)进行标准化的一门编程语言,这种语言在万维网上应用广泛,
    

    JavaScript是 ECMAScript 语言的实现和扩展。

    ECMAScript:规定了JS的编程语法和基础核心知识,是所有浏览器厂商共同遵守的一套JS语法工业标准。

  5. DOM
     	**文档对象模型**(DocumentObject Model,简称DOM),是W3C组织推荐的处理可扩展标记语言的标准编程接口。通过 DOM 提供的接口可以对页面上的各种元素进行操作(大小、位置、颜色等)
    
  6. BOM
     	**浏览器对象模型**(Browser Object Model,简称BOM) 是指浏览器对象模型,它提供了独立于内容的、可以与浏览器窗口进行互动的对象结构。通过BOM可以操作浏览器窗口,比如弹出框、控制浏览器跳转、获取分辨率等。
    

3.6 JS 初体验

​ JS 有3种书写位置,分别为行内、内嵌和外部。

  1. 行内式

    <input type="button" value="点我试试" onclick="alert('Hello World')" />
    
    • 可读性差, 在html中编写JS大量代码时,不方便阅读;
    • 引号易错,引号多层嵌套匹配时,非常容易弄混;
  2. 内嵌式

    <script>alert('Hello  World~!');
    </script>
    
    • 可以将多行JS代码写到 script 标签中
    • 内嵌 JS 是学习时常用的方式
  3. 外部JS文件

    <script src="my.js"></script>
    
    • 利于HTML页面代码结构化,把大段 JS代码独立到 HTML 页面之外,既美观,也方便文件级别的复用

    • 引用外部 JS文件的 script 标签中间不可以写代码

    • 适合于JS 代码量比较大的情况

4.JavaScript注释

4.1 单行注释

  • 单行注释的注释方式如下:
// 用来注释单行文字(  快捷键   ctrl  +  /   )

4.2 多行注释

  • 多行注释的注释方式如下:
/* */  用来注释多行文字( 默认快捷键  alt +  shift  + a ) 

5.JavaScript输入输出语句

  • 为了方便信息的输入输出,JS中提供了一些输入输出语句,其常用的语句如下:
方法说明归属
alert(msg)浏览器弹出警示框浏览器
console.log(msg)浏览器控制台打印输出信息浏览器
prompt(info)浏览器弹出输入框,用户可以输入浏览器
  • 注意:alert() 主要用来显示消息给用户,console.log() 用来给程序员自己看运行时的消息。

6.变量的概念

6.1 什么是变量

  • 要知道的

    程序处理的是数据,数据存储在内存中

  • 什么是变量

    变量是计算机内存中存储数据的标识符,根据变量名称可以获取到内存中存储的数据

  • 为什么要使用变量

    使用变量可以方便的获取或者修改内存中的数据

  • 白话:变量就是一个装东西的盒子。
    image-20230217221739184

6.2 变量在内存中的存储

image-20230217221834676

7.变量的使用

  • 7.1 声明变量
 var age;
  • var 是一个 JS关键字,用来声明变量( variable 变量的意思 )。

  • age 是程序员定义的变量名,我们要通过变量名来访问内存中分配的空间

7.2 赋值

age = 10; 
  • = 用来把右边的值赋给左边的变量空间中 此处代表赋值的意思

7.3 变量的初始化

var age  = 18; 

7.4 变量语法扩展

  • 更新变量

var age = 18;
age = 81;


- 同时声明多个变量同时声明多个变量时,只需要写一个 var, 多个变量名之间使用英文逗号隔开。```js
var age = 10, name = 'zs', sex = 2;       
  • 声明变量特殊情况

    情况说明结果
    var age ; console.log (age);只声明 不赋值undefined
    console.log(age)不声明 不赋值 直接使用报错
    age = 10; console.log (age);不声明 只赋值,不建议使用10

7.5 变量命名规范

规则:

  • 由字母(A-Za-z)、数字(0-9)、下划线(_)、美元符号( $ )组成,如:usrAge, num01, _name

  • 严格区分大小写。var app; 和 var App; 是两个变量

  • 不能 以数字开头。 18age 是错误的

  • 不能 是关键字、保留字。例如:var、for、while

  • 变量名必须有意义。

  • 遵守驼峰命名法。首字母小写,后面单词的首字母需要大写。myFirstName

    image-20230217221959115

7.6 关键字和保留字

关键字
关键字:是指 JS本身已经使用了的字,不能再用它们充当变量名、方法名。包括:break、case、catch、continue、default、delete、do、else、finally、for、function、if、in、instanceof、new、return、switch、this、throw、try、typeof、var、void、while、with 等。
保留字

现阶段版本未使用,但以后版本可能会作为关键字使用,所以也要避免使用这些保留字(goto)当标识符

8.数据类型

8.1 数据类型简介

  • 为什么需要数据类型

    在计算机中,不同的数据所需占用的存储空间是不同的,为了便于把数据分成所需内存大小不同的数据,充分利用存储空间,

    于是定义了不同的数据类型。

  • 变量的数据类型

      	JavaScript 是一种弱类型或者说动态语言。这意味着不用提前声明变量的类型,在程序运行过程中,类型会被自动确定:
    
    var age = 10;        // 这是一个数字型
    var userName = '码上未来';   // 这是一个字符串     
    
  • 数据类型的分类

    JS 把数据类型分为两类:

    • 简单数据类型 (Number,String,Boolean,Undefined,Null)

    • 复杂数据类型 (Object, Array, function)

8.2 简单数据类型

  • 简单数据类型(基本数据类型)

  • JavaScript 中的简单数据类型及其说明如下:

    简单数据类型说明默认值
    Number数字型,整型和浮点型,24、24.1、24.00
    Boolean布尔型,true、false、等价于1和0false
    String字符串,“张三”,表示文本“”
    Undefinedvar a; 声明了,但是没赋值,此时结果就是undefinedundefined
    Nullvar a = null;把null值赋予给了a,后面课程会详细讲到什么是nullnull
数字型 Number

​ JavaScript 数字类型既可以保存整数,也可以保存小数(浮点数)。

var age = 21;      
var Age = 21.3747;
var PI = 3.141592653     

数字型范围

JavaScript中数值的最大和最小值

  • 最大值:Number.MAX_VALUE,这个值为: 1.7976931348623157e+308

  • 最小值:Number.MIN_VALUE,这个值为:5e-324

  • console.log(Number.MIN_VALUE);
    console.log(Number.MAX_VALUE);
    
  1. 数字型三个特殊值

    • Infinity ,代表无穷大,大于任何数值

    • -Infinity ,代表无穷小,小于任何数值

    • NaN ,Not a number,代表一个非数值

  2. isNaN

    用来判断一个变量是否为非数字的类型,返回 true 或者 false

    image-20230217222653230
var userName = 'andy';
var isOk = isNaN(userName);
console.log(isOk);      // true ,"andy"是一个非数字
字符串型 String

​ 字符串型可以是引号中的任意文本,其语法为 双引号 “” 和 单引号’’

var strMsg = "我爱北京天安门~";  // 使用双引号表示字符串
var strMsg2 = '我爱吃猪蹄~';    // 使用单引号表示字符串
// 常见错误
var strMsg3 = 我爱大肘子;       // 报错,没使用引号,会被认为是js代码,但js没有这些语法

​ 因为 HTML 标签里面的属性使用的是双引号,JS 这里我们更推荐使用单引号。

  1. 字符串引号嵌套

    ​ JS 可以用单引号嵌套双引号 ,或者用双引号嵌套单引号 (外双内单,外单内双)

    var strMsg = '我是"高帅富"程序猿';   // 可以用''包含""
    var strMsg2 = "我是'高帅富'程序猿";  // 也可以用"" 包含''
    //  常见错误
    var badQuotes = 'What on earth?"; // 报错,不能 单双引号搭配
    
  2. 字符串转义符

    ​ 类似HTML里面的特殊字符,字符串中也有特殊字符,我们称之为转义符。

    | 转义符 | 解释说明 |
    | ------ | --------------------------------- |
    | \n | 换行符,n 是 newline 的意思 |
    | \ \ | 斜杠 \ |
    | ’ | ’ 单引号 |
    | " | ”双引号 |
    | \t | tab 缩进 |

  3. 字符串长度

    ​ 字符串是由若干字符组成的,这些字符的数量就是字符串的长度。通过字符串的 length 属性可以获取整个字符串的长度。

    var strMsg = "我是帅气多金的程序猿!";
    alert(strMsg.length); 
    
  4. 字符串拼接

    • 多个字符串之间可以使用 + 进行拼接,其拼接方式为 字符串 + 任何类型 = 拼接之后的新字符串

    • 拼接前会把与字符串相加的任何类型转成字符串,再拼接成一个新的字符串

      //1.1 字符串 "相加"
      alert('hello' + ' ' + 'world'); // hello world
      //1.2 数值字符串 "相加"
      alert('100' + '100'); // 100100
      //1.3 数值字符串 + 数值
      alert('11' + 12);     // 1112 
      
      • + 号总结口诀:数值相加 ,字符相连
  5. 字符串拼接加强

    console.log('小明' + 18);        // 只要有字符就会相连 
    var age = 18;
    console.log('小明age岁啦');      // 这样不行哦
    console.log('小明' + age);         
    
布尔型Boolean

​ 布尔类型有两个值:true 和 false ,其中 true 表示真(对),而 false 表示假(错)。

​ 布尔型和数字型相加的时候, true 的值为 1 ,false 的值为 0。

console.log(true + 1);  // 2
console.log(false + 1); // 1
Undefined和 Null

​ 一个声明后没有被赋值的变量会有一个默认值undefined ( 如果进行相连或者相加时,注意结果)

var variable;
console.log(variable);           // undefined
console.log('你好' + variable);  // 你好undefined
console.log(11 + variable);     // NaN
console.log(true + variable);   //  NaN

​ 一个声明变量给 null 值,里面存的值为空(学习对象时,我们继续研究null)

var vari = null;
console.log('你好' + vari);  // 你好null
console.log(11 + vari);     // 11
console.log(true + vari);   //  1

8.3 获取变量数据类型

  • 获取检测变量的数据类型

    ​ typeof 可用来获取检测变量的数据类型

    var num = 18;
    console.log(typeof num) // 结果 number      
    

    ​ 不同类型的返回值

    image-20230217222840783

8.4 数据类型转换

​ 什么是数据类型转换?

​ 使用表单、prompt 获取过来的数据默认是字符串类型的,此时就不能直接简单的进行加法运算,而需要转换变量的数据类型。通俗来说,就是把一种数据类型的变量转换成另一种数据类型,通常会实现3种方式的转换:

  1. 转换为字符串类型
  2. 转换为数字型
  3. 转换为布尔型
转换为字符串

image-20230217222915350

  • 三种转换方式,更多第三种加号拼接字符串转换方式, 这一种方式也称之为隐式转换。

  •     var a = 123;console.log(typeof String(a))//stringconsole.log(typeof (a.toString()))//stringvar c = a + '123'console.log(typeof c)//string
    
转换为数字型
image-20230217222938963

**parseInt()**转换注意点:

1.如果带有小数,转换时去掉小数,但不是四舍五入

2.特性:如果第一个为数字则继续解析,直到遇到字符停止解析

    var str = "123";str = parseInt(str)console.log(typeof str)//numberconsole.log(str)//123console.log(parseInt("码上未来"))//NaN   var num = parseInt("123.456")console.log(num)//123   会舍弃小数点var num1 = parseInt("123abc456")console.log(num1)//123 遇到abc这种字符就停止解析,后面有数字也不解析了

**parseFloat()**转换注意点:

与parseInt()一样,但是可以保留小数

    var str1 = "123.456";str1 = parseFloat(str1)console.log(typeof str1)//numberconsole.log(str1)//123.456

**Number()**转换注意点:

1.如果转换的内容可以转换成数字,那么就直接返回这个内容的数字

2.如果不可以转换比如是string类型文本,返回NaN

3.如果在内容中出现小数,那么小数会保留

4.如果内容为空,那么转换为0;

    var str2 = "";str2 = Number(str2)console.log(typeof str2)//number console.log(str2)//123console.log(Number(''))//0 

隐式转换是我们在进行算数运算的时候,JS 自动转换了数据类型

    console.log('6' + "2")//62 字符串拼接console.log('6' - "2")//4 隐式转换console.log('6' * "2")//12 隐式转换console.log('6' / "2")//3 隐式转换console.log('6' % "2")//0 隐式转换
转换为布尔型
  • 代表空、否定的值会被转换为 false ,如 ‘’、0、NaN、null、undefined

  • 其余值都会被转换为 true

    console.log(Boolean('')); // false
    console.log(Boolean(0)); // false
    console.log(Boolean(NaN)); // false
    console.log(Boolean(null)); // false
    console.log(Boolean(undefined)); // false
    console.log(Boolean('小白')); // true
    console.log(Boolean(12)); // true
    

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

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

相关文章

《点云处理》平面拟合

前言 在众多点云处理算法中&#xff0c;其中关于平面拟合的算法十分广泛。本篇内容主要是希望总结归纳各类点云平面拟合算法&#xff0c;并且将代码进行梳理保存。 环境&#xff1a; VS2019 PCL1.11.1 1.RANSAC 使用ransac对平面进行拟合是非常常见的用法&#xff0c;PCL…

医疗智能化革命:AI技术引领医疗领域的创新进程

一、“AI”医疗的崛起 随着人工智能&#xff08;AI&#xff09;技术的崛起&#xff0c;"AI"医疗正在以惊人的速度改变着医疗行业的面貌。AI作为一种强大的工具&#xff0c;正在为医疗领域带来前所未有的创新和突破。它不仅在医学影像诊断、病理学分析和基因组学研究等…

设计模式——状态模式

引言 状态模式是一种行为设计模式&#xff0c; 让你能在一个对象的内部状态变化时改变其行为&#xff0c; 使其看上去就像改变了自身所属的类一样。 问题 状态模式与有限状态机 的概念紧密相关。 其主要思想是程序在任意时刻仅可处于几种有限的状态中。 在任何一个特定状态中…

手拉手EasyExcel极简实现web上传下载(全栈)

环境介绍 技术栈 springbootmybatis-plusmysqleasyexcel 软件 版本 mysql 8 IDEA IntelliJ IDEA 2022.2.1 JDK 1.8 Spring Boot 2.7.13 mybatis-plus 3.5.3.2 EasyExcel是一个基于Java的、快速、简洁、解决大文件内存溢出的Excel处理工具。 他能让你在不用考虑性…

CentOS7安装教程

1.准备工作 安装虚拟机软件 VMware Workstation 17 Player下载CentOS7 镜像 2. 安装VMware Workstation 17 Player 官网 下载链接 下载好了安装包&#xff0c;双击安装包&#xff0c;傻瓜式安装一直下一步&#xff0c;安装即可。 3. 安装CentOS7 官网 推荐下载地址&…

Tekton 构建容器镜像

Tekton 构建容器镜像 介绍如何使用 Tektonhub 官方 kaniko task 构建docker镜像&#xff0c;并推送到远程dockerhub镜像仓库。 kaniko task yaml文件下载地址&#xff1a;https://hub.tekton.dev/tekton/task/kaniko 查看kaniko task yaml内容&#xff1a; 点击Install&…

RabbitMQ 消息持久化

默认情况下&#xff0c;exchange、queue、message 等数据都是存储在内存中的&#xff0c;这意味着如果 RabbitMQ 重启、关闭、宕机时所有的信息都将丢失。 RabbitMQ 提供了持久化来解决这个问题&#xff0c;持久化后&#xff0c;如果 RabbitMQ 发送 重启、关闭、宕机&#xff…

05 动态渲染数据

概述 实际上动态渲染数据&#xff0c;在《使用CDN开发Vue3项目》中就已经学习过了&#xff0c;核心代码如下&#xff1a; <div id"vue-app">{{text}}</div> <script src"https://cdn.staticfile.org/vue/3.0.5/vue.global.js"></sc…

【运维笔记】Hyperf正常情况下Xdebug报错死循环解决办法

问题描述 在使用hyperf进行数据库迁移时&#xff0c;迁移报错&#xff1a; 查看报错信息&#xff0c;错误描述是Xdebug检测到死循环&#xff0c;可是打印的堆栈确实正常堆栈&#xff0c;没看到死循环。 寻求解决 gpt 说的跟没说一样。。 google一下 直接把报错信息粘贴上去…

I.MX RT1170双核学习(3):多核管理之MCMGR源码分析详解

本文通过SDK中最简单的hello_world例程来说明一下双核程序如何运行。在CM7和CM4的工程中都有一个MCMGR(Multicore Manager)文件夹&#xff0c;它是用来管理多核之间的操作的&#xff0c;当然也包括我们前面提到的那些寄存器的设置。 文章目录 1 MCMGR_EarlyInit1.1 MCMGR_Trigg…

MFC 程序执行流程

目录 MFC 程序启动 MFC 入口函数 程序执行流程总结 在Win32课程中WinMain由程序员自己实现&#xff0c;那么流程是程序员安排&#xff0c;但到了MFC中&#xff0c;由于MFC库实现WinMain&#xff0c;也就意味着MFC负责安排程序的流程。 MFC 程序启动 程序的启动&#xff0c;…

PCB设计规则中的经验公式_笔记

PCB设计规则中的经验公式 规则1 - 临界长度规则2 - 信号带宽与上升时间规则3- 时钟信号带宽规则4-信号传输速度规则5- 集肤 (效应) 深度规则6 - 50Ω传输线电容规则7 - 50Ω传输线电感规则8 - 回流路径电感规则9 - 地弹噪声规则10- 串行传输比特率与信号带宽规则11- PCB走线直流…

HIVE窗口函数

什么是窗口函数 hive中开窗函数通过over关键字声明&#xff1b;窗口函数&#xff0c;准确地说&#xff0c;函数在窗口中的应用&#xff1b;比如sum函数不仅可在group by后聚合&#xff0c;在可在窗口中应用&#xff1b; hive中groupby算子和开窗over&#xff0c;shuffle的逻辑…

面试 Java 算法高频题五问五答第一期

面试 Java 算法高频题五问五答第一期 作者&#xff1a;程序员小白条&#xff0c;个人博客 相信看了本文后&#xff0c;对你的面试是有一定帮助的&#xff01; ⭐点赞⭐收藏⭐不迷路&#xff01;⭐ 1&#xff09;括号生成: 数字 n 代表生成括号的对数&#xff0c;请你设计一个…

OpenSergo Dubbo 微服务治理最佳实践

*作者&#xff1a;何家欢&#xff0c;阿里云 MSE 研发工程师 Why 微服务治理&#xff1f; 现代的微服务架构里&#xff0c;我们通过将系统分解成一系列的服务并通过远程过程调用联接在一起&#xff0c;在带来一些优势的同时也为我们带来了一些挑战。 如上图所示&#xff0c;可…

C语言之枚举类型

目录 枚举类型 枚举常量 枚举类型的特征 命名空间 本节我们来学习表示一定整数值的集合的枚举类型。 枚举类型 老样子&#xff0c;我们先用一段程序引出&#xff1a; /*显示所选动物的叫声*/ #include<stdio.h>enum animal {Dog, Cat, Monkey, Invalid}; /*显示狗叫…

Zotero攻略

给大家分享一下我对于Zotero的使用。 1、下载链接 Zotero | Your personal research assistant 进入后直接下载即可 2、一些好用的插件 &#xff08;1&#xff09;Zotero Connector 下载地址&#xff1a;Zotero | Connectors 超级好用&#xff01;不用一篇一篇下PDF了&am…

Redis设计与实现之事务

一、事务 Redis 通过 MULTI 、DISCARD 、EXEC 和 WATCH 四个命令来实现事务功能&#xff0c;本章首先讨 论使用 MULTI 、DISCARD 和 EXEC 三个命令实现的一般事务&#xff0c;然后再来讨论带有 WATCH 的事务的实现。 因为事务的安全性也非常重要&#xff0c;所以本章最后通过…

18个非技术面试题

请你自我介绍一下你自己&#xff1f; 这道面试题是大家在以后面试过程中会常被问到的&#xff0c;那么我们被问到之后&#xff0c;该如果回答呢&#xff1f;是说姓名&#xff1f;年龄&#xff1f;还是其他什么&#xff1f; 最佳回答提示&#xff1a; 一般人回答这个问题往往会…

neuq-acm预备队训练week 9 P1119 灾后重建

解题思路 本题可以用最短路算法——Floyd AC代码 #include<bits/stdc.h> #define inf 1e9 using namespace std; const int N 2e2 50; int n, m, q, now 0, a, b, c, t[N], G[N][N];int main() {scanf("%d%d", &n, &m);for(int i 0;i<n;i)sc…