【Java】数据类型变量
【Java】数据类型&变量
文章目录
- 【Java】数据类型&变量
- 1、字面常量
- 2、数据类型
- 3、变量
- 3.1 整型变量
- 3.1.1 整型变量
- 3.1.2 长短整型变量
- 3.1.3 字节型变量
- 3.2 浮点型变量
- 3.2.1 双精度浮点型
- 3.2.2 单精度浮点型
- 3.3 字符型变量
- 3.4 布尔型变量
- 3.5 类型转换
- 3.5.1 自动类型转换
- 3.5.2 强制类型转换
- 3.6 类型提升
- 4、字符串类型
- 字符串转整型:
- 整型转字符串:
1、字面常量
在Java中,字面常量(Literal Constants)是指直接在代码中表示特定值的固定值或数据。这些值是在代码中直接写出来的,而不是通过计算或变量赋值获得的。Java支持多种类型的字面常量,包括以下几种常见的类型:
-
整数字面常量:表示整数值,可以用十进制、八进制、十六进制表示。例如:
42、075、0x2A。 -
浮点数字面常量:表示浮点数值,可以使用小数点表示,也可以使用指数表示。例如:
3.14、2.0e-5。 -
字符字面常量:表示单个字符,使用单引号括起来。例如:
'A'、'1'、'%'。 -
字符串字面常量:表示字符串值,使用双引号括起来。例如:
"Hello, World!"、"Java Programming"。 -
布尔字面常量:表示布尔值,只有两个取值:
true和false。 -
null字面常量:表示空引用,用关键字
null表示。
这些字面常量在编写Java代码时非常常见,它们直接表示了对应的值,使代码更加清晰易懂。例如,以下是一些使用字面常量的示例:
int num = 42;
double pi = 3.14;
char initial = 'J';
String greeting = "Hello, World!";
boolean isValid = true;
Object obj = null;
在这些示例中,都直接使用了字面常量来初始化变量的值。
2、数据类型
基本数据类型(Primitive Data Types):
-
整数类型:
- byte:8位有符号整数,范围为 -128 到 127。
- short:16位有符号整数,范围为 -32,768 到 32,767。
- int:32位有符号整数,范围为 -2^31 到 2^31 - 1。
- long:64位有符号整数,范围为 -2^63 到 2^63 - 1。
-
浮点数类型:
- float:32位单精度浮点数。
- double:64位双精度浮点数。
-
字符类型:
- char:16位Unicode字符。
-
布尔类型:
- boolean:表示 true 或 false 值。
3、变量
3.1 整型变量
3.1.1 整型变量
-
int大小不变:
int数据类型在不同的系统下都是占用 4 个字节,即 32 位,无论是 32 位系统还是 64 位系统。 -
推荐使用方式一:通常情况下,推荐在定义变量时就给出合适的初始值。这有助于避免使用未初始化的变量,从而减少可能的错误。
-
初始值不能超过int范围:当给变量设置初始值时,确保值不超过
int数据类型的表示范围,以避免溢出。 -
必须赋初值:Java要求在使用变量之前必须对其赋初值。这可以帮助避免使用未初始化的变量,从而增强程序的健壮性。
-
int的包装类型为Integer:int的包装类型是 `Integer。包装类型用于将基本数据类型转换为对象,使其能够在面向对象的上下文中使用。例如,可以在集合(如列表或映射)中存储 Integer对象。
3.1.2 长短整型变量
长短整型变量(short 和 long)是 Java 中的两种整型数据类型,分别用于存储不同范围的整数值。在使用这些变量时,有一些注意事项需要考虑:
short 类型注意事项:
-
范围限制:
short类型只有 16 位,范围为 -32,768 到 32,767。因此,它适合于存储较小的整数值。如果值超出了这个范围,会导致溢出。 -
类型提升:在进行算术操作时,
short类型的操作数会被自动提升为int,然后执行计算。这可以避免溢出和精度丢失。 -
强制类型转换:如果需要将
int类型的值赋给short类型的变量,需要进行显式的强制类型转换。这可能会导致数据丢失,因为超出范围的值会被截断。
long 类型注意事项:
-
范围和精度:
long类型有 64 位,因此适用于存储大范围的整数值。它可以表示更大的整数,但注意不要超出其范围。 -
字面常量后缀:在使用较大的
long字面常量时,建议在数字后面加上L或l后缀,以指示这是long类型的值。 -
类型提升:与
short类型一样,long类型的操作数在进行算术操作时也会被自动提升为int或更高类型。 -
精度问题:当进行除法操作时,
long类型的精度可能会受到影响,可能会得到意外的结果。在需要保持精度的情况下,可以使用double或其他浮点数类型。
在使用 short 和 long 类型时,务必注意其范围、精度和数据转换的问题。合理选择数据类型,避免溢出和精度丢失,以确保程序的正确性和健壮性。
3.1.3 字节型变量
字节型变量(byte)是 Java 中的一种整型数据类型,用于存储8位有符号整数值。由于它的范围相对较小,通常在一些需要节省内存的情况下使用。以下是使用字节型变量时的注意事项:
-
范围限制:
byte类型有 8 位,范围为 -128 到 127。它适用于存储相对较小的整数值,例如像素值、文件处理等。 -
字面常量后缀:在使用
byte字面常量时,建议在数字后面加上B或b后缀,以指示这是byte类型的值。 -
类型提升:与其他整型数据类型一样,在进行算术操作时,
byte类型的操作数会被自动提升为int类型,然后执行计算。这可以避免溢出和精度丢失。 -
强制类型转换:如果需要将
int类型的值赋给byte类型的变量,需要进行显式的强制类型转换。这可能会导致数据丢失,因为超出范围的值会被截断。 -
应用场景:由于
byte变量范围较小,通常用于一些需要节省内存的场景,如图像处理、文件操作等。但要注意不要在需要较大范围的整数计算中使用它。
以下是一个简单的示例,演示了如何使用 byte 类型变量:
public class ByteVariableExample {public static void main(String[] args) {byte pixelValue = 100;byte fileSize;fileSize = 50;// 使用方式二定义后,在使用前如果没有赋值,则编译期间会报错// byte imageHeight; // 此处应该赋初值,否则会报错// System.out.println(imageHeight);// imageHeight = 200;System.out.println("Pixel Value: " + pixelValue);System.out.println("File Size: " + fileSize);// byte型变量所能表示的范围:System.out.println("Minimum Byte Value: " + Byte.MIN_VALUE);System.out.println("Maximum Byte Value: " + Byte.MAX_VALUE);}
}
在这个示例中,pixelValue 和 fileSize 都是 byte 类型变量,用于存储相对较小的整数值。注意在使用未初始化的 byte 变量时会导致编译错误,因此需要确保变量在使用前已经赋值。
3.2 浮点型变量
3.2.1 双精度浮点型
双精度浮点型(double)是 Java 中的一种浮点数数据类型,用于存储双精度浮点数值。double 类型使用 64 位内存空间,提供了更大的范围和更高的精度,适用于存储需要更大位数和小数点精度的浮点数值。以下是关于 double 类型的一些注意事项:
-
范围和精度:
double类型可以表示更大范围和更高精度的浮点数值,适用于科学计算、工程计算以及需要高精度的金融计算等。 -
字面常量后缀:在使用
double字面常量时,可以不加后缀,也可以加上D或d后缀,以明确指示这是double类型的值。例如:3.14或3.14D。 -
类型提升:与其他浮点数数据类型一样,
double类型的操作数在进行算术操作时会自动提升为double,以避免精度丢失。 -
科学计数法:
double类型的值可以使用科学计数法表示,例如:1.23e-4表示 0.000123。 -
默认小数点类型:在进行除法或其他浮点数运算时,如果参与运算的操作数中有
double类型,结果会自动被推断为double类型。
以下是一个简单的示例,展示了如何使用 double 类型变量进行浮点数运算:
public class DoubleVariableExample {public static void main(String[] args) {double pi = 3.141592653589793;double radius = 5.0;double circumference = 2 * pi * radius;double area = pi * radius * radius;System.out.println("Circumference: " + circumference);System.out.println("Area: " + area);}
}
在这个示例中,pi 和 radius 都是 double 类型变量,用于存储双精度浮点数值。然后,进行了圆周和面积的计算,并输出结果。由于 double 类型提供了高精度,它适用于涉及小数点的计算。
3.2.2 单精度浮点型
单精度浮点型(float)是 Java 中的一种浮点数数据类型,用于存储单精度浮点数值。float 类型使用 32 位内存空间,提供了适度的范围和精度,适用于存储需要小数点精度的浮点数值。以下是关于 float 类型的一些要点:
-
范围和精度:
float类型可以表示一定范围的浮点数值,通常用于存储需要适度位数和小数点精度的浮点数。范围和精度相对于double类型较小。 -
字面常量后缀:在使用
float字面常量时,需要加上F或f后缀,以明确指示这是float类型的值。例如:3.14F。 -
类型提升:与其他浮点数数据类型一样,
float类型的操作数在进行算术操作时会自动提升为double,以避免精度丢失。 -
科学计数法:
float类型的值同样可以使用科学计数法表示,例如:1.23e-4表示 0.000123。 -
默认小数点类型:在进行除法或其他浮点数运算时,如果参与运算的操作数中有
float类型,结果会自动被推断为double类型。
以下是一个简单的示例,展示了如何使用 float 类型变量进行浮点数运算:
public class FloatVariableExample {public static void main(String[] args) {float temperature = 25.5F;float gravity = 9.81F;float force = gravity * 5.0F;float area = 3.14F * 2.0F * 2.0F;System.out.println("Temperature: " + temperature);System.out.println("Force: " + force);System.out.println("Area: " + area);}
}
在这个示例中,temperature 和 gravity 都是 float 类型变量,用于存储单精度浮点数值。然后,进行了力和面积的计算,并输出结果。由于 float 类型提供了适度的精度,它适用于需要小数点位数的计算。
3.3 字符型变量
字符型变量(char)是 Java 中的一种基本数据类型,用于存储单个字符。char 类型可以表示 Unicode 字符集中的字符,包括字母、数字、标点符号和特殊字符。以下是关于 char 类型的一些要点:
-
表示字符:
char类型用于表示单个字符,可以是字母、数字、符号或特殊字符。字符被放置在单引号'中,例如:'A'、'1'、'@'。 -
Unicode 支持:Java 的
char类型支持 Unicode 编码,因此可以表示多种语言的字符。例如,'中'、'a'、'€'都是合法的char值。 -
转义序列:有些特殊字符需要通过转义序列表示,例如:
'\n'表示换行,'\t'表示制表符等。 -
整数表示:尽管
char是字符类型,但它在内部被表示为整数(16 位),因此可以进行数值运算。例如,'A' + 1的结果是'B'。
以下是一个示例,展示了如何使用 char 类型变量来存储字符:
public class CharVariableExample {public static void main(String[] args) {char letter = 'A';char digit = '7';char symbol = '$';System.out.println("Letter: " + letter);System.out.println("Digit: " + digit);System.out.println("Symbol: " + symbol);// 转义序列示例char newline = '\n';char tab = '\t';System.out.println("This is a" + tab + "tab.");System.out.println("This is a" + newline + "new line.");}
}
在这个示例中,letter、digit 和 symbol 都是 char 类型变量,用于存储字符。还展示了如何使用转义序列来表示特殊字符,如制表符和换行符。
需要注意的是,char 变量只能存储一个字符,而不是字符串。如果需要存储多个字符,应该使用字符串类型(String)。
3.4 布尔型变量
布尔型变量(boolean)是 Java 中的一种基本数据类型,用于存储布尔值,即 true 或 false。boolean 类型用于表示条件判断、逻辑运算的结果等情况,它在控制流程和条件判断中非常常用。以下是关于 boolean 类型的一些要点:
-
取值范围:
boolean类型只能存储两个值:true和false,用来表示真和假。 -
逻辑运算:
boolean类型通常用于逻辑运算,如与(&&)、或(||)、非(!)等。逻辑运算的结果也是boolean类型。 -
条件语句:
boolean类型常用于条件语句,例如if语句和循环中,以判断某个条件是否满足。 -
默认值:
boolean类型的默认值是false。
以下是一个示例,演示了如何使用 boolean 类型变量进行条件判断和逻辑运算:
public class BooleanVariableExample {public static void main(String[] args) {boolean isRaining = true;boolean isSunny = false;// 使用boolean变量进行条件判断if (isRaining) {System.out.println("It's raining outside. Take an umbrella!");} else if (isSunny) {System.out.println("It's sunny outside. Enjoy the weather!");} else {System.out.println("It's neither raining nor sunny. Check the weather forecast.");}// 使用逻辑运算符boolean isWeekend = true;boolean hasHomework = false;if (isWeekend && !hasHomework) {System.out.println("It's the weekend and you don't have homework. Relax!");} else {System.out.println("You have things to do. Keep working.");}}
}
在这个示例中,isRaining、isSunny、isWeekend 和 hasHomework 都是 boolean 类型变量,用于表示不同的布尔值。示例中展示了如何使用 boolean 变量进行条件判断和逻辑运算。
3.5 类型转换
3.5.1 自动类型转换
在 Java 中,有一种自动类型转换(或隐式类型转换)的机制,允许较小范围的数据类型自动转换为较大范围的数据类型,以避免数据丢失。这种类型转换是由编译器在特定情况下自动执行的。以下是一些常见的自动类型转换情况:
-
整数类型自动转换:在进行整数类型的运算时,较小范围的整数类型(如
byte或short)会自动提升为int类型,以避免溢出。byte a = 10; short b = 20; int result = a + b; // a 和 b 在运算前被自动转换为 int -
浮点数类型自动转换:在进行浮点数类型的运算时,较小精度的浮点数类型(如
float)会自动提升为double类型。float x = 3.14F; double y = 2.71; double sum = x + y; // x 在运算前被自动转换为 double -
混合类型运算:当在表达式中混合使用不同类型的操作数时,较小类型的操作数会自动转换为较大类型。
int num = 10; double decimal = 2.5; double result = num + decimal; // num 在运算前被自动转换为 double -
布尔类型转换:布尔类型不会自动转换为其他数据类型,也不会从其他数据类型自动转换为布尔类型。但是,在条件判断和逻辑运算中,
boolean类型会自动转换为适用的数据类型。boolean flag = true; int value = 42; if (flag) {// flag 会自动转换为适用于条件判断的数据类型 }
需要注意的是,虽然自动类型转换可以避免一些常见的数据丢失问题,但在进行类型转换时仍需谨慎。当进行类型转换时,如果目标类型的范围或精度不足以容纳源类型的值,可能会导致不正确的结果。在需要进行精确计算或数据处理时,应该使用适当的数据类型和显式的类型转换。
3.5.2 强制类型转换
强制类型转换(或显式类型转换)是在编程中将一个数据类型转换为另一个数据类型的过程。在某些情况下,自动类型转换可能不足以满足需求,因此需要使用强制类型转换来实现特定的转换需求。强制类型转换会在编译期间或运行时明确执行,以确保数据的正确性。以下是关于强制类型转换的一些要点:
-
语法:强制类型转换使用圆括号将要转换的值括起来,并在括号内指定目标数据类型。
// 语法:目标数据类型 变量名 = (目标数据类型) 原始值; int num1 = (int) 3.14; // 将浮点数转换为整数,小数部分被截断 -
数据范围缩小:通常情况下,强制类型转换用于将较大范围的数据类型转换为较小范围的数据类型。在这种情况下,可能会导致数据丢失。
double largeValue = 12345.67; int smallValue = (int) largeValue; // 将 double 转换为 int,小数部分被截断 -
数据类型扩展:在一些情况下,可以将较小范围的数据类型转换为较大范围的数据类型,以便在某些运算中获得更高的精度。
int intValue = 42; double doubleValue = (double) intValue; // 将 int 转换为 double,以获得更高的精度 -
注意溢出:在将一个大范围的整数类型转换为一个小范围的整数类型时,可能会发生溢出。因此,要确保目标数据类型足够大以容纳源数据类型的值。
long largeNumber = 12345678901234L; int smallNumber = (int) largeNumber; // 可能会导致溢出,需要谨慎 -
特殊情况:某些类型之间的转换可能不是直接的,可能需要多次转换,或者需要注意数据精度和范围。
在使用强制类型转换时,需要特别注意数据的范围、精度以及可能的数据丢失。不正确的类型转换可能导致程序运行时的错误或不符合预期的结果。因此,在进行强制类型转换时应该谨慎,并确保了解源数据类型和目标数据类型的特性。
3.6 类型提升
类型提升(或自动类型提升)是 Java 中一种在表达式中自动将较小的数据类型转换为较大的数据类型的机制。这种提升发生在进行算术操作或赋值等操作时,以确保不发生数据丢失或溢出。以下是关于类型提升的一些要点:
-
整数类型提升:在进行整数类型的算术运算时,较小范围的整数类型(如
byte、short或char)会被自动提升为int类型,然后进行运算。byte a = 10; short b = 20; int result = a + b; // a 和 b 在运算前被自动提升为 int -
浮点数类型提升:在进行浮点数类型的算术运算时,较小精度的浮点数类型(如
float)会被自动提升为double类型,然后进行运算。float x = 3.14F; double y = 2.71; double sum = x + y; // x 在运算前被自动提升为 double -
混合类型运算:当在表达式中混合使用不同类型的操作数时,较小类型的操作数会被自动提升为较大类型。
int num = 10; double decimal = 2.5; double result = num + decimal; // num 在运算前被自动提升为 double -
避免溢出和精度丢失:类型提升有助于避免在运算中发生溢出和精度丢失,因为运算会在更大范围或更高精度的数据类型中进行。
-
逻辑运算和条件判断:在逻辑运算和条件判断中,
boolean类型会被自动提升为适用的数据类型。boolean flag = true; int value = 42; if (flag) {// flag 会自动提升为适用于条件判断的数据类型 }
需要注意的是,类型提升是为了确保运算的准确性和合理性,但在某些情况下可能会导致意外的结果。在进行类型提升时,应该理解不同数据类型的范围和精度,以便正确处理运算结果。如果需要进行精确的数值计算,应该使用适当的数据类型和显式的类型转换。
4、字符串类型
在 Java 中,字符串和整型数字之间的转换涉及将字符串表示的数字转换为整型,或者将整型转换为字符串。以下是两种转换的示例:
字符串转整型:
使用 Integer.parseInt() 方法可以将表示整数的字符串转换为整型。
public class StringToIntExample {public static void main(String[] args) {String strNumber = "12345";int number = Integer.parseInt(strNumber);System.out.println("Parsed Number: " + number);}
}
在上面的示例中,将字符串 "12345" 转换为整型。
如果字符串不表示一个有效的整数,例如 "abc",则会引发 NumberFormatException 异常。为了避免异常,应该确保字符串可以被正确解析为整数。
整型转字符串:
使用 String.valueOf() 方法或整型的字符串连接方式可以将整型数字转换为字符串。
public class IntToStringExample {public static void main(String[] args) {int number = 9876;// 使用 String.valueOf()String strNumber1 = String.valueOf(number);// 使用字符串连接方式String strNumber2 = number + "";System.out.println("Converted String (Method 1): " + strNumber1);System.out.println("Converted String (Method 2): " + strNumber2);}
}
在上面的示例中,将整数 9876 转换为字符串。
这些转换方法可以在处理字符串和整型之间的相互转换时非常有用。但需要注意的是,在进行转换时应该确保数据格式正确,以避免异常或错误。
相关文章:
【Java】数据类型变量
【Java】数据类型&变量 文章目录 【Java】数据类型&变量1、字面常量2、数据类型3、变量3.1 整型变量3.1.1 整型变量3.1.2 长短整型变量3.1.3 字节型变量 3.2 浮点型变量3.2.1 双精度浮点型3.2.2 单精度浮点型 3.3 字符型变量3.4 布尔型变量3.5 类型转换3.5.1 自动类型转…...
护目镜佩戴检测识别算法
护目镜佩戴检测识别算法通过opencvpython网络深度学习模型,护目镜佩戴检测识别算法实时监测工人的护目镜佩戴情况,发现未佩戴或错误佩戴的情况,及时提醒调整。与C / C等语言相比,Python速度较慢。也就是说,Python可以使…...
NOIOLPJ2022B. 数学游戏 分析
数学游戏 题目描述 Kri 喜欢玩数字游戏。 一天,他在草稿纸上写下了 ttt 对正整数 (x,y)(x,y)(x,y),并对于每一对正整数计算出了 zxygcd(x,y)z x \times y \times \gcd(x,y)zxygcd(x,y)。 可是调皮的 Zay 找到了 Kri 的草稿纸,并把每一组的…...
android studio gradle build running慢 卡住不动 失败 原因与解决方式
快速导航 分析原因解决办法 分析原因 主要原因是 gradle 构建时无法从网络获取需要的包或库。 解决办法 将国外库替换为阿里云镜像库。 例如 google 对应的库是 maven { url ‘https://maven.aliyun.com/repository/google’ }...
如何保障Facebook账号登录稳定
当谈到保障Facebook账号的稳定性时,我们不得不提到那些令人头疼的情况——Facebook账号被封。尽管我们已经踏入数字化的未来,但是被封号似乎是一个时常困扰着社交媒体用户的问题。那么,让我们来看看一些常见的Facebook账号被封的原因…...
当前目录下的excel文件的两列内容的相似度比较
# -- coding: utf-8 --** from sklearn.feature_extraction.text import CountVectorizer from sklearn.metrics.pairwise import cosine_similarity import numpy as np import pandas as pd import os # 获取当前目录 current_dir os.getcwd() # 获取当前目录下所有xlsx文件…...
Cookie for Mac:隐私保护工具保护您的在线隐私
随着互联网的发展,我们每天都会浏览各种网站,享受在线购物、社交娱乐和学习资料等各种便利。然而,您是否曾经遇到过需要频繁输入用户名和密码的情况?或者不方便访问您常用的网站?如果是这样,那么Cookie for…...
Huggingface训练Transformer
在之前的博客中,我采用SFT(监督优化训练)的方法训练一个GPT2的模型,使得这个模型可以根据提示语进行回答。具体可见博客召唤神龙打造自己的ChatGPT_gzroy的博客-CSDN博客 Huggingface提供了一个TRL的扩展库,可以对tra…...
IA-YOLO项目中DIP模块的初级解读
IA-YOLO项目源自论文Image-Adaptive YOLO for Object Detection in Adverse Weather Conditions,其提出端到端方式联合学习CNN-PP和YOLOv3,这确保了CNN-PP可以学习适当的DIP,以弱监督的方式增强图像检测。IA-YOLO方法可以自适应地处理正常和不…...
MathType7.4mac最新版本数学公式编辑器安装教程
MathType7.4中文版是一款功能强大且易于使用的公式编辑器。该软件可与word软件配合使用,有效提高了教学人员的工作效率,避免了一些数学符号和公式无法在word中输入的麻烦。新版MathType7.4启用了全新的LOGO,带来了更多对数学符号和公式的支持…...
为Claude的分析内容做准备:提取PDF页面内容的简易应用程序
由于Claude虽然可以分析整个文件,但是对文件的大小以及字数是有限制的,为了将pdf文件分批传入Claude人工智能分析和总结文章内容,才有了这篇博客: 在本篇博客中,我们将介绍一个基于 wxPython 和 PyMuPDF 库编写的简易的…...
js中作用域的理解?
1.作用域 作用域,即变量(变量作用域又称上下文)和函数生效(能被访问)的区域或集合 换句话说,作用域决定了代码区块中变量和其他资源的可见性 举个例子 function myFunction() {let inVariable "函数内部变量"; } myFunction();//要先执行这…...
机器学习基础之《分类算法(4)—案例:预测facebook签到位置》
一、背景 1、说明 2、数据集 row_id:签到行为的编码 x y:坐标系,人所在的位置 accuracy:定位的准确率 time:时间戳 place_id:预测用户将要签到的位置 3、数据集下载 https://www.kaggle.com/navoshta/gr…...
【Java】反射 之 调用方法
调用方法 我们已经能通过Class实例获取所有Field对象,同样的,可以通过Class实例获取所有Method信息。Class类提供了以下几个方法来获取Method: Method getMethod(name, Class...):获取某个public的Method(包括父类&a…...
Java——单例设计模式
什么是设计模式? 设计模式是在大量的实践中总结和理论化之后优选的代码结构、编程风格、以及解决问题的思考方式。设计模式免去我们自己再思考和摸索。就像是经典的棋谱,不同的棋局,我们用不同的棋谱、“套路”。 经典的设计模式共有23种。…...
Java实现excel表数据的批量存储(结合easyexcel插件)
场景:加哥最近在做项目时,苦于系统自身并未提供数据批量导入的功能还不能自行添加上该功能,且自身不想手动一条一条将数据录入系统。随后,自己使用JDBC连接数据库、使用EasyExcel插件读取表格并将数据按照业务逻辑批量插入数据库完…...
Config:客户端连接服务器访问远程
springcloud-config: springcloud-config push pom <?xml version"1.0" encoding"UTF-8"?> <project xmlns"http://maven.apache.org/POM/4.0.0"xmlns:xsi"http://www.w3.org/2001/XMLSchema-instance"xsi:schemaLocatio…...
【KMP算法-代码随想录】
目录 1.什么是KMP2.什么是next数组3.什么是前缀表(1)前后缀含义(2)最长公共前后缀(3)前缀表的必要性 4.计算前缀表5.前缀表与next数组(1)使用next数组来匹配 6.构造next数组…...
【手写promise——基本功能、链式调用、promise.all、promise.race】
文章目录 前言一、前置知识二、实现基本功能二、实现链式调用三、实现Promise.all四、实现Promise.race总结 前言 关于动机,无论是在工作还是面试中,都会遇到Promise的相关使用和原理,手写Promise也有助于学习设计模式以及代码设计。 本文主…...
计算机网络-笔记-第二章-物理层
目录 二、第二章——物理层 1、物理层的基本概念 2、物理层下面的传输媒体 (1)光纤、同轴电缆、双绞线、电力线【导引型】 (2)无线电波、微波、红外线、可见光【非导引型】 (3)无线电【频谱的使用】 …...
JavaSec-RCE
简介 RCE(Remote Code Execution),可以分为:命令注入(Command Injection)、代码注入(Code Injection) 代码注入 1.漏洞场景:Groovy代码注入 Groovy是一种基于JVM的动态语言,语法简洁,支持闭包、动态类型和Java互操作性,…...
中南大学无人机智能体的全面评估!BEDI:用于评估无人机上具身智能体的综合性基准测试
作者:Mingning Guo, Mengwei Wu, Jiarun He, Shaoxian Li, Haifeng Li, Chao Tao单位:中南大学地球科学与信息物理学院论文标题:BEDI: A Comprehensive Benchmark for Evaluating Embodied Agents on UAVs论文链接:https://arxiv.…...
Debian系统简介
目录 Debian系统介绍 Debian版本介绍 Debian软件源介绍 软件包管理工具dpkg dpkg核心指令详解 安装软件包 卸载软件包 查询软件包状态 验证软件包完整性 手动处理依赖关系 dpkg vs apt Debian系统介绍 Debian 和 Ubuntu 都是基于 Debian内核 的 Linux 发行版ÿ…...
ardupilot 开发环境eclipse 中import 缺少C++
目录 文章目录 目录摘要1.修复过程摘要 本节主要解决ardupilot 开发环境eclipse 中import 缺少C++,无法导入ardupilot代码,会引起查看不方便的问题。如下图所示 1.修复过程 0.安装ubuntu 软件中自带的eclipse 1.打开eclipse—Help—install new software 2.在 Work with中…...
深入解析C++中的extern关键字:跨文件共享变量与函数的终极指南
🚀 C extern 关键字深度解析:跨文件编程的终极指南 📅 更新时间:2025年6月5日 🏷️ 标签:C | extern关键字 | 多文件编程 | 链接与声明 | 现代C 文章目录 前言🔥一、extern 是什么?&…...
SpringCloudGateway 自定义局部过滤器
场景: 将所有请求转化为同一路径请求(方便穿网配置)在请求头内标识原来路径,然后在将请求分发给不同服务 AllToOneGatewayFilterFactory import lombok.Getter; import lombok.Setter; import lombok.extern.slf4j.Slf4j; impor…...
DeepSeek 技术赋能无人农场协同作业:用 AI 重构农田管理 “神经网”
目录 一、引言二、DeepSeek 技术大揭秘2.1 核心架构解析2.2 关键技术剖析 三、智能农业无人农场协同作业现状3.1 发展现状概述3.2 协同作业模式介绍 四、DeepSeek 的 “农场奇妙游”4.1 数据处理与分析4.2 作物生长监测与预测4.3 病虫害防治4.4 农机协同作业调度 五、实际案例大…...
#Uniapp篇:chrome调试unapp适配
chrome调试设备----使用Android模拟机开发调试移动端页面 Chrome://inspect/#devices MuMu模拟器Edge浏览器:Android原生APP嵌入的H5页面元素定位 chrome://inspect/#devices uniapp单位适配 根路径下 postcss.config.js 需要装这些插件 “postcss”: “^8.5.…...
Mysql中select查询语句的执行过程
目录 1、介绍 1.1、组件介绍 1.2、Sql执行顺序 2、执行流程 2.1. 连接与认证 2.2. 查询缓存 2.3. 语法解析(Parser) 2.4、执行sql 1. 预处理(Preprocessor) 2. 查询优化器(Optimizer) 3. 执行器…...
mac 安装homebrew (nvm 及git)
mac 安装nvm 及git 万恶之源 mac 安装这些东西离不开Xcode。及homebrew 一、先说安装git步骤 通用: 方法一:使用 Homebrew 安装 Git(推荐) 步骤如下:打开终端(Terminal.app) 1.安装 Homebrew…...
