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

面试准备——Java理论高级【笔试,面试的核心重点】

集合框架

Java集合框架是面试中的重中之重,尤其是对ListSetMap的实现类及其底层原理的考察。

1. List

  • ArrayList

    • 底层是动态数组,支持随机访问(通过索引),时间复杂度为O(1)。
    • 插入和删除元素时,如果是在中间位置,需要移动后续元素,时间复杂度为O(n)。
    • 扩容机制:默认初始容量为10,扩容时增加为原来的1.5倍。
    • 线程不安全

    面试问题

    • ArrayList的扩容机制是什么?
    • ArrayList和LinkedList的区别?

    案例

    List<Integer> list = new ArrayList<>();
    list.add(1); // 添加元素
    list.get(0); // 获取元素
    list.remove(0); // 删除元素
    
  • LinkedList

    • 底层是双向链表,适合频繁的插入和删除操作,时间复杂度为O(1)。
    • 随机访问效率低,时间复杂度为O(n)。
    • 线程不安全

    面试问题

    • LinkedList的实现原理是什么?
    • 如何实现一个LRU缓存?(可以用LinkedList实现)

    案例

    List<Integer> linkedList = new LinkedList<>();
    linkedList.add(1);
    linkedList.add(2);
    linkedList.remove(1); // 删除元素
    

2. Set

  • HashSet

    • 基于HashMap实现,元素无序且不允许重复。
    • 添加元素时,先计算哈希值,再通过equals方法判断是否重复。
    • 线程不安全

    面试问题

    • HashSet如何保证元素唯一性?
    • HashSet和TreeSet的区别?

    案例

    Set<String> set = new HashSet<>();
    set.add("A");
    set.add("B");
    set.add("A"); // 不会重复添加
    
  • TreeSet

    • 基于TreeMap实现,元素按自然顺序或自定义顺序排序。
    • 内部使用红黑树实现,插入、删除、查找的时间复杂度为O(log n)。
    • 线程不安全

    案例

    Set<Integer> treeSet = new TreeSet<>();
    treeSet.add(3);
    treeSet.add(1);
    treeSet.add(2);
    System.out.println(treeSet); // 输出 [1, 2, 3]
    

3. Map

  • HashMap

    • 基于哈希表实现,允许null键和null值。
    • 扩容机制:默认初始容量为16,负载因子为0.75,扩容时容量变为原来的2倍。
    • 线程不安全

    面试问题

    • HashMap的底层实现原理?
    • HashMap如何解决哈希冲突?(链地址法)
    • JDK 1.8中HashMap的优化?(引入红黑树)

    案例

    Map<String, Integer> map = new HashMap<>();
    map.put("A", 1);
    map.put("B", 2);
    map.get("A"); // 获取值
    
  • ConcurrentHashMap

    • 线程安全的HashMap,JDK 1.8之前使用分段锁,JDK 1.8之后使用CAS + synchronized。
    • 面试问题
      • ConcurrentHashMap如何保证线程安全?
      • ConcurrentHashMap的锁粒度是什么?

    案例

    Map<String, Integer> concurrentMap = new ConcurrentHashMap<>();
    concurrentMap.put("A", 1);
    concurrentMap.put("B", 2);
    

File API

File API用于操作文件和目录,常见操作包括创建、删除、重命名、遍历等。

