2. Java基本语法

news2025/1/23 15:03:23

文章目录

  • 2. Java基本语法
    • 2.1 关键字保留字
      • 2.1.1 关键字
      • 2.1.2 保留字
      • 2.1.3 标识符
      • 2.1.4 Java中的名称命名规范
    • 2.2 变量
      • 2.2.1 分类
      • 2.2.2 整型变量
      • 2.2.3 浮点型
      • 2.2.4 字符型 char
      • 2.2.5 Unicode编码
      • 2.2.6 UTF-8
      • 2.2.7 boolean类型
    • 2.3 基本数据类型转换
      • 2.3.1 自动类型转换
      • 2.2.2 强制类型转换
    • 2.4 进制
      • 2.4.1 128强转byte为什么是-128?
      • 2.4.2 为什么数据类型的范围是-2^n^~2^n^-1?
      • 2.4.3 进制之间转换
    • 2.5.运算符
      • 2.5.1 算术运算符
      • 2.5.2 赋值运算符
      • 2.5.3 比较运算符
      • 2.5.4 逻辑运算符
      • 2.5.5 位运算符
      • 2.5.6 三元运算符
      • 2.5.7 运算符的优先级和结合性
    • 2.6程序流程控制
      • 2.6.1 顺序结构
      • 2.6.2 分支结构
      • 2.6.3 循环结构
      • 2.6.4 用Scanner类来获取键盘中的信息
      • 2.6.5 Math.random() 随机数生成
      • 2.6.6 输出0~100质数
      • 2.6.7 break的使用
      • 8.continue的使用
      • 9.return的使用

2. Java基本语法

2.1 关键字保留字

关键字(keyword)和保留字(reserved word)

2.1.1 关键字

关键字(keyword)的定义和特点

  • 定义:被Java语言赋予了特殊含义 ,用做专门用途的字符串

  • 特点:关键字中所有字母都为小写

官方地址: https://docs.oracle.com/javase/tutorial/java/nutsandbolts/_keywords.html

image-20220716132342641

image-20220716132401354

2.1.2 保留字

Java保留字:现有Java版本尚未使用,但以后版本可能会作为关键字使用。自己命名标识符时要避免使用这些保留字goto 、const

2.1.3 标识符

自己定义的名称称为标识符

标识符命名规则:

  1. 26英文,0-9,_,或$
  2. 数字不可以开头
  3. 不可以使用关键字和保留字,
  4. 严格区分大小写,无长度限制
  5. 标识符不包含空格

2.1.4 Java中的名称命名规范

Java中的名称命名规范:

  • 包名:所有字母都小写:xxxyyyzzz

  • 类名、接口名:所有单词的首字母大写:XxxYyyZzz

  • 变量名、方法名:第一个单词首字母小写,其余每个单词首字母大写:xxxYyyZzz

  • 常量名:所有字母都大写。多单词时每个单词用下划线连接:XXX_YYY_ZZZ

注意1:在起名字时,为了提高阅读性,要尽量有意义,“见名知意”。

注意2:java采用unicode字符集,因此标识符也可以使用汉字声明,但是不建议使用。

2.2 变量

2.2.1 分类

  1. 按数据类型分类(八种基本数据类型)

  2. 按声明位置分类

注意:不允许使用未初始化的变量,成员变量可以声明不初始化,但局部变量(除形参外)一定要初始化。

2.2.2 整型变量

  • java程序中变量通常声明为int型,约21亿。更大的数据类型用long

    以byte为例,一个字节八位,28次方,为了表示负数,对半分,正数比负数少一位,-27~27-1。

  • java的整型常量默认为 int 型,声明long型常量须后加lL不加会报错吗?有时会有时不会,为什么?

    没有加上L或l编译器会认为是int型,再赋值给long型变量,再数值范围在231~231-1内时都没有问题。但我们知道,long的范围大于int,所以当数值范围介于int和long范围之间时,就会出现数值过大的报错。

2.2.3 浮点型

