当前位置: 首页 > news >正文

面试官考我Object类中的所有方法及场景使用?我...

  咦咦咦,各位小可爱,我是你们的好伙伴——bug菌,今天又来给大家普及Java 知识点啦,别躲起来啊,听我讲干货还不快点赞,赞多了我就有动力讲得更嗨啦!所以呀,养成先点赞后阅读的好习惯,别被干货淹没了哦~


🏆本文收录于「Java进阶实战」专栏,数多年Java开发老兵项目累计经验,专业攻坚指数级提升,助你一臂之力,早日实现财富自由🚀,欢迎大家关注&&收藏!持续更新中,up!up!up!!

环境说明:Windows 10 + IntelliJ IDEA 2021.3.2 + Jdk 1.8

  前几日,有位女读者遇到了一个很常见却又不好答的棘手面试题,于是特地向我诉苦了一波,于此,我怎么能见女不救,正所谓救人一命胜造七级浮屠。在此,我们就一起来再来温故一波对象的鼻祖Object类,及它的所有方法及使用场景吧。

解读Object类

  在Java中,我们都知道,Object类是所有类的根类,它位于类层次结构的顶端。Object类提供了一些基本的方法,这些方法被继承到所有的类中。以下是Object类中定义的主要方法及其用法:

toString()

  1. toString() - 返回对象的字符串表示,通常用于打印对象的简要信息。
   Object obj = new Object();System.out.println(obj.toString()); 

默认实现会返回类名@哈希码,源码实现如下:


  如上段代码是Java中用于生成对象的字符串表示形式的常见方法之一。它在默认情况下返回一个由类名和对象的哈希码组成的字符串,格式为类名@哈希码

拓展一下:

  1. getClass().getName() 返回对象所属类的名称。
  2. Integer.toHexString(hashCode()) 将对象的哈希码转换为十六进制字符串表示。

  因此,toString() 方法返回的字符串将类名和对象的哈希码连接在一起,以 @ 符号分隔。这样的字符串并不是特别有用,因为它不提供对象的实际内容信息,但是它可以用于快速检查对象的标识。

示例演示:

equals(Object obj)

  1. equals(Object obj) - 用于比较两个对象是否相等。默认实现是比较对象的引用,即是否为同一个实例。
   Object obj1 = new Object();Object obj2 = obj1;Object obj3 = new Object();System.out.println(obj1.equals(obj2)); // true,因为obj1和obj2是同一个对象System.out.println(obj1.equals(obj3)); // false,因为obj1和obj3是不同的对象

示例演示如下:

hashCode()

  1. hashCode() - 返回对象的哈希码值,该值在equals方法中用于比较对象的相等性。默认实现返回对象的系统标识符。

例如:

   Object obj = new Object();int hash = obj.hashCode();

示例演示:

在这里插入图片描述

getClass()

  1. getClass() - 获取运行时对象的类信息,返回一个Class对象。

例如:

   Object obj = new Object();Class<?> clazz = obj.getClass(); // 获取obj的运行时类类型

示例演示:

在这里插入图片描述

clone()

  1. clone() - 创建并返回对象的一个副本。默认实现是浅拷贝,即复制对象的引用值,而不是实际的内容。

例如:

/*** @Author bug菌* @Source 公众号:猿圈奇妙屋* @Date 2024-04-02 19:02*/
public class testObject implements Cloneable{@Overrideprotected Object clone() throws CloneNotSupportedException {return super.clone();}public static void main(String[] args) {testObject obj = new testObject();try {testObject cloneObj = (testObject) obj.clone(); // 创建obj的一个浅拷贝System.out.println(cloneObj);} catch (CloneNotSupportedException e) {e.printStackTrace();}}
}

示例演示:

在这里插入图片描述

拓展一下:

  在Java中,要使用clone()方法,首先需要确保被克隆的对象的类实现了Cloneable接口。如果一个类没有实现Cloneable接口,调用其clone()方法会抛出CloneNotSupportedException异常。