常见面试问题

  1. 如何递归遍历目录下的所有文件?

    • 使用递归或Files.walk()方法。

    案例

    public void listFiles(File dir) {if (dir.isDirectory()) {File[] files = dir.listFiles();for (File file : files) {if (file.isDirectory()) {listFiles(file); // 递归} else {System.out.println(file.getName());}}}
    }
    
  2. 如何读取大文件?

    • 使用BufferedReader逐行读取。

    案例

    try (BufferedReader br = new BufferedReader(new FileReader("largeFile.txt"))) {String line;while ((line = br.readLine()) != null) {System.out.println(line);}
    }
    

IO

Java IO分为字节流和字符流,常见类包括InputStreamOutputStreamReaderWriter

常见面试问题

  1. 字节流 vs 字符流的区别?

    • 字节流以字节为单位操作数据,适合处理二进制文件(如图片、视频)。
    • 字符流以字符为单位操作数据,适合处理文本文件。

    案例

    // 字节流
    try (FileInputStream fis = new FileInputStream("input.txt");FileOutputStream fos = new FileOutputStream("output.txt")) {int data;while ((data = fis.read()) != -1) {fos.write(data);}
    }// 字符流
    try (FileReader fr = new FileReader("input.txt");FileWriter fw = new FileWriter("output.txt")) {int data;while ((data = fr.read()) != -1) {fw.write(data);}
    }
    
  2. NIO是什么?

    • NIO(Non-blocking IO)是Java提供的高性能IO API,基于通道(Channel)和缓冲区(Buffer)操作。
    • 核心组件ChannelBufferSelector

    案例

    try (FileChannel channel = FileChannel.open(Paths.get("input.txt"), StandardOpenOption.READ)) {ByteBuffer buffer = ByteBuffer.allocate(1024);while (channel.read(buffer) > 0) {buffer.flip();while (buffer.hasRemaining()) {System.out.print((char) buffer.get());}buffer.clear();}
    }
    

线程

线程是Java并发编程的核心,面试中常考线程的创建、生命周期、同步机制等。

常见面试问题

  1. 如何实现线程同步?

    • 使用synchronized关键字或ReentrantLock

    案例

    class Counter {private int count = 0;public synchronized void increment() {count++;}public int getCount() {return count;}
    }
    
  2. wait()、notify()、notifyAll()的作用?

    • 用于线程间的通信,wait()使线程等待,notify()唤醒一个等待线程,notifyAll()唤醒所有等待线程。

    案例

    class SharedResource {private boolean flag = false;public synchronized void produce() {while (flag) {try {wait();} catch (InterruptedException e) {e.printStackTrace();}}flag = true;notify();}public synchronized void consume() {while (!flag) {try {wait();} catch (InterruptedException e) {e.printStackTrace();}}flag = false;notify();}
    }
    

线程池

线程池是面试中的高频考点,尤其是对ThreadPoolExecutor的参数和原理的考察。

常见面试问题

  1. 线程池的核心参数有哪些?

    • corePoolSize:核心线程数。
    • maximumPoolSize:最大线程数。
    • keepAliveTime:空闲线程存活时间。
    • workQueue:任务队列。
    • threadFactory:线程工厂。
    • handler:拒绝策略。
  2. 线程池的拒绝策略有哪些?

    • AbortPolicy:直接抛出异常。
    • CallerRunsPolicy:由调用线程处理任务。
    • DiscardOldestPolicy:丢弃队列中最老的任务。
    • DiscardPolicy:直接丢弃任务。

    案例

    ThreadPoolExecutor executor = new ThreadPoolExecutor(2, // corePoolSize5, // maximumPoolSize60, // keepAliveTimeTimeUnit.SECONDS,new LinkedBlockingQueue<>(10),Executors.defaultThreadFactory(),new ThreadPoolExecutor.CallerRunsPolicy()
    );
    

问题答案


ArrayList的扩容机制是什么?

  • 答案

    • ArrayList的底层是一个动态数组,初始容量为10。
    • 当元素数量超过当前容量时,ArrayList会自动扩容。
    • 扩容时,新容量通常是旧容量的1.5倍(即oldCapacity + (oldCapacity >> 1))。
    • 扩容过程会创建一个新的数组,并将旧数组中的元素复制到新数组中。

    示例

    ArrayList<Integer> list = new ArrayList<>();
    for (int i = 0; i < 20; i++) {list.add(i); // 当元素数量超过10时,ArrayList会自动扩容
    }
    

ArrayList和LinkedList的区别?

  • 答案

    • 底层实现
      • ArrayList基于动态数组,支持随机访问,时间复杂度为O(1)。
      • LinkedList基于双向链表,插入和删除操作效率高,时间复杂度为O(1),但随机访问效率低,时间复杂度为O(n)。
    • 内存占用
      • ArrayList占用连续内存空间。
      • LinkedList占用非连续内存空间,每个节点需要额外存储前后节点的引用。
    • 适用场景
      • ArrayList适合频繁查询的场景。
      • LinkedList适合频繁插入和删除的场景。

    示例

    List<Integer> arrayList = new ArrayList<>();
    arrayList.add(1); // 适合查询
    arrayList.get(0); // O(1)List<Integer> linkedList = new LinkedList<>();
    linkedList.add(1); // 适合插入和删除
    linkedList.remove(0); // O(1)
    

HashSet如何保证元素唯一性?

  • 答案

    • HashSet基于HashMap实现,元素存储在HashMap的键中。
    • 添加元素时,先计算元素的哈希值(通过hashCode()方法),然后通过equals()方法判断是否重复。
    • 如果哈希值相同且equals()返回true,则认为元素重复,不会添加。

    示例

    Set<String> set = new HashSet<>();
    set.add("A");
    set.add("B");
    set.add("A"); // 不会重复添加
    

HashMap的底层实现原理?

  • 答案

    • HashMap基于哈希表实现,底层是数组 + 链表(JDK 1.8之前)或数组 + 链表 + 红黑树(JDK 1.8之后)。
    • 添加元素时,先计算键的哈希值,然后通过哈希值找到数组中的位置(桶)。
    • 如果发生哈希冲突(即多个键映射到同一个桶),则使用链表或红黑树存储冲突的元素。
    • 当链表长度超过8时,链表会转换为红黑树,以提高查找效率。

    示例

    Map<String, Integer> map = new HashMap<>();
    map.put("A", 1);
    map.put("B", 2);
    map.get("A"); // 获取值
    

LinkedList的实现原理是什么?

  • 答案

    • LinkedList是基于双向链表实现的。
    • 每个节点(Node)包含三个部分:
      • 数据域(存储元素值)。
      • 前驱指针(指向前一个节点)。
      • 后继指针(指向后一个节点)。
    • 链表的头节点(first)和尾节点(last)分别指向链表的第一个和最后一个节点。
    • 插入和删除操作只需要修改节点的指针,时间复杂度为O(1)。
    • 随机访问需要从头节点或尾节点遍历,时间复杂度为O(n)。

    示例

    LinkedList<Integer> list = new LinkedList<>();
    list.add(1); // 添加到链表尾部
    list.add(2);
    list.remove(1); // 删除元素
    

如何实现一个LRU缓存?(可以用LinkedList实现)

  • 答案

    • LRU(Least Recently Used)缓存是一种淘汰最近最少使用数据的缓存策略。
    • 可以使用LinkedList + HashMap实现:
      • LinkedList用于维护数据的访问顺序,最近访问的数据放在链表头部。
      • HashMap用于快速查找数据。

    实现步骤

    1. 当访问一个数据时,如果数据在缓存中,则将其移动到链表头部。
    2. 如果数据不在缓存中,则将其添加到链表头部。
    3. 如果缓存已满,则移除链表尾部的数据。

    示例

    class LRUCache<K, V> {private final int capacity;private final Map<K, V> map;private final LinkedList<K> list;public LRUCache(int capacity) {this.capacity = capacity;this.map = new HashMap<>();this.list = new LinkedList<>();}public V get(K key) {if (map.containsKey(key)) {list.remove(key); // 移除旧位置list.addFirst(key); // 放到链表头部return map.get(key);}return null;}public void put(K key, V value) {if (map.containsKey(key)) {list.remove(key); // 移除旧位置} else if (map.size() >= capacity) {K lastKey = list.removeLast(); // 移除链表尾部数据map.remove(lastKey);}list.addFirst(key); // 放到链表头部map.put(key, value);}
    }
    

HashSet和TreeSet的区别?

  • 答案

    • 底层实现
      • HashSet基于HashMap实现,元素无序。
      • TreeSet基于TreeMap实现,元素按自然顺序或自定义顺序排序。
    • 性能
      • HashSet的插入、删除、查找操作的时间复杂度为O(1)。
      • TreeSet的插入、删除、查找操作的时间复杂度为O(log n)。
    • 适用场景
      • HashSet适合需要快速查找且不关心顺序的场景。
      • TreeSet适合需要有序数据的场景。

    示例

    Set<Integer> hashSet = new HashSet<>();
    hashSet.add(3);
    hashSet.add(1);
    hashSet.add(2);
    System.out.println(hashSet); // 输出顺序不确定Set<Integer> treeSet = new TreeSet<>();
    treeSet.add(3);
    treeSet.add(1);
    treeSet.add(2);
    System.out.println(treeSet); // 输出 [1, 2, 3]
    

HashMap如何解决哈希冲突?(链地址法)

  • 答案

    • HashMap使用链地址法解决哈希冲突。
    • 当多个键映射到同一个桶(数组位置)时,HashMap会将这些键值对存储在同一个链表中。
    • 在JDK 1.8中,当链表长度超过8时,链表会转换为红黑树,以提高查找效率。

    示例

    Map<String, Integer> map = new HashMap<>();
    map.put("A", 1);
    map.put("B", 2);
    map.put("C", 3);
    // 假设 "A" 和 "B" 的哈希值相同,它们会被存储在同一个链表中
    

JDK 1.8中HashMap的优化?(引入红黑树)

  • 答案

    • 在JDK 1.8中,HashMap引入了红黑树来优化性能。
    • 当链表长度超过8时,链表会转换为红黑树,查找时间复杂度从O(n)降低到O(log n)。
    • 当红黑树的节点数少于6时,红黑树会退化为链表。

    优化点

    • 提高了哈希冲突严重时的查找效率。
    • 减少了链表过长时的性能问题。

    示例

    Map<String, Integer> map = new HashMap<>();
    for (int i = 0; i < 100; i++) {map.put("Key" + i, i);
    }
    // 当链表长度超过8时,会自动转换为红黑树
    

ConcurrentHashMap的锁粒度是什么?

  • 答案

    • 在JDK 1.7中,ConcurrentHashMap使用分段锁(Segment),每个段独立加锁,锁粒度是段级别。
    • 在JDK 1.8中,ConcurrentHashMap使用CAS + synchronized,锁粒度是桶级别(数组中的每个位置)。
      • 对每个桶(数组中的每个位置)使用synchronized锁。
      • 使用CAS操作保证原子性。

    示例

    Map<String, Integer> concurrentMap = new ConcurrentHashMap<>();
    concurrentMap.put("A", 1);
    concurrentMap.put("B", 2);
    

ConcurrentHashMap如何保证线程安全?

  • 答案

    • 在JDK 1.7中,ConcurrentHashMap使用分段锁(Segment),每个段独立加锁。
    • 在JDK 1.8中,ConcurrentHashMap使用CAS(Compare-And-Swap) + synchronized实现线程安全。
      • 对每个桶(数组中的每个位置)使用synchronized锁。
      • 使用CAS操作保证原子性。

    示例

    Map<String, Integer> concurrentMap = new ConcurrentHashMap<>();
    concurrentMap.put("A", 1);
    concurrentMap.put("B", 2);
    

如何递归遍历目录下的所有文件?

  • 答案

    • 使用递归方法遍历目录及其子目录。
    • 对于每个文件,如果是目录,则递归调用;如果是文件,则输出文件名。

    示例

    public void listFiles(File dir) {if (dir.isDirectory()) {File[] files = dir.listFiles();for (File file : files) {if (file.isDirectory()) {listFiles(file); // 递归} else {System.out.println(file.getName());}}}
    }
    

字节流 vs 字符流的区别?

  • 答案

    • 字节流:以字节为单位操作数据,适合处理二进制文件(如图片、视频)。
      • 核心类:InputStreamOutputStream
    • 字符流:以字符为单位操作数据,适合处理文本文件。
      • 核心类:ReaderWriter

    示例

    // 字节流
    try (FileInputStream fis = new FileInputStream("input.txt");FileOutputStream fos = new FileOutputStream("output.txt")) {int data;while ((data = fis.read()) != -1) {fos.write(data);}
    }// 字符流
    try (FileReader fr = new FileReader("input.txt");FileWriter fw = new FileWriter("output.txt")) {int data;while ((data = fr.read()) != -1) {fw.write(data);}
    }
    

如何实现线程同步?

  • 答案

    • 使用synchronized关键字或ReentrantLock实现线程同步。
    • synchronized可以修饰方法或代码块,确保同一时刻只有一个线程访问共享资源。

    示例

    class Counter {private int count = 0;public synchronized void increment() {count++;}public int getCount() {return count;}
    }
    

线程池的核心参数有哪些?

  • 答案

    • corePoolSize:核心线程数。
    • maximumPoolSize:最大线程数。
    • keepAliveTime:空闲线程存活时间。
    • workQueue:任务队列。
    • threadFactory:线程工厂。
    • handler:拒绝策略。

    示例

    ThreadPoolExecutor executor = new ThreadPoolExecutor(2, // corePoolSize5, // maximumPoolSize60, // keepAliveTimeTimeUnit.SECONDS,new LinkedBlockingQueue<>(10),Executors.defaultThreadFactory(),new ThreadPoolExecutor.CallerRunsPolicy()
    );
    

线程池的拒绝策略有哪些?

  • 答案

    • AbortPolicy:直接抛出异常。
    • CallerRunsPolicy:由调用线程处理任务。
    • DiscardOldestPolicy:丢弃队列中最老的任务。
    • DiscardPolicy:直接丢弃任务。

    示例

    ThreadPoolExecutor executor = new ThreadPoolExecutor(2, 5, 60, TimeUnit.SECONDS,new LinkedBlockingQueue<>(10),Executors.defaultThreadFactory(),new ThreadPoolExecutor.CallerRunsPolicy()
    );
    

哈希表核心原理

相关文章:

面试准备——Java理论高级【笔试,面试的核心重点】

集合框架 Java集合框架是面试中的重中之重&#xff0c;尤其是对List、Set、Map的实现类及其底层原理的考察。 1. List ArrayList&#xff1a; 底层是动态数组&#xff0c;支持随机访问&#xff08;通过索引&#xff09;&#xff0c;时间复杂度为O(1)。插入和删除元素时&#…...

AI伴读-清华大学104页《DeepSeek:从入门到精通》

辅助工具&#xff1a;deepseek、豆包AI伴读 官网&#xff1a;DeepSeekDeepSeek, unravel the mystery of AGI with curiosity. Answer the essential question with long-termism.https://www.deepseek.com/https://www.deepseek.com/清华大学104页《DeepSeek&#xff1a;从入…...

unity学习34:角色相关3,触发器trigger,铰链 hingejoint 等 spring joint, fixed joint

目录 1 触发的实现条件 1.1 碰撞的的实现条件 1.2 触发的实现条件 1.3 触发器trigger&#xff0c;直接拿 碰撞器collider修改下配置即可 2 触发器相关实验&#xff1a;触发开门效果 2.0 目标 2.1 player物体的属性 2.2 新建一个trigger 物体 2.3 新建一个被trigger 控…...

HarmonyOS Next 方舟字节码文件格式介绍

在开发中&#xff0c;可读的编程语言要编译成二进制的字节码格式才能被机器识别。在HarmonyOS Next开发中&#xff0c;arkts会编译成方舟字节码。方舟字节码长什么样呢&#xff1f;我们以一个demo编译出的abc文件&#xff1a; 二进制就是长这样&#xff0c;怎么去理解呢&…...

计算机视觉语义分割——Attention U-Net(Learning Where to Look for the Pancreas)

计算机视觉语义分割——Attention U-Net(Learning Where to Look for the Pancreas) 文章目录 计算机视觉语义分割——Attention U-Net(Learning Where to Look for the Pancreas)摘要Abstract一、Attention U-Net1. 基本思想2. Attention Gate模块3. 软注意力与硬注意力4. 实验…...

html 列动态布局

样式说明&#xff1a; /* 列动态布局&#xff0c;列之间以空格填充 */ li {display: flex;/* flex-direction: column; */justify-content: space-between; }...

DeepSeek开源多模态大模型Janus-Pro部署

DeepSeek多模态大模型部署 请自行根据电脑配置选择合适环境配置安装conda以及gitJanus 项目以及依赖安装运行cpu运行gpu运行 进入ui界面 请自行根据电脑配置选择合适 本人家用电脑为1060&#xff0c;因此部署的7B模型。配置高的可以考虑更大参数的模型。 环境配置 安装conda…...

DeepSeek结合Langchain的基本用法

DeepSeek结合Langchain的基本用法 DeepSeek 基于Openai接口规范的Prompt应答Deepseek结合LangchainDeepSeek 基于langchain的结构化返回 DeepSeek 基于Openai接口规范的Prompt应答 首先我们需要先基于pip 安装 pip install openai最开始我们先熟悉如何使用openai的接口规范&a…...

Redis持久化的两种方式:RDB和AOF

redis中的数据存储在缓存中&#xff0c;如果没有持久化的策略&#xff0c;Redis一旦宕机&#xff0c;那么将会导致数据丢失&#xff1b;因此redis提供了以下两种持久化方式&#xff1a;RDB和AOF 一般来说&#xff0c;大部分公司对这两种方式都是同时开启的 一、RDB RDB策略全…...

每日一题——131.分割回文串

题目链接&#xff1a;131. 分割回文串 - 力扣&#xff08;LeetCode&#xff09; 代码&#xff1a; class Solution { private:vector<vector<string>> result;vector<string> path;void backtracking (const string& s,int startindex){if(startindex …...

内容中台赋能人工智能技术提升业务创新能力

内容概要 在当今快速变化的市场环境中&#xff0c;企业需要不断寻求创新以保持竞争力。内容中台作为一种新型的内容管理架构&#xff0c;能够极大地提升企业在内容创建、管理和分发方面的效率。通过与人工智能技术的深度融合&#xff0c;企业能够将海量的数据和信息转化为有价…...

第七节 文件与流

基本的输入输出&#xff08;iostream&#xff09; C标准库提供了一组丰富的输入/输出功能&#xff0c;C的I/O发生在流中&#xff0c;流是字节序列。如果字节流是从设备&#xff08;键盘、磁盘驱动器、网络连接等&#xff09;流向内存&#xff0c;叫做输入操作。如果字节流是从…...

软件工程 项目管理

软件项目管理中可以分成两部分: 软件创新 软件项目管理项目是定义明确的任务&#xff0c;这是为了实现某个目标&#xff08;例如&#xff0c;软件开发和交付&#xff09;进行的一系列操作的集合。一个项目可以表征为: 每个项目都可以有一个独特而鲜明的目标。 项目不是日常活…...

通过类加载和初始化的一些题目理解Java类加载过程

通过题目重点理解&#xff1a;Class加载流程和运行时区域 目录 子类和父类static变量父子类加载顺序2class.forName初始化 子类和父类static变量 class Parent {static int a 1;static int b 2;static int c;static {c 3;System.out.println("parent static block&quo…...

LLMs之DeepSeek r1:TinyZero的简介、特点、安装和使用方法、案例应用Logic-RL的简介、安装和使用方法、案例应用之详细攻略

LLMs之DeepSeek r1&#xff1a;TinyZero的简介、特点、安装和使用方法、案例应用Logic-RL的简介、安装和使用方法、案例应用之详细攻略 目录 TinyZero的简介 1、TinyZero的特点 TinyZero的安装和使用方法 1、安装 创建 conda 环境 数据准备 (倒计时任务) 多GPU (适用于 …...

爬取豆瓣电影 Top250 数据的脚本及调整方法

以下是一个完整的 Python 脚本,用于爬取豆瓣电影 Top250 的数据,包括电影名称、评分和短评。同时,我将提供应对豆瓣页面结构更新和反爬虫机制的调整方法。 安装必要的库 首先,确保安装了必要的库: bash复制 pip install requests beautifulsoup4 pandas示例代码 Pyth…...

Deepseek 接入Word处理对话框(隐藏密钥)

硅基流动邀请码&#xff1a;1zNe93Cp 邀请链接&#xff1a;网页链接 亲测deepseek接入word&#xff0c;自由调用对话&#xff0c;看截图有兴趣的复用代码&#xff08;当然也可以自己向deepseek提问&#xff0c;帮助你完成接入&#xff0c;但是提问逻辑不一样给出的答案是千差万…...

Jupyter Notebook自动保存失败等问题的解决

一、未生成配置文件 需要在命令行中&#xff0c;执行下面的命令自动生成配置文件 jupyter notebook --generate-config 执行后会在 C:\Users\用户名\.jupyter目录中生成文件 jupyter_notebook_config.py 二、在网页端打开Jupyter Notebook后文件保存失败&#xff1b;运行代码…...

基于机器学习时序库pmdarima实现时序预测

目录 一、Pmdarima实现单变量序列预测1.1 核心功能与特性1.2 技术优势对比1.3 python案例1.3.1 时间序列交叉验证1.3.1.1 滚动交叉验证1.3.1.2 滑窗交叉验证 时间序列相关参考文章&#xff1a; 时间序列预测算法—ARIMA 基于VARMAX模型的多变量时序数据预测 基于机器学习时序库…...

Dart语言的云计算

Dart语言在云计算中的应用 引言 云计算作为一种新兴的计算模式&#xff0c;为各行各业带来了重大变革。借助于云计算&#xff0c;用户可以通过互联网获取和使用各种资源&#xff0c;如计算能力、存储、数据库等。随着云计算的快速发展&#xff0c;编程语言的选择变得愈发重要…...

从WWDC看苹果产品发展的规律

WWDC 是苹果公司一年一度面向全球开发者的盛会&#xff0c;其主题演讲展现了苹果在产品设计、技术路线、用户体验和生态系统构建上的核心理念与演进脉络。我们借助 ChatGPT Deep Research 工具&#xff0c;对过去十年 WWDC 主题演讲内容进行了系统化分析&#xff0c;形成了这份…...

R语言AI模型部署方案:精准离线运行详解

R语言AI模型部署方案:精准离线运行详解 一、项目概述 本文将构建一个完整的R语言AI部署解决方案,实现鸢尾花分类模型的训练、保存、离线部署和预测功能。核心特点: 100%离线运行能力自包含环境依赖生产级错误处理跨平台兼容性模型版本管理# 文件结构说明 Iris_AI_Deployme…...

相机Camera日志实例分析之二:相机Camx【专业模式开启直方图拍照】单帧流程日志详解

【关注我&#xff0c;后续持续新增专题博文&#xff0c;谢谢&#xff01;&#xff01;&#xff01;】 上一篇我们讲了&#xff1a; 这一篇我们开始讲&#xff1a; 目录 一、场景操作步骤 二、日志基础关键字分级如下 三、场景日志如下&#xff1a; 一、场景操作步骤 操作步…...

五年级数学知识边界总结思考-下册

目录 一、背景二、过程1.观察物体小学五年级下册“观察物体”知识点详解&#xff1a;由来、作用与意义**一、知识点核心内容****二、知识点的由来&#xff1a;从生活实践到数学抽象****三、知识的作用&#xff1a;解决实际问题的工具****四、学习的意义&#xff1a;培养核心素养…...

【C语言练习】080. 使用C语言实现简单的数据库操作

080. 使用C语言实现简单的数据库操作 080. 使用C语言实现简单的数据库操作使用原生APIODBC接口第三方库ORM框架文件模拟1. 安装SQLite2. 示例代码:使用SQLite创建数据库、表和插入数据3. 编译和运行4. 示例运行输出:5. 注意事项6. 总结080. 使用C语言实现简单的数据库操作 在…...

2025季度云服务器排行榜

在全球云服务器市场&#xff0c;各厂商的排名和地位并非一成不变&#xff0c;而是由其独特的优势、战略布局和市场适应性共同决定的。以下是根据2025年市场趋势&#xff0c;对主要云服务器厂商在排行榜中占据重要位置的原因和优势进行深度分析&#xff1a; 一、全球“三巨头”…...

视觉slam十四讲实践部分记录——ch2、ch3

ch2 一、使用g++编译.cpp为可执行文件并运行(P30) g++ helloSLAM.cpp ./a.out运行 二、使用cmake编译 mkdir build cd build cmake .. makeCMakeCache.txt 文件仍然指向旧的目录。这表明在源代码目录中可能还存在旧的 CMakeCache.txt 文件,或者在构建过程中仍然引用了旧的路…...

云原生安全实战:API网关Kong的鉴权与限流详解

&#x1f525;「炎码工坊」技术弹药已装填&#xff01; 点击关注 → 解锁工业级干货【工具实测|项目避坑|源码燃烧指南】 一、基础概念 1. API网关&#xff08;API Gateway&#xff09; API网关是微服务架构中的核心组件&#xff0c;负责统一管理所有API的流量入口。它像一座…...

比较数据迁移后MySQL数据库和OceanBase数据仓库中的表

设计一个MySQL数据库和OceanBase数据仓库的表数据比较的详细程序流程,两张表是相同的结构,都有整型主键id字段,需要每次从数据库分批取得2000条数据,用于比较,比较操作的同时可以再取2000条数据,等上一次比较完成之后,开始比较,直到比较完所有的数据。比较操作需要比较…...

Qemu arm操作系统开发环境

使用qemu虚拟arm硬件比较合适。 步骤如下&#xff1a; 安装qemu apt install qemu-system安装aarch64-none-elf-gcc 需要手动下载&#xff0c;下载地址&#xff1a;https://developer.arm.com/-/media/Files/downloads/gnu/13.2.rel1/binrel/arm-gnu-toolchain-13.2.rel1-x…...