浮点型变量两种表示形式:

  • 十进制数形式:如:5.12 512.0f .512 (必须有小数点)

  • 科学计数法形式:如:5.12e2 512E2 100E-2 (后面的数字就是10的幕)

  • float:单精度,尾数可以精确到7位有效数字。很多情况下,精度很难满足需求。

  • double:双精度,精度是float的两倍。通常采用此类型。

  • Java 的浮点型常量默认为double型,声明float型常量,须后加fF。 那么在定义float变量时,不加f会报错码,会!

    image-20220716174723446

    那么问题来了,long定义有时候可以不加l,但float定义就一定要加上f,为什么?因为int到long型数据不会丢失,但double到float类型就会数据丢失!这才是关键,所以说语言设计的真的很妙。

2.2.4 字符型 char

  • Java中的所有字符都使用Unicode编码,故一个字符可以存储一个字母,一个汉字,或其他书面语的一个字符(日文等)。

  • 直接使用 Unicode 值来表示字符型常量:‘\uXXXX’。其中,XXXX代表一个十六进制整数。如:\u000a 表示 \n。

  • 字符型用单引号来赋值,但也可以根据ascll码值进行直接赋值。

    char c1=97//c1='a'

  • char类型是可以进行运算的。因为它都对应有Unicode码。

    1. java中内码中的char使用UTF16的方式编码,一个char占用2或4个字节;
    2. java中外码中char使用UTF8的方式编码,一个字符占用1~6个字节。

    在讨论这个问题之前,我们需要先区分unicode和UTF。

    • unicode :统一的字符编号,仅仅提供字符与编号间映射。符号数量在不断增加,已超百万。详细:[https://zh.wikipedia.org/zh-cn/Unicode]
    • UTF :unicode转换格式 (unicode transformation format) 。定义unicode中编号的编码方式。utf8和utf16便是其中两种实现方式。其中utf8为变长表示,长度可能是1~6个字节;utf16为变长表示,长度可能是2或4个字节。详细:UTF8 [https://zh.wikipedia.org/zh-cn/UTF-8] UTF16 [https://zh.wikipedia.org/zh-cn/UTF-16]

    接着,要分清内码(internal encoding)和外码(external encoding)。

    • 内码 :某种语言运行时,其char和string在内存中的编码方式
    • 外码 :除了内码,皆是外码。

    要注意的是,源代码编译产生的目标代码文件(可执行文件或class文件)中的编码方式属于外码。

    先看一下内码

    JVM中内码采用UTF16。早期,UTF16采用固定长度2字节的方式编码,两个字节可以表示65536种符号(其实真正能表示要比这个少),足以表示当时unicode中所有字符。但是随着unicode中字符的增加,2个字节无法表示所有的字符,UTF16采用了2字节或4字节的方式来完成编码。Java为应对这种情况,考虑到向前兼容的要求,Java用一对char来表示那些需要4字节的字符。所以,java中的char是占用两个字节,只不过有些字符需要两个char来表示

    外码

    Java的class文件采用UTF8来存储字符,也就是说,class中字符占1~6个字节。

    Java序列化时,字符也采用UTF8编码,占1~6个字符。

    总结:

    • java中内码(运行内存)中的char使用UTF16的方式编码,一个char占用两个字节,但是某些字符需要两个char来表示。所以,一个字符会占用2个或4个字节。
    • java外码中char使用UTF8的方式编码,一个字符占用1~6个字节。
    • UTF16编码中,英文字符占两个字节;绝大多数汉字(尤其是常用汉字)占用两个字节,个别汉字(在后期加入unicode编码的汉字,一般是极少用到的生僻字)占用四个字节。
    • UTF8编码中,英文字符占用一个字节;绝大多数汉字占用三个字节,个别汉字占用四个字节。

2.2.5 Unicode编码

  • 乱码:世界上存在着多种编码方式,同一个二进制数字可以被解释成不同的符号。因此,要想打开一个文本文件,就必须知道它的编码方式,否则用错误的编码方式解读,就会出现乱码。

  • Unicode:一种编码,将世界上所有的符号都纳入其中。每一个符号都给予一个独一无二的编码,使用 Unicode 没有乱码的问题。

  • Unicode 的缺点Unicode 只规定了符号的二进制代码,却没有规定这个二进制代码应该如何存储:无法区别 Unicode 和 ASCII:计算机无法区分三个字节表示一个符号还是分别表示三个符号。另外,我们知道,英文字母只用一个字节表示就够了,如果unicode统一规定,每个符号用三个或四个字节表示,那么每个英文字母前都必然有二到三个字节是0,这对于存储空间来说是极大的浪费。

2.2.6 UTF-8

  • UTF-8 是在互联网上使用最广的一种 Unicode 的实现方式

  • UTF-8 是一种变长的编码方式。它可以使用 1-6 个字节表示一个符号,根据不同的符号而变化字节长度。

  • UTF-8的编码规则:

    1. 对于单字节的UTF-8编码,该字节的最高位为0,其余7位用来对字符进行编码(等同于ASCII码)。
    2. 对于多字节的UTF-8编码,如果编码包含 n 个字节,那么第一个字节的前 n 位为1,第一个字节的第 n+1 位为0,该字节的剩余各位用来对字符进行编码。在第一个字节之后的所有的字节,都是最高两位为"10",其余6位用来对字符进行编码

2.2.7 boolean类型

  • boolean类型数据只允许取值true和false。

  • 不可以使用0或非 0 的整数替代false和true,这点和C语言不同

  • Java虚拟机中没有任何供boolean值专用的字节码指令,Java语言表达所操作的boolean值,在编译之后都使用java虚拟机中的int数据类型来代替:true用1表示,false用0表示。———《java虚拟机规范 8版》

  • 底层是转化成int类型,占用8个字节。在oracle的java虚拟机中,java语言中的boolean数组被编码为java虚拟机中的字节数组。 每个boolean元素使用8位,1个字节来表示。 java虚拟机中使用1表示真,0表示假,来对boolean进行编码。

  • boolean类型不可以转换为其它的数据类型。

2.3 基本数据类型转换

基本数据类型转换分为自动类型转换和强制类型转换

2.3.1 自动类型转换

容量小的类型自动转换为容量大的数据类型,为之自动类型转换

数据类型按容量大小排序为

image-20220721232919625

  • 有多种类型的数据混合运算时,系统首先自动将所有数据类型转换成容量最大的那种数据类型,然后再进行计算。

  • byte,short,char之间不会相互转换,他们三者在计算时首先转换为int类型。

  • boolean类型不能与其它数据类型运算。

  • 当把任何基本数据类型的值和字符串(String)进行连接运算时(+),基本数据类型的值将自动转化为字符串(String)类型。(字符串类型:String。String不是基本数据类型,属于引用数据类型)

QQ截图20220722144047

String str2=3.5+"";//合法写法

2.2.2 强制类型转换

自动类型转换的逆过程,将容量大的数据类型转换为容量小的数据类型。使用时要加上强制转换符:(),但可能造成精度降低或溢出,格外要注意。

  • 通常,字符串不能直接转换为基本类型,但通过基本类型对应的包装类则可以实现把字符串转换成基本类型。 如:

    String a =43;
    int i = Integer.parseInt(a);
    
  • boolean类型不可以转换为其它的数据类型。

2.4 进制

世界上有10种人,认识和不认识二进制的。

  • 二进制(binary):0,1 ,满2进1,以0b或0B开头。

  • 十进制(decimal):0-9 ,满10进1。

  • **八进制(octal):**0-7 ,满8进1, 以数字0开头表示。

  • **十六进制(hex):**0-9及A-F,满16进1. 以0x或0X开头表示。此处的A-F不区分大小写。如:0x21AF +1= 0X21B0

2.4.1 128强转byte为什么是-128?

数字在计算机底层均用二进制的补码形式存储。下面是求负数的补码基本过程。

128在int(4个字节里面)为00000000 00000000 00000000 100000000

强转为byte类型后,截断取后八位得100000000,但最左边的1在byte类型存储里面表示符号位,表示负数。根据补码的换算即为-128。

计算技巧:对于负数,补码减一取反就是源码,但其实补码取反加一也是源码。上述例子可以验证补码10000000,反码01111111,加一10000000,也就是128,加上符号,为-128

在byte中0的二进制码:0000 0000,-0的二进制码:1000 0000(补码,反码对应1111 1111,源码对应1000 0000)。但-0显然是没有意义的,规定1000 0000是-128的补码,这是以一种数码结合的形式,符号位也是数值位。

2.4.2 为什么数据类型的范围是-2n~2n-1?

这里以byte为例子,最高位为符号位。所以表示数值的位数就是后面七位,最大的就是28-1,也就是127。对于正数,最大值最高位为零,0111 1111,表示127。

但对于最小值(负数)为1000 0000(符号位为1,其余为0表示最小负数)

-0的二进制码:1000 0000(补码,反码对应0111 1111,源码对应1000 0000)。但-0显然是没有意义的,规定1000 0000是-128的补码,这是以一种数码结合的形式,符号位也是数值位。

所以和其他基本数据类型一样,负数范围比正数大1的原因就是-0的存在,所以数据类型的范围是-2n~2n-1。可以说是补码的编码方式决定了范围就是最大值和最小值的绝对值相差1。

  • 那么为什么要使用原码、反码、补码表示形式呢?

    计算机辨别“符号位”显然会让计算机的基础电路设计变得十分复杂! 于是人们想出了将符号位也参与运算的方法. 我们知道, 根据运算法则减去一个正数等于加上一个负数, 即: 1-1 = 1 + (-1) = 0 , 所以机器可以只有加法而没有减法, 这样计算机运算的设计就更简单了。

2.4.3 进制之间转换

首先二进制和十进制之间的转换:注意符号位,和数据存储形式位补码!

而八进制和二进制,十六进制和二进制之间的转换类似。二进制转换成八进制,三位一看。二进制转换成十六进制,四位一看。反过来八进制和十六进制转换为二进制也是如此,三位和四位一看

而二进制,八进制,十进制,十六进制之间的转换,我们可以统一转换成二进制再进行转换。

在java中提供的进制转换的方法:

  • toBinaryString(int n)
  • toOctalString(int n )
  • toHexString(int n )

2.5.运算符

2.5.1 算术运算符

  1. 求余运算符

    被模数%模数,结果符号和被模数一致

    结果符号与被模数的符号是相同的(前面的那个)并且求余是允许浮点数求余的。

  2. 自增自减

    • java编译器只能做自动类型提升,强制类型转换需显示说明。另外整型常量默认为int,浮点型常量默认为double类型。下面是错误例子:

    • 第二个,了解本质,判断数据溢出的问题

      b1在底层是01111111,加以后为10000000,即为-128。

    • 值得注意,后置自增自减和C++一样返回的临时变量,不容许修改!所以b++++;是不被允许的。因为前面的b++放回临时变量,临时变量++不被允许。

2.5.2 赋值运算符

*=、+=, -=, =, /=, %=

byte b1=10;
b1+=2;//+=不改变数据类型

这样的写法是正确的!b1=b1+1;还是有区别的。

//对变量加1操作
byte b=5//方法一  b++;
//方法二  b+=1;  推荐写法
//方法三  b=byte(b+1);  这种写法注意强制类型转换需要显示转换

//在java中对变量的修改,如对变量b加2操作
byte a=5;
//方法一  a=a+2;错误写法,只有int类型这么些是对的
//方法二  a+=2;  推荐写法
//方法三  a++++;  错误写法,临时变量不容许修改

综上所述,+=-=是修改变量值的推荐写法

例子思考

2.5.3 比较运算符

比较运算符结果都是boolean值,只有true和false

2.5.4 逻辑运算符

逻辑运算符是对boolean类型的数据进行运算,不全面,对二进制为也可以逻辑运算

&逻辑与 |逻辑或 !逻辑非 ^ 逻辑异或

&& 短路与 || 短路或

逻辑与和短路与的区别是什么?

首先结果的逻辑值来说是没有区别的,逻辑与和短路与操作实际上均为与操作,但由于判断的时候自左向右,当前面出现false,那么就是结果就是false。逻辑与就是计算完所有式子。而短路与则是后面的语句便不再执行。所以就出现了m2数值没有发生变化的情况。

逻辑或和短路或的区别?

类似短路或和逻辑或,短路或遇到true便不再计算后面的式子。

2.5.5 位运算符

面试题:最高效的计算2*8?2<<3,8<<1。

面试题:交换两个数值:

int a=10;
int b=20;
a=a^b;
b=a^b;
a=a^b;
  1. <<:左移,将数的二进制左移指定的位数,低位补0。
  2. <<<:在Java中并没有 <<< 操作符,这是一个错误的表达方式。(因为只有右移才涉及符号问题,左移没有这方面的需求)
  3. >>:右移,将数的二进制右移指定的位数,高位补符号位(即最高位的值保持不变)。
  4. >>>:无符号右移,将数的二进制右移指定的位数,高位位补0。

需要注意的是,位移操作符只能用于整数类型的数据,包括 byteshortintlong 和对应的包装类。对于负数,带符号右移操作符 >> 会在高位补符号位,而无符号右移操作符 >>> 会在高位补0。因此,在使用位移操作符时,需要考虑符号位对结果的影响。

2.5.6 三元运算符

int a=(m1>m2)?2.0:2;
//错误: 不兼容的类型: 从double转换到int可能会有损失
double b=(m1>m2)?2.0:2;
//自动类型提升,正确

此外三元运算符是允许嵌套的!但可读性差些。

string b=(m1>m2)?"m1大":((m1==m2)?"m1和m2一样大":"m2大");

凡是能使用三目运算符的都可以改写成ifelse,如果程序既可以使用三目运算符又能使用ifelse,推荐使用三元运算符,特别是方法内return+三目运算符,很简练

2.5.7 运算符的优先级和结合性

结合性:**只有单目运算符、三元运算符、 赋值运算符是从右向左运算的。**所以像加减等二目运算符都是从左向右的。

优先级: 运算符有不同的优先级,所谓优先级就是表达式运算中的运算顺序。如右表,上一行运算 符总优先于下一行。

2.6程序流程控制

2.6.1 顺序结构

一般编写的程序就是顺序结构

2.6.2 分支结构

ifelse语句和switch语句

  • ifelse语句细节:

    1. if和else之间的是不允许出现其他的句式

    1. if语句中括号中要求是boolean类型
  • switch语句细节:

    1. switch括号中要求是以下六种数据类型常量:byte、short、char、int、枚举类型(JDK5.0新增)、String类型(JDK7.0新增)
    2. default子句是可任选的,位置也是灵活的。当没有匹配的case时, 执行default。因为switch语句是分支结构,按括号内的常量决定执行的语句是什么。但注意一般我们将default放在最后我们可以不加break,因为是最后一个语句了。但是如果我们将default放在语段中间,那么就要加上break了,因为如果default满足,他会一直向下执行的!

2.6.3 循环结构

  1. for循环结构

    求最大公约数的方法有循环遍历,但有个更加好的方法:

    //辗转相除法:求a和b的最大公约数等价于求b与a%b的最大公约数
    //若m,n为两个正整数,则
    //1、当m>n时,m和n和最大公约数等于n与m%n的最大公约数;
    //2、当n=0时,m与n的最大公约数等于m;//两个数中一个为零,另一个数(大数)就是最大公约数
    //简而言之:(A>B)A和B的最大公约数等于B和A%B的最大公约数(此时B>A%B)
    int gcd(int a,int b)//a>b
    {
        return a%b==0?b:gcd(b,a%b);
    }
    
  2. while语句和dowhile语句很简单,不在此描述

2.6.4 用Scanner类来获取键盘中的信息

  1. 导包:import java.util.Scanner;
  2. Scanner类实例化:Scanner scan=new Scanner(System.in);
  3. 调用Scanner类的相关方法,来获取所指定类型的变量。

注意Scanner没有提供提取char类型的数据,可以通过nextString来进行。

如果输入的数据和函数类型不匹配且不满足自动类型提升要求,那么就会报错:java.util.InputMismatchException

2.6.5 Math.random() 随机数生成

利用Math类提供的函数

Math.random()返回一个正值double类型,范围是[0.0-1.0)

//对于生成一个[min,max]的随机数
int num=(int)(Math.random()*(max-min+1)+min);
//math.random()*(max-min+1)+min范围是[min,max+1),取整后即[min,max]
//熟练记下,其中是否加1以及加1位置的关键在于目标范围左右边界是否取得到,灵活变化!

2.6.6 输出0~100质数

这里先讲讲计算时间的函数currentTimeMilles():返回距离1970年一月一日 零时零分零秒的毫秒数(long类型)

方法一:循环遍历用质数的定义,符合条件就输出。但算法不优,可以用上面计算时间的函数观察与下面方法的区别

//方法一:
Boolean isFlag=true;
long start=System.currentTimeMillis();
for(int i=2;i<=10000;i++){
	for(int j=2;j<i & isFlag;j++){
		if(i%j==0)isFlag=false;//如果有一个整除,说明不是质数
	}
	if(isFlag)System.out.println(i);
	isFlag=true;
}
long end=System.currentTimeMillis();
System.out.println("time : "+(end-start));
//time : 73

方法二: 优化算法

  1. 循环中只要找到一个因数,就break
  2. 判断i是否是质数,只需要计算到根号i即可。怎么理解呢?如果存在比根号i大的数字被整除,那么对应的一定会有一个数小于根号i也被整除,所以只需要检测到根号i即可。
Boolean isFlag=true;
long start=System.currentTimeMillis();
for(int i=2;i<=10000;i++)
{
	//优化2:Math.sqrt(i),只需要计算到根号i即可!理解哦
	for(int j=2;j<Math.sqrt(i);j++)
	{
		if(i%j==0)
		{
			isFlag=false;//如果有一个整除,说明不是质数
			break;//优化一,发现一个因数就推出
		}
	}
	if(isFlag)System.out.println(i);
	isFlag=true;
}
long end=System.currentTimeMillis();
System.out.println("time : "+(end-start));
//time : 6

方法三:用到continue,代码简略些,但不如遍历来的快

long start=System.currentTimeMillis();
label:for(int i=2;i<=100000;i++)
{
	//优化2:Math.sqrt(i),只需要计算到根号i即可!整除一定是成对出现的,理解哦
	for(int j=2;j<Math.sqrt(i);j++)
	{
		if(i%j==0)
		{
			continue label;
		}
	}
	System.out.println(i);
}
long end=System.currentTimeMillis();
System.out.println("time : "+(end-start));
//time:22

2.6.7 break的使用

  • break语句用于终止当前循环体的执行

    {...
    	break;
    }
    
  • break语句出现在多层嵌套的语句块中时,可以通过标签指明要终止的是 哪一层语句块(如果没有标签,结束的是当次循环)

    label1: { ……
    label2: 	{ ……
    label3: 		{ ……
    				break label2;//结束指定标识的语句块
    					……
    				}
    			}
    		}
    

8.continue的使用

  • continue只能使用在循环结构中
  • continue语句用于跳过其所在循环语句块的一次执行,继续下一次循环
  • continue语句出现在多层嵌套的循环语句体中时,可以通过标签指明要跳过的是哪一层循环
label1:for(;;){ ……
label2:for(;;){ ……
label3:for(;;){ ……
				continue label2;//结束指定标识的一层循环
               //意思就是如果执行党该语句,下一步就跳到label2对应的位置再次进入循环,懂吧?
					……
				}
			}
		}

9.return的使用

结束方法+返回数据

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

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

相关文章

【详细讲解PostCSS如何安装和使用】

&#x1f308;个人主页:程序员不想敲代码啊&#x1f308; &#x1f3c6;CSDN优质创作者&#xff0c;CSDN实力新星&#xff0c;CSDN博客专家&#x1f3c6; &#x1f44d;点赞⭐评论⭐收藏 &#x1f91d; 希望本文对您有所裨益&#xff0c;如有不足之处&#xff0c;欢迎在评论区提…

macOS Ventura 13.6.6 (22G630) Boot ISO 原版可引导镜像下载

macOS Ventura 13.6.6 (22G630) Boot ISO 原版可引导镜像下载 3 月 26 日凌晨&#xff0c;macOS Sonoma 14.4.1 发布&#xff0c;同时带来了 macOS Ventru 13.6.6 安全更新。 macOS Ventura 13.6 及更新版本&#xff0c;如无特殊说明皆为安全更新&#xff0c;不再赘述。 本站…

MoneyPrinterTurbo搭建详细流程(Linux)及常见问题

先附上链接: MoneyPrinterTurbohttps://github.com/harry0703/MoneyPrinterTurboMoneyPrinterTurbo是一款合成视频的软件。 你只需要提供一个主题或者关键字,就可以全自动生成视频文案、视频素材、视频字幕、视频背景音乐,然后合成一个高清的短视频。 接下来讲解详细的搭…

vue3 渲染一个后端返回的图片字段渲染、table表格内放置图片

一、后端直接返回图片url 当图片字段接口直接返回的是图片url&#xff0c;可以直接放到img标签上 <img v-if"thumbLoader" class"r-image-loader-thumb" :src"resUrl" /> 二、当图片字段接口直接返回的是图片Id 那么就需要去拼一下图片…

SQL-CRUD-2数据库实验

目录 第一关任务描述 相关知识 插入完整内容的行 插入选定内容的行 编程要求 测试说明 第一关代码 第二关任务描述 相关知识 删除表中的指定行 删除表中的所有行 编程要求 测试说明 第二关代码 第三关任务描述 相关知识 更新表中的指定行 编程要求 测试说明…

鸿蒙:搜索框组件Search

搜索框组件&#xff0c;适用于浏览器的搜索内容输入框等应用场景。 说明 该组件从API Version 8开始支持 子组件 无 接口 Search(options?: { value?: string, placeholder?: string, icon?: string, controller?: SearchController }) 参数: 参数名 参数类型 必…

61、服务攻防——中间件安全CVE复现K8sDockerJettyWebsphere

文章目录 K8sDockerWebSphere K8s k8s&#xff1a;简单来说&#xff0c;跟docker一样&#xff0c;是个容器系统。 k8s对外攻击面总结 常见漏洞&#xff1a;未授权访问、提权漏洞 Docker docker逃逸&#xff1a;1、由内核漏洞引起&#xff1b;2、由Docker软件设计引起&#x…

【Git】git status中文文件名编码问题解决

git status中文文件名编码问题解决 一、问题二、解决方法 一、问题 在默认配置下&#xff0c;查看文件状态&#xff0c;中文文件名在工作区状态输出&#xff0c;中文名不能正确显示&#xff0c;而是显示为八进制的字符编码。 PS D:\VS代码\Widget> git status On branch m…

TOP100-回溯(二)

4.39. 组合总和 给你一个 无重复元素 的整数数组 candidates 和一个目标整数 target &#xff0c;找出 candidates 中可以使数字和为目标数 target 的 所有 不同组合 &#xff0c;并以列表形式返回。你可以按 任意顺序 返回这些组合。 candidates 中的 同一个 数字可以 无限制…

【计算机网络篇】数据链路层(4.2)可靠传输的实现机制

文章目录 &#x1f354;可靠传输的实现机制⭐停止 - 等待协议&#x1f5d2;️注意 &#x1f50e;停止 - 等待协议的信道利用率&#x1f5c3;️练习题 ⭐回退N帧协议&#x1f388;回退N帧协议的基本工作流程&#x1f50e;无传输差错的情况&#x1f50e;超时重传的情况&#x1f5…

GitHub开源项目权限管理-使用账号和个人令牌访问

1.打开后台账号设置 2.找到左下角的Developer settings 3.找到Personal access tokens 的 Tokens(classic) 4.选择创建新证书 5.填写证书信息 6.点击生成证书&#xff0c;复制证书并且保存起来&#xff08;血泪教训&#xff0c;证书只会在创建时显示一次&#xff0c;以后就再也…

篮球论坛系统的设计与实现|Springboot+ Mysql+Java+ B/S结构(可运行源码+数据库+设计文档)

本项目包含可运行源码数据库LW&#xff0c;文末可获取本项目的所有资料。 推荐阅读100套最新项目持续更新中..... 2024年计算机毕业论文&#xff08;设计&#xff09;学生选题参考合集推荐收藏&#xff08;包含Springboot、jsp、ssmvue等技术项目合集&#xff09; 目录 1. …

iOS UIFont-实现三方字体的下载和使用

UIFont 系列传送门 第一弹加载本地字体:iOS UIFont-新增第三方字体 第二弹加载线上字体:iOS UIFont-实现三方字体的下载和使用 前言 在上一章我们完成啦如何加载使用本地的字体。如果我们有很多的字体可供用户选择,我们当然可以全部使用本地字体加载方式,可是这样就增加了…

SpringBoot3任务处理

目录 1.异步任务 无返回值异步任务 效果 有返回值异步任务 效果 2.定时任务 效果 3.邮件任务 获取授权码 加入依赖 配置文件 纯文本邮件 效果 复杂邮件 效果 1.异步任务 Async注释&#xff1a; SpringBoot中的异步调用&#xff0c;可以写在类上或方法上&#…

如何选择指纹浏览器?盘点好用是防关联浏览器

在网络世界中&#xff0c;保护您的在线隐私和安全非常重要。反检测浏览器是专门为此诞生的工具&#xff0c;旨在通过更改浏览器指纹来帮助您做到这一点&#xff0c;它们使网站、广告商和其他人很难跟踪您的在线行为。 一、什么是反检测浏览器&#xff1f; 您是否想过网站如何检…

PCD3012五通道高功率因数LED控制芯片,集成700V高压MOSFET 低THD 外围极少元件

概述 PCD 3012B 是一款五段低 THD 、高功率因数 LED 线性恒流控制芯片&#xff0c;芯片集成了 700V 高压 MOSFET &#xff0c;采用独特创新的器件工艺技术&#xff0c;具有优越的抗雪崩击穿及浪涌能力&#xff0c;在外围无保护器件时可通过650V 雷击浪涌测试&#xff0c;内置…

实验7 内置对象response

编写代码&#xff0c;掌握request、response的用法。【参考课本4.6.2】 三、源代码以及执行结果截图&#xff1a; input.jsp <% page language"java" contentType"text/html; charsetutf-8" pageEncoding"utf-8"%> <!DOCTYPE html>…

重学SpringBoot3-SpringBoot可执行JAR的原因

更多SpringBoot3内容请关注我的专栏&#xff1a;《SpringBoot3》 期待您的点赞&#x1f44d;收藏⭐评论✍ 重学SpringBoot3-SpringBoot可执行JAR的原因 Spring Boot可执行JAR的结构打包运行JAR 包内部结构 工作原理优点总结 Spring Boot 的一个核心特性是它的可执行 JAR&#x…

在word中显示Euclid Math One公式的问题及解决(latex公式,无需插件)

问题&#xff1a;想要在word中显示形如latex中的花体字母 网上大多解决办法是安装Euclid Math One。安装后发现单独的符号插入可行&#xff0c;但是公式中选择该字体时依然显示默认字体。 解决办法&#xff1a;插入公式后&#xff0c;勾选左上角的latex 在公式块中键入latex代码…

在宝塔面板中,为自己的云服务器安装SSL证书,为所搭建的网站启用https(主要部分攻略)

前提条件 My HTTP website is running Nginx on Debian 10&#xff08;或者11&#xff09; 时间&#xff1a;2024-3-28 16:25:52 你的网站部署在Debain 10&#xff08;或者11&#xff09;的 Nginx上 安装单域名证书&#xff08;默认&#xff09;&#xff08;非泛域名&#xf…