学习日志04 java
PTA上的练习复盘
java01 编程题作业感悟:
可以用ai指导自己怎么调试,但是不要把调代码这过程里面的精华交给ai,就是自己去修正错误不能让ai代劳!~~~
1 scanner.close()
Scanner *** = new Scanner(System.in);
***.close();
---------------------------------------------------------------------------------------------------------------------------------
所以后面真的要close的是这个***哦,以前我都会把***写成scanner,还以为所有都是用scanner关闭?!
***表示我自己取的一个变量名
2 其实同scanner输入的变量类型可以一起定义
前面我写的是Scanner sc = new Scanner(System.in);
int a = sc.nextInt();
int b = sc.nextInt();
其实也可以写成
int a = sc.nextInt(),b = sc.nextInt();
3 调试打印方法
例如第一道编程题目里面的——————————————————————————————
调试语句 System.out.println("当前i=" + i + ", sum=" + sum);
4 case
标签的值不需要连续,也不需要按顺序排列。它们可以是任意离散的值
常见误区对比
❌ 错误认知:
// 误以为 case 必须连续(如 1, 2, 3...)
switch (num) {case 1: // 正确case 2: // 正确case 3: // 正确case 5: // ❌ 误以为不允许“跳过”4printf("Number is 1-3 or 5");break;
}
✅ 正确写法:
// case 值可以是任意离散值
switch (num) {case 1: // 允许case 10: // 允许case 100: // 允许printf("Number is 1, 10, or 100");break;case 5: // 位置随意,不影响逻辑printf("Number is 5");break;
}
关键点:
- 值的独立性:每个
case
标签只需要与switch
表达式的类型兼容(如整数、枚举、字符串等)。 - 顺序无关性:
case
标签的顺序不影响匹配逻辑,匹配是通过值直接跳转的。 - 合并规则:连续的
case
标签(无代码间隔)会共享同一个执行块。
5 直观感受自己的不足吧,对比解法!
好的,我将对比分析你的代码与最优雅解法之间的差异,帮助你理解如何优化代码结构和逻辑表达:
你的原始代码(优化后)
java
public class Demo1_2 {public static void main(String[] args) {Scanner scanner = new Scanner(System.in);int limit = scanner.nextInt(),speed = scanner.nextInt();switch (test(limit, speed)) {case 0:System.out.println("Congratulations, you are within the speed limit!");break;case 1:System.out.println("You are speeding and your fine is 100.");break;case 2:System.out.println("You are speeding and your fine is 270.");break;case 3:System.out.println("You are speeding and your fine is 500.");break;}scanner.close();}//我想用switch case语句来实现,需要怎么做?/*一个朴素的想法就是将不同的类型对应其规定为case*/public static int test(int a , int b){int fine = 0;int c =b-a;if(c>= 1&&c<= 20){fine =1;}else if(c>= 21&&c<= 30){fine =2;}else if(c>=31){fine =3;}return fine;}
最优雅解法的核心逻辑
java
int overSpeed = actualSpeed - speedLimit;
if (overSpeed <= 0) {System.out.println("未超速");
} else if (overSpeed <= 20) {System.out.println("罚款100");
} else if (overSpeed <= 30) {System.out.println("罚款270");
} else {System.out.println("罚款500");
}
对比分析
-
函数封装 vs 直接处理
- 你的代码:将逻辑封装在独立函数中,通过返回值(0-3)间接映射罚款金额。这种设计提高了代码复用性,但增加了函数调用的复杂度。
- 优雅解法:直接在
main
方法中处理逻辑,减少了函数调用层级,代码更扁平化。
-
条件判断的简洁性
- 你的代码:使用
c >= 1 && c <= 20
等多条件组合,覆盖每个区间的边界值。 - 优雅解法:利用条件的互斥性,通过
overSpeed <= 20
→overSpeed <= 30
→ 否则 的顺序,隐式覆盖边界值,减少了条件复杂度。
- 你的代码:使用
-
边界值处理
- 你的代码:显式包含边界值(如
c >= 21 && c <= 30
),逻辑更严谨但代码稍冗长。 - 优雅解法:通过条件顺序(如先判断
<=20
再判断<=30
)隐式处理边界,代码更简洁。
- 你的代码:显式包含边界值(如
-
变量命名
- 你的代码:使用
a
、b
、c
作为参数和中间变量,语义不明确。 - 优雅解法:使用
speedLimit
、actualSpeed
、overSpeed
,代码可读性更高。
- 你的代码:使用
优雅解法的优势
- 更少的抽象层次:避免了额外的函数封装和返回值映射,直接输出结果,符合 “最小化抽象” 原则。
- 自然的条件顺序:利用条件的互斥性,按数值范围从小到大判断,逻辑更直观。
- 更清晰的变量命名:直接反映业务含义(限速、实际速度、超速值),减少理解成本。
你的代码的优势
- 可复用性:独立的
test
函数便于在其他场景中复用。 - 扩展性:若后续需要增加更多罚款等级,你的代码结构更易于扩展(只需修改函数内部逻辑)。
总结建议
=========================================================================
- 优先选择简洁性:对于简单问题(如本题),直接在
main
方法中处理逻辑更符合 “KISS 原则”(保持简单愚蠢)。 - 权衡复用性:若逻辑可能在多处使用,封装成独立函数更合理。
- 优化变量命名:使用有明确语义的变量名(如
overSpeed
)提升可读性。 - 简化条件判断:利用条件的互斥性,通过顺序判断隐式处理边界值。
6 在java里面我要输入多组数据,每组数据进行一样的处理,在这个输入的代码块要怎么写?
在 Java 中,处理多组输入数据并对每组数据进行相同操作时,你可以使用循环结合 Scanner 类来实现。以下是几种常见的实现方式:
1. 已知输入组数
如果题目明确告诉你有多少组数据,可以先读取组数,再用循环处理每组数据:
java
import java.util.Scanner;public class Main {public static void main(String[] args) {Scanner scanner = new Scanner(System.in);int n = scanner.nextInt(); // 读取数据组数for (int i = 0; i < n; i++) {// 读取每组数据(示例:读取两个整数)int a = scanner.nextInt();int b = scanner.nextInt();// 处理数据(示例:输出两数之和)System.out.println(a + b);}scanner.close();}
}
2. 未知输入组数,以特定条件结束(如输入 0 结束)
如果题目没有明确告诉你有多少组数据,但指定了结束条件,可以使用 while 循环:
java
import java.util.Scanner;public class Main {public static void main(String[] args) {Scanner scanner = new Scanner(System.in);while (true) {int a = scanner.nextInt();int b = scanner.nextInt();// 判断是否为结束条件(示例:a和b都为0时结束)if (a == 0 && b == 0) {break;}// 处理数据System.out.println(a + b);}scanner.close();}
}
3. 未知输入组数,以文件结束符(EOF)结束
在控制台中,Windows 用户可以按 Ctrl+Z,Linux/Mac 用户可以按 Ctrl+D 来模拟 EOF:
java
import java.util.Scanner;public class Main {public static void main(String[] args) {Scanner scanner = new Scanner(System.in);while (scanner.hasNext()) {int a = scanner.nextInt();int b = scanner.nextInt();// 处理数据System.out.println(a + b);}scanner.close();}
}
4. 每行包含多个数据,处理整行
如果每行包含多个数据,并且需要将整行作为一个字符串处理,可以使用 scanner.nextLine()
:
java
import java.util.Scanner;public class Main {public static void main(String[] args) {Scanner scanner = new Scanner(System.in);while (scanner.hasNextLine()) {String line = scanner.nextLine();// 处理整行数据(示例:分割字符串并求和)String[] parts = line.split(" ");int sum = 0;for (String part : parts) {sum += Integer.parseInt(part);}System.out.println(sum);}scanner.close();}
}
关键说明:
- Scanner 类:用于从标准输入(控制台)读取数据。
- 循环结构:根据题目要求选择
for
循环(已知组数)或while
循环(未知组数)。 - 结束条件:通过判断特定值(如 0)或文件结束符(EOF)来终止循环。
- 数据读取:使用
nextInt()
、nextLine()
等方法读取不同类型的数据。
7 hasNextline是什么用法?(前面提到的)
在 Java 中,Scanner.hasNextLine()
是 Scanner
类的一个方法,用于检查输入源中是否还有下一行数据可读。它通常与 Scanner.nextLine()
方法结合使用,用于逐行读取文本输入。
基本用法
hasNextLine()
返回一个布尔值:
true
:如果输入源中还有下一行(即使是空白行)。false
:如果输入源已结束(例如,用户按下了Ctrl+D
(Linux/Mac)或Ctrl+Z
(Windows))。
示例 1:逐行读取输入
java
import java.util.Scanner;public class Main {public static void main(String[] args) {Scanner scanner = new Scanner(System.in);// 循环读取每一行,直到输入结束while (scanner.hasNextLine()) {String line = scanner.nextLine(); // 读取整行文本System.out.println("你输入的是:" + line);}scanner.close();}
}
运行效果:
输入:Hello World
输出:你输入的是:Hello World
输入:Java is cool
输出:你输入的是:Java is cool
(用户按 Ctrl+D 结束输入)
与其他方法的区别
-
hasNextLine()
vshasNext()
:hasNextLine()
:检查是否还有下一行(无论行内是否有内容)。hasNext()
:检查是否还有下一个标记(默认以空格分隔)。
java
// 输入:Hello World\nJava is cool scanner.hasNext(); // true(下一个标记是 "Hello") scanner.hasNextLine(); // true(下一行是 "Hello World")
-
nextLine()
vsnext()
:nextLine()
:读取一整行(包括换行符),返回的字符串不含换行符。next()
:读取下一个标记(遇到空格、制表符或换行符停止)。
常见场景
场景 1:处理多行输入
java
// 输入:
// 1 2 3
// 4 5 6
// 7 8 9Scanner scanner = new Scanner(System.in);
while (scanner.hasNextLine()) {String line = scanner.nextLine();String[] numbers = line.split(" ");for (String num : numbers) {System.out.println(Integer.parseInt(num));}
}
场景 2:跳过空行
java
while (scanner.hasNextLine()) {String line = scanner.nextLine();if (!line.isEmpty()) { // 忽略空行System.out.println("处理:" + line);}
}
注意事项
-
避免混用
nextLine()
和其他nextXxx()
方法:java
// 错误示例: int num = scanner.nextInt(); // 读取整数后,换行符仍留在缓冲区 String line = scanner.nextLine(); // 直接读取了剩余的换行符,导致跳过输入// 正确做法: int num = scanner.nextInt(); scanner.nextLine(); // 手动消耗掉换行符 String line = scanner.nextLine();
-
输入结束条件:
- 在控制台中,用户需要手动触发结束(
Ctrl+D
或Ctrl+Z
)。 - 如果从文件读取,文件结束时
hasNextLine()
自动返回false
。
- 在控制台中,用户需要手动触发结束(
总结
hasNextLine()
是逐行读取输入的关键方法,适用于:
- 处理多行文本(如文件内容、多行输入)。
- 需要整行处理的场景(如字符串分割、正则匹配)。
- 配合
while
循环实现连续读取,直到输入结束。
8 最大公约数的算法思路
GCD(最大公约数)是指能够同时整除两个数的最大正整数。计算 GCD 最常用的方法是欧几里得算法(辗转相除法),其核心思想是:
对于两个数 a 和 b(a > b),它们的 GCD 等于 b 和 a% b 的 GCD,递归或迭代这个过程直到余数为 0。
欧几里得算法步骤:
- 用较大数除以较小数,得到余数。
- 用较小数除以余数,得到新的余数。
- 重复步骤 2,直到余数为 0。此时的除数就是 GCD。
示例:计算 GCD (48, 18)
- 48 ÷ 18 = 2 余 12 → GCD (48, 18) = GCD (18, 12)
- 18 ÷ 12 = 1 余 6 → GCD (18, 12) = GCD (12, 6)
- 12 ÷ 6 = 2 余 0 → GCD (12, 6) = 6
- 最终结果:GCD (48, 18) = 6
代码实现(Java):
java
// 方法1:递归实现
public static int gcd(int a, int b) {if (b == 0) {return a;}return gcd(b, a % b);
}// 方法2:迭代实现(更高效)
public static int gcd(int a, int b) {while (b != 0) {int temp = b;b = a % b;a = temp;}return a;
}
关键点:
- 递归逻辑:
gcd(a, b) = gcd(b, a % b)
,直到b
为 0。 - 迭代逻辑:用临时变量存储中间值,不断更新
a
和b
直到余数为 0。
9 有关最大公约数最小公倍数的代码修正历程
关键改进点
-
移除冗余的首行读取:
java
// 删除了循环前的这两行 // int x = scanner.nextInt(); // int y = scanner.nextInt();
-
使用
trim()
处理首尾空格:
trim是java里面很好的内置方法哦~~!
-
java
String line = scanner.nextLine().trim();
-
空行检查:
java
if (line.isEmpty()) continue;
10 对比我的修正代码和优雅代码,感受进步
以下是一个更简洁优雅的标准答案,我会标注与你代码的主要区别:
优雅版代码
import java.util.Scanner;public class Demo1_3 {public static void main(String[] args) {try (Scanner scanner = new Scanner(System.in)) { // try-with-resources自动关闭资源while (scanner.hasNextLine()) {String[] parts = scanner.nextLine().trim().split("\\s+"); // 使用\s+处理多个空格int a = Integer.parseInt(parts[0]);int b = Integer.parseInt(parts[1]);System.out.printf("%d %d%n", gcd(a, b), lcm(a, b)); // 格式化输出}} catch (Exception e) {System.err.println("输入格式错误: " + e.getMessage()); // 异常处理}}// 使用递归实现GCD (更简洁)public static int gcd(int a, int b) {return b == 0 ? a : gcd(b, a % b);}public static int lcm(int a, int b) {return Math.abs(a * b) / gcd(a, b); // 处理负数情况}
}
我的代码
import java.util.Arrays;
import java.util.Scanner;
public class {public static void main(String[] args) {Scanner scanner = new Scanner(System.in);while (scanner.hasNextLine()) {String line = scanner.nextLine().trim(); // 读取整行并去除首尾空格if (line.isEmpty()) continue; // 跳过空行//System.out.println("读取的行: " + line);// 分割输入的两个整数String[] parts = line.split(" ");int a = Integer.parseInt(parts[0]);int b = Integer.parseInt(parts[1]);//System.out.println("分割后的部分: " + Arrays.toString(parts));// 计算GCD和LCMint gcdResult = gcd(a, b);int lcmResult = lcm(a, b);// 输出结果System.out.println(gcdResult + " " + lcmResult);}}public static int lcm(int a, int b){// 先除后乘避免溢出return a / gcd(a, b) * b;}public static int gcd(int a,int b) {while (b != 0) {int temp = b;b = a % b;a = temp;}return a;}
}
与你代码的主要区别
特性 | 你的代码 | 优雅版代码 |
---|---|---|
资源管理 | 手动调用scanner.close() | 使用try-with-resources 自动关闭 |
空格处理 | split(" ") | split("\\s+") (处理多个空格) |
GCD 实现 | 迭代循环 | 递归(更简洁) |
异常处理 | 无 | 捕获输入格式错误 |
输出格式 | 字符串拼接 | printf 格式化输出 |
负数处理 | 未处理 | Math.abs() 处理负数 |
关键优化点解释
-
资源自动关闭:
java
try (Scanner scanner = new Scanner(System.in)) {// 代码块结束时自动关闭scanner }
-
正则表达式处理空格:
java
split("\\s+") // 匹配任意数量的空白字符(空格、制表符等)
-
递归 GCD:
java
public static int gcd(int a, int b) {return b == 0 ? a : gcd(b, a % b); }
-
格式化输出:
java
System.out.printf("%d %d%n", gcd, lcm); // 更清晰的输出控制
-
异常处理:
java
catch (Exception e) {System.err.println("输入格式错误: " + e.getMessage()); }
总结
你的代码已经正确实现了核心功能,而优雅版代码主要在以下方面进行了提升:
- 代码简洁性:递归、正则表达式减少了代码量
- 健壮性:异常处理和资源管理更完善
- 可读性:
printf
和方法设计更符合 Java 风格
在实际开发中,建议优先考虑代码的健壮性和可维护性,而不是一味追求简洁。你的实现已经很好,这些优化点可以作为未来的参考!
谢谢ai的点评,/(ㄒoㄒ)/~~,感觉就是这样才能进步啊!!!加油!今天先写到这里啦~明天继续加油~!~!~!~!
相关文章:
学习日志04 java
PTA上的练习复盘 java01 编程题作业感悟: 可以用ai指导自己怎么调试,但是不要把调代码这过程里面的精华交给ai,就是自己去修正错误不能让ai代劳!~~~ 1 scanner.close() Scanner *** new Scanner(System.in); ***.close(); …...
vue-pdf-embed预览PDF
一、vue-pdf-embed 链接:Yarn 1、安装插件 npm install vue-pdf-embed 2、文件中引入(分页效果已实现,样式请自行修改) <template><div class"download-pdf-preview" style"height: 450px; border:1…...
C++GO语言微服务之Dockerfile docker-compose
目录 01 01-知识点概述 02 02-dockerfile复习 03 03-环境变量ENV的使用 04 04-WORKDIR的使用 05 05-USER和ARG的使用 06 06-ONBUILD的使用 07 07-dockerfile的缓存相关的参数 08 08-dockerfile的编写 09 09-测试-没成功-好像是网不行 01 10-docker-compose介绍 02 11…...
【漫话机器学习系列】255.独立同分布(Independent and Identically Distributed,简称 IID)
深入理解独立同分布(IID):机器学习与统计学的基石 在机器学习、深度学习、统计建模等领域,我们经常会遇到一个重要假设:独立同分布(Independent and Identically Distributed,简称 IID…...
树莓派4 yolo 11l.pt性能优化后的版本
树莓派4 使用 Picamera2 拍摄图像,然后通过 YOLO11l.pt 进行目标检测,并在实时视频流中显示结果。但当前的代码在运行时可能会比较卡顿,主要原因包括: picam2.capture_array() 是一个较慢的操作;YOLO 推理可能耗时较长…...
AD22 快速定义PCB板框与DXF导入定义
自行定义板框 1. 初步评估:选中所有的器件,选中‘在矩形区域排列’ 将元件放好后,可以再将元件紧凑一下 2. 设置原点,并在下方选中机械一层 从原点出发,点击快捷键PL 画框线 3. 对线条长度取整,且最好是5…...
LInux系统文件与目录管理(二)
提示:第二部分对第一部分收尾 文章目录 常见的命令如下一、文件查看命令1. more命令2.less命令3.head命令4.tail命令5.nl命令(了解)6.创建目录命令7.创建文件命令>: 覆盖重定向>>: 追加重定向 8.touch命令9.echo命令10.文件或目录复…...
Redisson在业务处理中失败后的应对策略:保障分布式系统的可靠性
分布式系统中的数据一致性与高可用性一直是开发者面临的难题。作为Redis官方推荐的Java客户端,Redisson凭借其强大的分布式能力成为解决这些问题的利器。但在实际业务场景中,网络抖动、资源竞争、节点故障等问题可能导致操作失败,本文将深入探…...
windows下docker 运行 ros2humble arm64
目前要想运行arm版ros humble 目前最好的解决方案是使用qemu模拟。 1.拉取 ubuntu22.04 docker pull ubuntu:22.04 --platformarm642.安装小鱼ros2 humble wget http://fishros.com/install -O fishros && . fishros3.安装eqmu docker run --rm --privileged multia…...
表的增删改查 -- 2
目录 3、查询(R) 3.7、条件查询:where 3.8、分页查询:limit 3.9、查询总结 4、修改(U) 5、删除(D) 3、查询(R) 3.7、条件查询:where selec…...
Linux系统管理与编程20:Apache
兰生幽谷,不为莫服而不芳; 君子行义,不为莫知而止休。 做好网络和yum配置,用前面dns规划的www的IP进行。 #!/bin/bash #----------------------------------------------------------- # File Name: myWeb.sh # Version: 1.0 # …...
dfs 第一次加训 详解 下
目录 P1706 全排列问题 思路 B3618 寻找团伙 思路 B3621 枚举元组 思路 B3622 枚举子集(递归实现指数型枚举) 思路 B3623 枚举排列(递归实现排列型枚举) B3625 迷宫寻路 思路 P6183 [USACO10MAR] The Rock Game S 总结…...
vue2/3 中使用 @vue-office/docx 在网页中预览(docx、excel、pdf)文件
1. 安装依赖: #docx文档预览组件npm install vue-office/docx vue-demi0.14.6#excel文档预览组件npm install vue-office/excel vue-demi0.14.6#pdf文档预览组件npm install vue-office/pdf vue-demi0.14.6 vue2.6版本或以下还需要额外安装 vue/composition-api …...
Excel表的导入与导出
Excel表的导入与导出 根据excel表来建立所需的数据库表格 <dependency><groupId>com.auth0</groupId><artifactId>java-jwt</artifactId><version>3.10.3</version></dependency><dependency><groupId>cn.hutool&…...
Redis 中常见的数据类型有哪些?
Redis 常见的数据类型包括 5 种基础类型(String、Hash、List、Set、Zset)和 3 种特殊类型(HyperLogLog、Bitmap、Geospatial)。以下是详细说明: 一、5 种基础数据类型 1. 字符串(String) 特点…...
消息队列如何保证消息可靠性(kafka以及RabbitMQ)
目录 RabbitMQ保证消息可靠性 生产者丢失消息 MQ丢失消息 消费端丢失了数据 Kakfa的消息可靠性 生产者的消息可靠性 Kakfa的消息可靠性 消费者的消息可靠性 RabbitMQ保证消息可靠性 生产者丢失消息 1.事务消息保证 生产者在发送消息之前,开启事务消息随后生…...
基于STM32、HAL库的BMP390L气压传感器 驱动程序设计
一、简介: BMP390L 是 Bosch Sensortec 生产的一款高精度气压传感器,专为需要精确测量气压和海拔高度的应用场景设计。BMP390L 具有更低的功耗、更高的精度和更快的响应速度。 二、硬件接口: BMP390L 引脚STM32L4XX 引脚说明VDD3.3V电源GNDGND地SCLPB6 (I2C1 SCL)I2C 时钟线…...
QMK键盘固件中LED锁定指示灯的配置与使用详解(实操部分+拓展)
QMK键盘固件中LED锁定指示灯的配置与使用详解 大家好!今天就跟大家一起探索QMK固件中LED锁定指示灯的配置与使用。无论你是键盘DIY新手还是老司机,相信这篇教程都能帮你解锁新技能! 一、基础配置:定义LED引脚 在QMK固件中配置LED锁定指示灯非常简单,只需在config.h文件…...
【日撸 Java 三百行】Day 12(顺序表(二))
目录 Day 12:顺序表(二) 一、顺序表的方法 1. 顺序查找 拓展:顺序查找中的哨兵思想 2. 插入 3. 删除 二、代码及测试 拓展: 小结 Day 12:顺序表(二) Task: 今天…...
Python爬虫实战:研究ajax异步渲染加密
一、引言 在当今数字化时代,数据已成为推动各行业发展的核心驱动力。网络爬虫作为一种高效的数据采集工具,能够从互联网上自动获取大量有价值的信息。然而,随着 Web 技术的不断发展,越来越多的网站采用了 AJAX(Asynchronous JavaScript and XML)异步渲染技术来提升用户体…...
Golang企业级商城高并发微服务实战
Golang企业级商城高并发微服务实战包含内容介绍: 从零开始讲了百万级单体高并发架构、千万级微服务架构,其中包含Rpc实现微服务、微服务的跨语言调用jsonrpc和protobuf、protobuf的安装、protobuf高级语法、protobuf结合Grpc实现微服务实战、微服务服务…...
从经典力扣题发掘DFS与记忆化搜索的本质 -从矩阵最长递增路径入手 一步步探究dfs思维优化与编程深度思考
1引子: DFS和递归法的一道经典例题矩阵最长递增子序列这个题写完之后脑袋产生了许多突发奇想: 1 第一个堆栈代码段这些底层C语言内部管理的工具它是怎么进行内存分配的?能不能深究? 2 第二个这个DFS和计划数组存储的思路到底抽象…...
我开源了一个免费在线工具!UIED Tools
UIED Tools - 免费在线工具集合 最近更新:修改了文档说明,优化了项目结构介绍 这是设计师转开发的第一个开源项目,bug和代码规范可能有些欠缺。 这是一个功能丰富的免费在线工具集合网站,集成了多种实用工具,包括 AI …...
geoserver发布arcgis瓦片地图服务(最新版本)
第一步:下载geoserver服务,进入bin目录启动 需要提前安装好JDK环境,1.8及以上版本 安装完成,页面访问端口,进入控制台界面,默认用户名密码admin/geoserver 第二步:下载地图 破解版全能电子地图下载器&…...
RN 鸿蒙混合开发实践(踩坑)
#三方框架# #React Native # 1 。环境配置; 安装 DevEco 开发工具; Node 版本16; hdc环境配置 hdc 是 OpenHarmony 为开发人员提供的用于调试的命令行工具,鸿蒙 React Native 工程使用 hdc 进行真机调试。hdc 工具通过 OpenHa…...
2025年阿里云ACP大数据分析师认证模拟试题(附答案解析)
这篇文章的内容是阿里云ACP大数据分析师认证考试的模拟试题。 所有模拟试题由AI自动生成,主要为了练习和巩固知识,并非所谓的 “题库”,考试中如果出现同样试题那真是纯属巧合。 1、ABC公司现有大量的图片和视频信息,以下哪种产…...
go语言实现IP归属地查询
效果: 实现代码main.go package mainimport ("encoding/json""fmt""io/ioutil""net/http""os" )type AreaData struct {Continent string json:"continent"Country string json:"country"ZipCode …...
Qt中解决UI线程阻塞导致弹窗无法显示的两种方法
在Qt应用程序开发中,我们经常会遇到这样的问题:当执行一个耗时操作时,整个界面会卡住,无法响应任何用户操作,甚至连一个简单的提示弹窗都无法正常显示。本文将介绍两种解决这个问题的方法,并通过完整的代码示例进行说明。 问题描述 先来看一个常见的错误示例: #inclu…...
位运算题目:黑板异或游戏
文章目录 题目标题和出处难度题目描述要求示例数据范围 解法思路和算法代码复杂度分析 题目 标题和出处 标题:黑板异或游戏 出处:810. 黑板异或游戏 难度 8 级 题目描述 要求 给定一个整数数组 nums \texttt{nums} nums,表示写在黑板…...
LegoGPT,卡内基梅隆大学推出的乐高积木设计模型
LegoGPT 是由卡内基梅隆大学开发的一款创新性乐高积木设计模型,能够根据用户的文本提示生成结构稳固、可组装的乐高模型。该模型基于自回归语言模型和大规模乐高设计数据集进行训练,用户只需输入简单的文字描述,LegoGPT 就能逐步构建出物理稳…...
深度 |国产操作系统“破茧而出”:鸿蒙电脑填补自主生态空白
真心为国内能有像华为这样的技术型公司而自豪,一步步突围技术封锁。从这篇信息,可以给软件从业者一个启示:鸿蒙生态将是一个新的机会,值得好好把握。 鸿蒙电脑正成为中国电子信息技术新坐标。 超10亿鸿蒙生态设备、2800家鸿蒙智…...
【Python】Python常用数据类型判断方法详解
在Python编程中,准确判断数据类型是处理逻辑分支、类型转换和异常处理的基础。本文结合核心方法与实践场景,系统介绍type()、isinstance()等常用判断方式,并分析其适用性与最佳实践。 一、直接类型判断方法 type()函数 • 功能:返回对象的精确类型,适用于简单类型判断。 •…...
【美国将取消对能源之星支持 严重影响AI服务器】
1992年美国政府在共和党执政期间推出了影响深远的“能源之星”计划(Energy Star),很多人可能并不知道能源执行计划,但这个蓝色星星标签估计大多数人都不会陌生。能源之星计划从推出以来不止得到各类消费电子制造商认可,…...
《 C++ 点滴漫谈: 三十七 》左值?右值?完美转发?C++ 引用的真相超乎你想象!
摘要 本文全面系统地讲解了 C 中的引用机制,涵盖左值引用、右值引用、引用折叠、完美转发等核心概念,并深入探讨其底层实现原理及工程实践应用。通过详细的示例与对比,读者不仅能掌握引用的语法规则和使用技巧,还能理解引用在性能…...
【生产实践】Linux中/usr/bin、/usr/sbin与/usr/local的关系解析(2025年技术规范)
一、核心定位与功能划分 /usr/bin:用户级通用命令库 • 定位:存储系统预装的用户级可执行文件,这些命令通常由Linux发行版官方软件包管理器(如APT、YUM)安装,属于系统默认功能的一部分。 • 示例命令&#…...
数据可视化:用一张图讲好一个故事
在这个信息爆炸的时代,数据无处不在,但如何让复杂的数据变得通俗易懂?数据可视化就是一把神奇的钥匙。它不仅能将枯燥的数字转化为生动的图像,还能挖掘出数据背后隐藏的故事。然而,很多人对数据可视化的理解还停留在表…...
C++获取目录中所有图片路径的函数get_image_paths解析
本文将全面解析一个用于获取目录中图片路径的C函数get_image_paths,从基础语法到高级概念,涵盖C标准库、文件系统操作、异常处理等多个方面。 原始代码 std::vector<std::string> get_image_paths(const std::string& directory_path) {log_…...
物联网无线传感方向专业词汇解释
涡旋电磁波(VEMW):一种具有轨道角动量的电磁波,其特性在于能够在传播过程中携带额外的相位信息,从而增加通信系统的容量和灵活性。波前:波动传播过程中,同一时刻振动相位相同的所有点构成的几何曲面,代表波…...
【C语言指针超详解(五)】--回调函数,qsort函数的理解和使用,qsort函数的模拟实现
目录 一.回调函数 1.1--回调函数的概念 1.2--回调函数改造计算器程序 二.qsort函数的理解和使用 2.1--qsort函数的理解 2.2--使用qsort函数排序整型数据 2.3--使用qsort函数排序结构数据 三.qsort函数的模拟实现 🔥个人主页:草莓熊Lotso的个人主…...
【Linux网络】————HTTP协议详解
作者主页: 作者主页 本篇博客专栏:Linux 创作时间 :2025年5月11日 1. HTTP 协议介绍 基本介绍: http协议全称:超文本传输协议,适用于从万维网服务器传输超文本到本地的传送协议。HTTP是一种应用层协议…...
使用WinSW工具将exe注册为window服务
下载工具WinSW(工具在GitHub上 打不开就需要魔法VPN) 文件准备 将以下文件放在同一个目录(例如:WebSocketService 文件夹)中: WebScoket.exe WinSW-x64.exe WebScoketService.xml ← 服务配置文件 install_service.bat ←…...
远程命令执行RCE概述
远程命令执行RCE诞生于1997年,比SQL注入早1年,据说当时的程序员发现在网站里可以随意的删除网页,就像删除本地文件一样简单,但是这种场景相对不多,因此没有SQL注入广泛,早期的web攻击像现在的护网一样&…...
在 .NET 8 开发的WinForms 程序中展示程序版本号的几种方式
前言 欢迎关注dotnet研习社,今天我们讨论一个Winform开发中的一个常见的需求内容“关于程序的版本号显示”。 在 WinForms 桌面应用程序开发中,向用户显示当前程序的版本号是一个常见的需求,尤其是在产品发布、更新提示或技术支持场景中尤为…...
[特殊字符] Spring Cloud 微服务项目中 common 模块依赖导致网关启动失败的排查与解决
在进行微服务开发时,我们通常会抽取一个 common 公共模块,封装一些通用配置类、工具类、拦截器、常用组件依赖等,供多个微服务共享使用。 但近期在实际开发中,出现了一个典型问题:在 Gateway 网关模块中引入 common 后…...
Java SpringMVC 和 MyBatis 整合关键配置详解
目录 一、数据源配置二、MyBatis 工厂配置三、Mapper 扫描配置四、SpringMVC 配置五、整合示例实体类Mapper 接口Mapper XML 文件Service 类控制器JSP 页面六、总结在 Java Web 开发中,SpringMVC 和 MyBatis 是两个常用框架。SpringMVC 负责 Web 层的请求处理和视图渲染,MyBa…...
24.(vue3.x+vite)引入组件并动态挂载(mount)
示例截图 组件代码: <template><div><div>{{message }}</div>...
Linux 软件包|服务管理
rpm 指令备注rpm -qa查看已安装软件,可以结合grep过滤查找rpm -e firefox卸载firefoxrpm -ivh firefox-115.12.0-1.el7.centos.i686.rpm安装gcc(只能离线安装) yum 能够从指定的服务器自动下载 RPM 包并且安装 指令备注yum list列出所有可…...
前端上传el-upload、原生input本地文件pdf格式(纯前端预览本地文件不走后端接口)
前端实现本地文件上传与预览(PDF格式展示)不走后端接口 实现步骤 第一步:文件选择 使用前端原生input上传本地文件,或者是el-upload组件实现文件选择功能,核心在于文件渲染处理。(input只不过可以自定义样…...
TestNG接口自动化
第一章、 Rest assured接口测试框架 一、概述 接口自动化的框架,主要是用来做接口自动化测试,返回的报文都是JSON 语法比较简单,只需要掌握常用的方法 用例运行的速度非常快 断言的机制 Json 封装相关方法,jsonpath,x…...
Parasoft C++Test软件单元测试_实例讲解(指针类型的处理)
系列文章目录 Parasoft C++Test软件静态分析:操作指南(编码规范、质量度量)、常见问题及处理 Parasoft C++Test软件单元测试:操作指南、实例讲解、常见问题及处理 Parasoft C++Test软件集成测试:操作指南、实例讲解、常见问题及处理 进阶扩展:自动生成静态分析文档、自动…...