  另外,clone()这个方法使用了protected访问修饰符,因此只能在同一包内的类或者继承了这个类的子类中访问,因此只能在同一个包内或者子类中使用。

在这里插入图片描述

如果要克隆一个对象,最好的方式是通过实现Cloneable接口并重写clone()方法。示例代码如下:

class MyClass implements Cloneable {// 类的成员和方法@Overrideprotected Object clone() throws CloneNotSupportedException {return super.clone();}
}

然后你可以这样使用:

MyClass obj = new MyClass();
MyClass cloneObj = (MyClass) obj.clone();

  若你直接对Object类的实例调用了clone()方法,但是Object类并没有实现Cloneable接口,会抛出CloneNotSupportedException异常。

wait()

  1. wait() - 使当前线程等待,直到另一个线程调用此对象的notify()notifyAll()方法。
   synchronized (obj) {try {obj.wait(); // 当前线程等待} catch (InterruptedException e) {e.printStackTrace();}}

  示例这里我就先不着急给大家演示,同学们先看下我给大家解读的notify()方法学习后,我再一并给大家演示,毕竟这两是一起连用的,单独用没啥意义。

notify()

  1. notify() - 唤醒在此对象上等待的单个线程(如果有的话)。

使用例如:

   synchronized (obj) {obj.notify(); // 唤醒一个在此对象上等待的线程}

示例演示:

  这里联合notify(),关于Object类中使用wait()及notify()方法的示例演示:

定义启动类,将演示wait()、notify()方法效果。

/*** @Author bug菌* @Source 公众号:猿圈奇妙屋* @Date 2024-04-02 19:38*/
public class WaitNotifyExample {public static void main(String[] args) {Message message = new Message();// 创建一个等待线程Thread waiterThread = new Thread(new Waiter(message));// 创建一个通知线程Thread notifierThread = new Thread(new Notifier(message));// 启动线程waiterThread.start();notifierThread.start();}
}

定义一个Message类,用于在线程之间传递消息

package com.example.javase.bugTest.objectDemo;/*** @Author bug菌* @Source 公众号:猿圈奇妙屋* @Date 2024-04-02 19:38*/
public class Message {private String content;public synchronized String getContent() {return content;}public synchronized void setContent(String content) {this.content = content;}
}

定义一个Waiter类,等待消息并打印。

/*** @Author bug菌* @Source 公众号:猿圈奇妙屋* @Date 2024-04-02 19:38*/
public class Waiter implements Runnable {private Message message;public Waiter(Message message) {this.message = message;}@Overridepublic void run() {synchronized (message) {try {System.out.println("Waiter 等待中...");// 调用wait()方法,等待被通知message.wait();} catch (InterruptedException e) {e.printStackTrace();}// 收到通知后打印消息System.out.println("Waiter 收到通知: " + message.getContent());}}
}

定义一个Notifier类,负责发送通知。

/*** @Author bug菌* @Source 公众号:猿圈奇妙屋* @Date 2024-04-02 19:38*/
// Notifier类负责发送通知
public class Notifier implements Runnable {private Message message;public Notifier(Message message) {this.message = message;}@Overridepublic void run() {synchronized (message) {// 设置消息内容message.setContent("你好,这是一条消息!");// 通知等待线程message.notify();System.out.println("Notifier 发送通知完毕");}}
}

  其中这个示例包含了一个Message类用于在线程之间传递消息,一个Waiter类等待消息并打印,一个Notifier类负责发送通知。在Waiter类中,使用了wait()方法来使线程进入等待状态,直到收到Notifier类发送的通知才继续执行。

实际运行结果展示:

拓展一下:

  如上示例演示了Object类中的wait()和notify()方法的使用,用于线程间的通信和同步。第一,我定义了一个Message类,它包含一个私有的字符串成员变量msg,以及一个getMessage()方法和setMessage()方法用于设置和获取消息。第二,定义了一个Waiter类和一个Notifier类,它们都实现了Runnable接口,用于作为线程执行体。Waiter类中的run()方法中调用了message.waitMessage()方法,而Notifier类中的run()方法中调用了message.setMessage()方法。第三,在WaitNotifyExample类的main()方法中,先创建了一个Message对象,并分别创建了一个等待线程waiterThread和一个通知线程notifierThread,它们都传入了同一个Message对象。最后,通过start()方法启动了这两个线程,实现了等待线程和通知线程的交互。

  总的来说,为大家演示了如何使用wait()和notify()方法实现线程间的等待和通知机制,从而实现线程间的协作。不知道大家可否能及时掌握,有疑问的及时评论区告知于我。

notifyAll()

  1. notifyAll() - 唤醒在此对象上等待的所有线程。

例如:

   synchronized (obj) {obj.notifyAll(); // 唤醒所有在此对象上等待的线程}

示例演示:

1、定义一个MessageProducer类,实现Runnable 接口,定位为一个消息生产者,当执行它的 run() 方法时,它会将一个新消息设置到 message 对象中,并通知所有等待中的线程。

/*** @Author bug菌* @Source 公众号:猿圈奇妙屋* @Date 2024-04-02 19:51*/
public class MessageProducer implements Runnable {private Message message;public MessageProducer(Message message) {this.message = message;}@Overridepublic void run() {synchronized (message) {// 生产消息message.setContent("New message: Hello, world!");// 通知所有等待的线程message.notifyAll();}}
}

2、定义一个MessageConsumer类,实现Runnable 接口,定位为一个消息消费者,目的是实现一个等待消息并处理的逻辑,通过线程的等待和唤醒机制,确保消息在到达后能够及时被消费。

/*** @Author bug菌* @Source 公众号:猿圈奇妙屋* @Date 2024-04-02 19:51*/
public class MessageConsumer implements Runnable {private Message message;public MessageConsumer(Message message) {this.message = message;}@Overridepublic void run() {synchronized (message) {// 等待消息的到来while (message.getContent() == null) {try {// 等待消息通知message.wait();} catch (InterruptedException e) {e.printStackTrace();}}// 收到消息后进行处理System.out.println("Received message: " + message.getContent());}}
}

3、定义一个mian主函数,用于创建生产者和消费者线程,最后通过启动线程,达到生产者线程将消息放入 Message 对象中,而消费者线程则从 Message 对象中获取消息并进行处理的效果。

package com.example.javase.bugTest.objectDemo;/*** @Author bug菌* @Source 公众号:猿圈奇妙屋* @Date 2024-04-02 19:51*/
public class NotifyAllTest {public static void main(String[] args) {// 创建一个共享的消息对象Message message = new Message();// 创建生产者线程和消费者线程Thread producerThread = new Thread(new MessageProducer(message));Thread consumerThread1 = new Thread(new MessageConsumer(message));Thread consumerThread2 = new Thread(new MessageConsumer(message));// 启动线程producerThread.start();consumerThread1.start();consumerThread2.start();}
}

4、执行main函数本地测试结果如下:

  很明显,结果符合预期,生产者将消息传递后且唤醒在此对象上等待的所有线程(所有消费者线程),消费者拿到消息后并进行了打印。

拓展一下:

  如上示例演示了线程间如何通过共享对象进行通信。具体来说,创建了一个名为 NotifyAllTest 的公共类,其中包含一个名为 main 的静态方法。在 main 方法中:

  1. 创建了一个 Message 对象,这是一个自定义的消息对象,用于在生产者和消费者线程之间传递消息。
  2. 创建了一个生产者线程 (producerThread) 和两个消费者线程 (consumerThread1consumerThread2)。
  3. 启动了这三个线程。

  其中,MessageProducer 类和 MessageConsumer 类实现了 Runnable 接口,用于定义生产者和消费者线程的行为。生产者线程将消息放入 Message 对象中,而消费者线程则从 Message 对象中获取消息并进行处理。

  这个示例,我给大家演示了下线程间的基本通信和协作机制,但需要注意的是,它并没有提供线程安全的保障。在实际应用中,可能需要采取额外的措施来确保多线程环境下的数据安全性。

finalize()

  1. finalize() - 在垃圾收集器决定回收对象之前,由垃圾收集器调用此方法。这个 finalize 机制是不确定的,不保证会被调用,且在Java 9中已经被弃用。

简单使用实例例如:

   protected void finalize() throws Throwable {super.finalize();// 清理资源的代码}

示例演示:

好的,下面是一个关于Object类使用finalize()方法的示例:

/*** @Author bug菌* @Source 公众号:猿圈奇妙屋* @Date 2024-04-02 20:08*/
public class FinalizeExample {// 定义一个类来演示finalize()方法static class MyObject {// 在对象销毁前调用finalize()方法@Overrideprotected void finalize() throws Throwable {try {// 执行清理资源的操作System.out.println("对象被销毁前执行finalize()方法");} finally {super.finalize();}}}public static void main(String[] args) {// 创建一个对象MyObject obj = new MyObject();// 将对象设为null,以便触发垃圾回收obj = null;// 强制垃圾回收System.gc();// 等待一段时间以确保finalize()方法被调用try {Thread.sleep(1000);} catch (InterruptedException e) {e.printStackTrace();}}
}

本地执行结果如下:

在这里插入图片描述

  在这个示例中,我定义了一个包含finalize()方法的内部类MyObject。在该方法中,我们可以执行清理资源的操作。在主函数中,我创建了一个MyObject对象,并将其设为null以便触发垃圾回收。然后,我手动调用了System.gc()方法来强制进行垃圾回收。最后,通过让主线程休眠一段时间,等待finalize()方法被调用。

小结

  大多数时候,你可能需要重写这些方法来提供特定的实现。例如,为了正确地比较两个对象是否相等,你可能需要重写equalshashCode方法。同样,为了实现深拷贝,你可能需要重写clone方法。

  请注意,Object类中的wait(), notify()notifyAll()方法是同步控制的一部分,它们只能在对象的监视器(由synchronized关键字实现)被当前线程持有时调用。不当使用这些方法可能导致死锁或其他同步问题。

… …

  ok,以上就是我这期的全部内容啦,如果还想学习更多,你可以看看专栏《Java进阶实战》中的其他硬货,每篇都是实打实的项目实战经验所撰。只要你每天学习一个奇淫小知识,日积月累下去,你一定能成为别人眼中的大佬的!功不唐捐,久久为功!

「赠人玫瑰,手留余香」,咱们下期拜拜~~

☀️建议/推荐你

  无论你是计算机专业的学生,还是对编程感兴趣的跨专业小白,都建议直接入手「滚雪球学Java」专栏;该专栏不仅免费,bug菌还郑重承诺,只要你学习此专栏,均能入门并理解Java SE,以全网最快速掌握Java语言,每章节源码均同步「Gitee」,你真值得拥有;学习就像滚雪球一样,越滚越大,带你指数级提升。

最后,如果这篇文章对你有所帮助,帮忙给作者来个一键三连,关注、点赞、收藏,您的支持就是我坚持写作最大的动力。

同时欢迎大家关注公众号:「猿圈奇妙屋」 ,以便学习更多同Java实战类型技术硬货,还可免费白嫖最新BAT大厂面试真题、4000G Pdf技术书籍、万份简历/PPT模板、技术文章Markdown文档等海量资料,你想要的我都有!

📣关于我

我是bug菌,CSDN | 掘金 | InfoQ | 51CTO | 华为云 | 阿里云 | 腾讯云 等社区博客专家,C站博客之星Top30,华为云2023年度十佳博主,掘金多年度人气作者Top40,51CTO年度博主Top12,掘金/InfoQ/51CTO等社区优质创作者;全网粉丝合计 20w+;硬核微信公众号「猿圈奇妙屋」,欢迎你的加入!免费白嫖最新BAT互联网公司面试真题、4000G PDF电子书籍、简历模板等海量资料,你想要的我都有,关键是你不来拿。


相关文章:

面试官考我Object类中的所有方法及场景使用?我...

咦咦咦&#xff0c;各位小可爱&#xff0c;我是你们的好伙伴——bug菌&#xff0c;今天又来给大家普及Java 知识点啦&#xff0c;别躲起来啊&#xff0c;听我讲干货还不快点赞&#xff0c;赞多了我就有动力讲得更嗨啦&#xff01;所以呀&#xff0c;养成先点赞后阅读的好习惯&a…...

Web前端精通教程:深入探索与实战指南

Web前端精通教程&#xff1a;深入探索与实战指南 在数字化时代&#xff0c;Web前端技术已经成为构建优秀用户体验的基石。想要精通Web前端&#xff0c;不仅需要掌握扎实的基础知识&#xff0c;还需要具备丰富的实战经验和深入的思考。本文将从四个方面、五个方面、六个方面和七…...

四轴飞行器、无人机(STM32、NRF24L01)

一、简介 此电路由STM32为主控芯片&#xff0c;NRF24L01、MPU6050为辅,当接受到信号时&#xff0c;处理对应的指令。 二、实物图 三、部分代码 void FlightPidControl(float dt) { volatile static uint8_t statusWAITING_1; switch(status) { case WAITING_1: //等待解锁 if…...

OpenAI Assistants API:如何使用代码或无需代码创建您自己的AI助手

Its now easier than ever to create your own AI Assistant that can handle a lot of computing tasks for you. See how you can get started with the OpenAI AI Assistant API. 现在比以往任何时候都更容易创建您自己的AI助手&#xff0c;它可以为您处理许多计算任务。了…...

CentOS7 配置Nginx域名HTTPS

Configuring Nginx with HTTPS on CentOS 7 involves similar steps to the ones for Ubuntu, but with some variations in package management and service control. Here’s a step-by-step guide for CentOS 7: Prerequisites Domain Name: “www.xxx.com”Nginx Install…...

C++入门8 构造函数析构函数顺序|拷贝构造

一&#xff0c;构造函数析构函数 调用顺序 我们先来看下面的代码&#xff1a; #define _CRT_SECURE_NO_WARNINGS #include <iostream> #include <cstring> using namespace std; class student { public:char my_name[20];int my_id;student(int a) {my_id a;co…...

【git使用四】git分支理解与操作(详解)

目录 &#xff08;1&#xff09;理解git分支 主分支&#xff08;主线&#xff09; 功能分支 主线和分支关系 将分支合并到主分支 快速合并 非快速合并 git代码管理流程 &#xff08;2&#xff09;理解git提交对象 提交对象与commitID Git如何保存数据 示例讲解 &a…...

【docker】如何解决artalk的跨域访问问题

今天折腾halo的时候&#xff0c;发现artalk出现跨域访问报错&#xff0c;内容如下。 Access to fetch at https://artk.musnow.top/api/stat from origin https://halo.musnow.top has been blocked by CORS policy: The Access-Control-Allow-Origin header contains multipl…...

MYSQL 索引下推 45讲

刘老师群里,看到一位小友 问<MYSQL 45讲>林晓斌的回答 大意是一个组合索引 (a,b,c) 条件 a > 5 and a <10 and b123, 这样的情况下是如何? 林老师给的回答是 A>5 ,然后下推B123 小友 问 "为什么不是先 进行范围查询,然后在索引下推 b123?" 然后就…...

CentOS7服务器中安装openCV4.8的教程

参考链接&#xff1a;Centos7环境下cmake3.25的编译与安装 参考链接&#xff1a;Linux安装或者升级cmake&#xff0c;例子为v3.10.2升级到v3.25.0(自己指定版本) 参考链接&#xff1a;Linux安装Opencv&#xff08;C&#xff09; 一、下载资源 1.下载cmake3.25.0的压缩包&am…...

Java课程设计:基于swing的贪吃蛇小游戏

文章目录 一、项目介绍二、核心代码三、项目展示四、源码获取 一、项目介绍 贪吃蛇是一款经典的休闲益智游戏,自问世以来便深受广大用户的喜爱。这个游戏的基本玩法是控制一条不断增长的蛇,目标是吃掉屏幕上出现的食物,同时避免撞到边缘或自身。随着游戏的进行,蛇的身体会越长…...

【HarmonyOS】HUAWEI DevEco Studio 下载地址汇总

目录 OpenHarmony 4.x Releases 4.1 Release4.0 Release OpenHarmony 3.x Releases 3.2.1 Release3.2 Release3.1.3 Release3.1.2 Release3.1.1 Release3.1 Release 说明 Full SDK&#xff1a;面向OEM厂商提供&#xff0c;包含了需要使用系统权限的系统接口。 Public SDK&am…...

华为OD刷题C卷 - 每日刷题30(小明找位置,分隔均衡字符串)

1、&#xff08;小明找位置&#xff09;&#xff1a; 这段代码是解决“小明找位置”的问题。它提供了一个Java类Main&#xff0c;其中包含main方法和getResult方法&#xff0c;用于帮助小明快速找到他在排队中应该站的位置。 main方法首先读取已排列好的小朋友的学号数组和小…...

SOFTS: 时间序列预测的最新模型以及Python使用示例

近年来&#xff0c;深度学习一直在时间序列预测中追赶着提升树模型&#xff0c;其中新的架构已经逐渐为最先进的性能设定了新的标准。 这一切都始于2020年的N-BEATS&#xff0c;然后是2022年的NHITS。2023年&#xff0c;PatchTST和TSMixer被提出&#xff0c;最近的iTransforme…...

C++ 取近似值

描述 写出一个程序&#xff0c;接受一个正浮点数值&#xff0c;输出该数值的近似整数值。如果小数点后数值大于等于 0.5 ,向上取整&#xff1b;小于 0.5 &#xff0c;则向下取整。 数据范围&#xff1a;保证输入的数字在 32 位浮点数范围内 输入描述&#xff1a; 输入一个正…...

云原生系列之Docker常用命令

&#x1f339;作者主页&#xff1a;青花锁 &#x1f339;简介&#xff1a;Java领域优质创作者&#x1f3c6;、Java微服务架构公号作者&#x1f604; &#x1f339;简历模板、学习资料、面试题库、技术互助 &#x1f339;文末获取联系方式 &#x1f4dd; 系列文章目录 云原生之…...

opencv_GUI

图像入门 import numpy as np import cv2 as cv # 用灰度模式加载图像 img cv.imread(C:/Users/HP/Downloads/basketball.png, 0)# 即使图像路径错误&#xff0c;它也不会抛出任何错误&#xff0c;但是打印 img会给你Nonecv.imshow(image, img) cv.waitKey(5000) # 一个键盘绑…...

FlowUs轻量化AI:趁这波升级专业版,全年无限AI助力笔记产出与二次编写

在数字时代&#xff0c;信息管理与知识产出的效率直接影响个人的生产力。FlowUs作为一款集笔记、文档、多维表、文件夹于一体的新一代知识管理平台&#xff0c;其轻量化AI的加入更是如虎添翼。特别是在活动期间&#xff0c;升级专业版将带来全年无限AI使用次数&#xff0c;让每…...

Day 22:2786. 访问数组中的位置使分数最大

Leetcode 2786. 访问数组中的位置使分数最大 给你一个下标从 0 开始的整数数组 nums 和一个正整数 x 。 你 一开始 在数组的位置 0 处&#xff0c;你可以按照下述规则访问数组中的其他位置&#xff1a; 如果你当前在位置 i &#xff0c;那么你可以移动到满足 i < j 的 任意 …...

理解Es的DSL语法(二):聚合

前一篇已经系统介绍过查询语法&#xff0c;详细可直接看上一篇文章&#xff08;理解DSL语法&#xff08;一&#xff09;&#xff09;&#xff0c;本篇主要介绍DSL中的另一部分&#xff1a;聚合 理解Es中的聚合 虽然Elasticsearch 是一个基于 Lucene 的搜索引擎&#xff0c;但…...

浅谈 React Hooks

React Hooks 是 React 16.8 引入的一组 API&#xff0c;用于在函数组件中使用 state 和其他 React 特性&#xff08;例如生命周期方法、context 等&#xff09;。Hooks 通过简洁的函数接口&#xff0c;解决了状态与 UI 的高度解耦&#xff0c;通过函数式编程范式实现更灵活 Rea…...

(LeetCode 每日一题) 3442. 奇偶频次间的最大差值 I (哈希、字符串)

题目&#xff1a;3442. 奇偶频次间的最大差值 I 思路 &#xff1a;哈希&#xff0c;时间复杂度0(n)。 用哈希表来记录每个字符串中字符的分布情况&#xff0c;哈希表这里用数组即可实现。 C版本&#xff1a; class Solution { public:int maxDifference(string s) {int a[26]…...

Spring Boot 实现流式响应(兼容 2.7.x)

在实际开发中&#xff0c;我们可能会遇到一些流式数据处理的场景&#xff0c;比如接收来自上游接口的 Server-Sent Events&#xff08;SSE&#xff09; 或 流式 JSON 内容&#xff0c;并将其原样中转给前端页面或客户端。这种情况下&#xff0c;传统的 RestTemplate 缓存机制会…...

STM32F4基本定时器使用和原理详解

STM32F4基本定时器使用和原理详解 前言如何确定定时器挂载在哪条时钟线上配置及使用方法参数配置PrescalerCounter ModeCounter Periodauto-reload preloadTrigger Event Selection 中断配置生成的代码及使用方法初始化代码基本定时器触发DCA或者ADC的代码讲解中断代码定时启动…...

HBuilderX安装(uni-app和小程序开发)

下载HBuilderX 访问官方网站&#xff1a;https://www.dcloud.io/hbuilderx.html 根据您的操作系统选择合适版本&#xff1a; Windows版&#xff08;推荐下载标准版&#xff09; Windows系统安装步骤 运行安装程序&#xff1a; 双击下载的.exe安装文件 如果出现安全提示&…...

ElasticSearch搜索引擎之倒排索引及其底层算法

文章目录 一、搜索引擎1、什么是搜索引擎?2、搜索引擎的分类3、常用的搜索引擎4、搜索引擎的特点二、倒排索引1、简介2、为什么倒排索引不用B+树1.创建时间长,文件大。2.其次,树深,IO次数可怕。3.索引可能会失效。4.精准度差。三. 倒排索引四、算法1、Term Index的算法2、 …...

Spring Boot+Neo4j知识图谱实战:3步搭建智能关系网络!

一、引言 在数据驱动的背景下&#xff0c;知识图谱凭借其高效的信息组织能力&#xff0c;正逐步成为各行业应用的关键技术。本文聚焦 Spring Boot与Neo4j图数据库的技术结合&#xff0c;探讨知识图谱开发的实现细节&#xff0c;帮助读者掌握该技术栈在实际项目中的落地方法。 …...

Android15默认授权浮窗权限

我们经常有那种需求&#xff0c;客户需要定制的apk集成在ROM中&#xff0c;并且默认授予其【显示在其他应用的上层】权限&#xff0c;也就是我们常说的浮窗权限&#xff0c;那么我们就可以通过以下方法在wms、ams等系统服务的systemReady()方法中调用即可实现预置应用默认授权浮…...

QT: `long long` 类型转换为 `QString` 2025.6.5

在 Qt 中&#xff0c;将 long long 类型转换为 QString 可以通过以下两种常用方法实现&#xff1a; 方法 1&#xff1a;使用 QString::number() 直接调用 QString 的静态方法 number()&#xff0c;将数值转换为字符串&#xff1a; long long value 1234567890123456789LL; …...

第 86 场周赛:矩阵中的幻方、钥匙和房间、将数组拆分成斐波那契序列、猜猜这个单词

Q1、[中等] 矩阵中的幻方 1、题目描述 3 x 3 的幻方是一个填充有 从 1 到 9 的不同数字的 3 x 3 矩阵&#xff0c;其中每行&#xff0c;每列以及两条对角线上的各数之和都相等。 给定一个由整数组成的row x col 的 grid&#xff0c;其中有多少个 3 3 的 “幻方” 子矩阵&am…...