多线程多进程

秋招面试的java八股文知识点补充以及iot

这里有一点阅读补充

线程和进程区别

什么是进程?
进程 (Process) 是计算机中的一个独立执行单元,是操作系统资源分配的基本单位·每个进程有各自独立的内存空间和资源,它们之间相互独立,相互之间不能访问彼此的内存空间和寄存器等资源。

什么是线程?
线程 (Thread) 是指进程中的一个执行单元,也被称为轻量级进程。一个进程可以包含多个线程,它们共享进程的内存和资源·线程拥有自己的栈和程序计数器,但共享进程内的数据和资源。

进程上下文切换

进程上下文切换是操作系统将CPU从一个进程切换到另一个进程的过程
简要来说,它包括以下步骤
1.中断当前进程。
2.保存当前进程的上下文 (如程序计数器、CPU寄存器)
3.根据调度策略选择新进程
4更新新进程的进程控制块(PCB)
5.恢复新进程的上下文。
6.开始执行新进程。
进程的上下文切换非常昂贵,它涉及到需要保存很多的上下文资源


何时使用多进程和多线程?

多进程:

对资源保护和管理要求高,不限制开销和效率时可以使用多进程。
每个进程有独立的内存空间,相互之间不会影响,更安全,适合于需要并发执行但需要隔离资源的任务。
多线程:

要求效率高,切换频繁时使用多线程。
多线程共享内存空间,因此线程之间的通信和切换更加快速,适合于需要频繁切换和共享数据的任务。

进程间通信方式有哪些?

文件: 进程可以通过读写共享文件来进行通信。一个进程写入文件,另一个进程读取文件。

Socket通信: 基于网络编程的Socket通信是一种进程间通信的常见方式。可以通过套接字实现进程间的数据传输,包括本地通信和远程通信。

管道(Pipes): java.io.PipedInputStream 和 java.io.PipedOutputStream 可以用于在两个相关的Java进程之间进行通信。一个进程通过输出流写入数据,另一个进程通过输入流读取数据。

Java RMI(Remote Method Invocation): Java RMI 允许一个Java虚拟机中的对象调用另一个Java虚拟机中的对象的方法,实现了远程通信。

消息队列(Message Queue): 使用消息队列工具,比如 RabbitMQ 或 Apache Kafka,可以在不同Java进程之间传递消息,实现进程间通信。

共享内存: Java的共享内存通常通过使用 Java 的并发工具,例如 java.util.concurrent 包中的类,实现多线程间的共享数据。

进程间通信的选择:

管道通信:用于进程间互发短小、频率很高的消息。
共享内存:用于进程间共享数据量庞大、读写频繁的数据。
其他考虑套接字(Socket)。

线程间通信方法有哪些?

临界区
互斥量
信号量
事件
条件变量
读写锁

操作系统

4. 创建进程的方式:
系统初始化,例如后台进程、守护进程。
一个进程开启另一个进程,使用 fork() 函数。
用户的交互式请求,例如在命令行中启动一个新的进程。
5. 进程有几种状态?
进程有五种状态:创建、就绪、运行、阻塞、终止。在Linux系统中,进程的生命周期是从创建到终止。
11. 什么是内核线程和用户线程?
用户线程:由用户进行管理,创建、调度、同步和销毁由用户空间的库函数完成,不需要内核帮助,开销较小。
内核线程:由操作系统创建和销毁,完全由内核管理。
12. 如何实现守护进程?
创建子进程,终止父进程。
调用 setsid() 创建一个新的会话。
将当前目录更改为根目录。
重设文件权限掩码。
关闭不再需要的文件描述符。

线程里面的java函数

sleep()和wait()的区别:

sleep() 是 Thread 类的方法,wait() 是 Object 类的方法。
sleep() 不释放锁,wait() 会释放锁。
wait() 必须在同步方法或同步代码块中执行。


如何在Java中创建线程?

答案: 可以通过继承 Thread 类或实现 Runnable 接口来创建线程。
继承 Thread 类和实现 Runnable 接口的区别是什么?

答案: 继承 Thread 类只能创建一个线程,而实现 Runnable 接口可以创建多个线程。
如何启动一个线程?

答案: 可以通过调用 start() 方法来启动一个线程。
如何在Java中使用 sleep() 方法暂停线程的执行?

答案: 可以使用以下代码使用 sleep() 方法暂停线程的执行:
java
Copy code
try {
    Thread.sleep(1000);
} catch (InterruptedException e) {
    e.printStackTrace();
}
如何在Java中使用 yield() 方法让出CPU资源?

答案: 可以使用以下代码使用 yield() 方法让出CPU资源:
java
Copy code
Thread.yield();
如何在Java中使用 join() 方法等待线程执行完毕?

答案: 可以使用以下代码使用 join() 方法等待线程执行完毕:
java
Copy code
try {
    thread.join();
} catch (InterruptedException e) {
    e.printStackTrace();
}
如何在Java中使用 wait() 方法等待其他线程的通知?

答案: 可以使用以下代码使用 wait() 方法等待其他线程的通知:
java
Copy code
try {
    obj.wait();
} catch (InterruptedException e) {
    e.printStackTrace();
}
如何在Java中使用 notify() 方法通知其他线程?

答案: 可以使用以下代码使用 notify() 方法通知其他线程:
java
Copy code
obj.notify();
如何在Java中使用 notifyAll() 方法通知所有等待的线程?

答案: 可以使用以下代码使用 notifyAll() 方法通知所有等待的线程:
java
Copy code
obj.notifyAll();
如何在Java中使用 synchronized 关键字同步代码块?

答案: 可以使用以下代码使用 synchronized 关键字同步代码块:
java
Copy code
synchronized (obj) {
    // 同步代码块
}
如何在Java中使用 synchronized 关键字同步方法?

答案: 可以使用以下代码使用 synchronized 关键字同步方法:
java
Copy code
public synchronized void method() {
    // 同步方法
}
如何在Java中使用 volatile 关键字保证变量的可见性?

答案: 可以使用以下代码使用 volatile 关键字保证变量的可见性:
java
Copy code
private volatile int count;
如何在Java中使用 AtomicInteger 类保证变量的原子性?

答案: 可以使用以下代码使用 AtomicInteger 类保证变量的原子性:
java
Copy code
private AtomicInteger count = new AtomicInteger();
如何在Java中使用 CountDownLatch 类等待多个线程完成?

答案: 可以使用以下代码使用 CountDownLatch 类等待多个线程完成:
java
Copy code
CountDownLatch latch = new CountDownLatch(2);
Thread thread1 = new Thread(() -> {
    // 线程1执行的代码
    latch.countDown();
});
Thread thread2 = new Thread(() -> {
    // 线程2执行的代码
    latch.countDown();
});
thread1.start();
thread2.start();
latch.await();
如何在Java中使用 Semaphore 类控制并发线程数?

答案: 可以使用以下代码使用 Semaphore 类控制并发线程数:
java
Copy code
Semaphore semaphore = new Semaphore(1);
Thread thread1 = new Thread(() -> {
    try {
        semaphore.acquire();
        // 线程1执行的代码
        semaphore.release();
    } catch (InterruptedException e) {
        e.printStackTrace();
    }
});
Thread thread2 = new Thread(() -> {
    try {
        semaphore.acquire();
        // 线程2执行的代码
        semaphore.release();
    } catch (InterruptedException e) {
        e.printStackTrace();
    }
});
thread1.start();
thread2.start();
如何在Java中使用 ReentrantLock 类实现同步?

答案: 可以使用以下代码使用 ReentrantLock 类实现同步:
java
Copy code
private ReentrantLock lock = new ReentrantLock();

public void method() {
    lock.lock();
    try {
        // 同步代码块
    } finally {
        lock.unlock();
    }
}
如何在Java中使用 ReadWriteLock 类实现读写分离?

答案: 可以使用以下代码使用 ReadWriteLock 类实现读写分离:
java
Copy code
private ReadWriteLock lock = new ReentrantReadWriteLock();

public void readMethod() {
    lock.readLock().lock();
    try {
        // 读操作
    } finally {
        lock.readLock().unlock();
    }
}

public void writeMethod() {
    lock.writeLock().lock();
    try {
        // 写操作
    } finally {
        lock.writeLock().unlock();
    }
}
如何在Java中使用 ThreadLocal 类实现线程本地变量?

答案: 可以使用以下代码使用 ThreadLocal 类实现线程本地变量:
java
Copy code
private ThreadLocal<Integer> count = new ThreadLocal<>();

public void method() {
    count.set(1);
    // 访问 count 变量
    count.remove();
}
如何在Java中使用 Executor 框架管理线程池?

答案: 可以使用以下代码使用 Executor 框架管理线程池:
java
Copy code
ExecutorService executor = Executors.newFixedThreadPool(2);

executor.execute(() -> {
    // 线程1执行的代码
});

executor.execute(() -> {
    // 线程2执行的代码
});

executor.shutdown();

程序是什么运行的

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

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

相关文章

在ubuntu上使用vscode+gcc-arm-none-eabi+openocd工具开发STM32

文章目录 所需工具安装调试搭建过程中遇到的问题 写在前面 老大上周让我用vscode开发STM32&#xff0c;我爽快的答应了&#xff0c;心想大学四年装了这么多环境了这不简简单单&#xff0c;更何况vscode这两年还用过&#xff0c;然而现实总是令人不快的——我竟然花了差不多两周…

第三百九十回

文章目录 1. 概念介绍2. 思路与方法2.1 实现思路2.2 实现方法 3. 示例代码4. 内容总结 我们在上一章回中介绍了"如何把异步的CallBack转换成事件流"相关的内容&#xff0c;本章回中将介绍如何延时处理数据.闲话休提&#xff0c;让我们一起Talk Flutter吧。 1. 概念介…

new;getline();重载<<和>>

面向对象程序设计的优点&#xff1a; 易维护易扩展模块化&#xff1a;通过设置访问级别&#xff0c;限制别人对自己的访问&#xff0c;保护了数据安全 int main(){ return 0;} 返回值0在windows下编程一般没用&#xff0c;但是在linux中编程&#xff0c;返回值有时有用 汇编与…

在Leaflet中使用Turf.js生成范围多边形的两种实现方式

目录 前言 一、场景需求 1、Leaflet.js的不足 2、Turf.js 二、原始数据展示 1、点位数据展示 2、定义样式 3、定位数据初始化 三、Turfjs中bbox生成 1、官网讲解 2、轨迹bbox生成 四、Turfjs生成外包多边形 1、官网例子 2、凸多边形生成 总结 前言 在一些共享出…

德人合科技|天锐绿盾加密软件——数据防泄漏系统

德人合科技是一家专注于提供企业级信息安全解决方案的服务商&#xff0c;提供的天锐绿盾加密软件是一款专为企业设计的数据安全防护产品&#xff0c;主要用于解决企事业单位内部敏感数据的防泄密问题。 www.drhchina.com PC端&#xff1a; https://isite.baidu.com/site/wjz012…

spring-cloud-openfeign 3.0.0之前版本(对应spring boot 2.4.x之前版本)feign配置加载顺序

在之前写的文章配置基础上 https://blog.csdn.net/zlpzlpzyd/article/details/136060312 下图为自己整理的

正则表达式 || 遇到字符串里面有() 就在括号后面换行

<template><div class"vertical-layout"><header><h1>testPage</h1><p>(1)第一行内容xxxxxxxxx&#xff08;2&#xff09;第二行内容xxxxxxx(3)第三行内容</p></header><main><el-button click"goToO…

Matlab|2机5节点牛拉法(含报告)

目录 主要内容 下载链接 主要内容 采用牛拉法计算2机5节点的潮流计算程序&#xff0c;程序迭代稳定&#xff0c;运行可靠&#xff0c;含报告资料。 下载链接

错误和异常之标准异常创建异常

标准异常 表 10.2 列出了所有的 Python 当前的标准异常集,所有的异常都是内建的. 所以它们在脚本启动 前或在互交命令行提示符出现时已经是可用的了. 表10.2 Python内建异常 异常名称描述所有异常的基类 python 解释器请求退出 用户中断执行(通常是输入^C) 常规错误的基类

Flutter使用auto_updater实现windows/mac桌面应用版本升级功能

因为windows应用一般大家都是从网上下载的&#xff0c;后期版本肯定会更新&#xff0c;那用flutter开发windows应用&#xff0c;怎么实现应用内版本更新功能了&#xff1f;可以使用auto_updater库&#xff0c; 这个插件允许 Flutter 桌面 应用自动更新自己 (基于 sparkle 和 wi…

#onenet网络请求http(GET,POST)

参考博文&#xff1a; POST: https://blog.csdn.net/qq_43350239/article/details/104361153 POST请求&#xff08;用串口助手测试&#xff09;&#xff1a; POST /devices/1105985351/datapoints HTTP/1.1 api-key:AdbrV5kCRsKsRCfjboYOCVcF9FY Host:api.heclouds.com Con…

Util工具类功能设计与类设计(http模块一)

目录 类功能 类定义 类实现 编译测试 Split分割字符串测试 ReadFile读取测试 WriteFile写入测试 UrlEncode编码测试 UrlDecode编码测试 StatuDesc状态码信息获取测试 ExtMime后缀名获取文件mime测试 IsDirectory&IsRegular测试 VaildPath请求路径有效性判断测…

图像处理与视觉感知---期末复习重点(2)

文章目录 一、空间域图像增强1.1 图像增强1.2 几种变换 二、直方图2.1 直方图定义2.2 直方图均衡化2.3 离散情况2.4 例子2.5 直方图匹配2.6 例子2.7 一道例题 三、空间滤波器3.1 定义3.2 例子 四、平滑空间滤波器4.1 作用与分类4.2 线性滤波器 五、统计排序滤波器5.1 定义与分类…

RNN(Recurrent Neural Networks)循环神经网络

循环神经网络&#xff08;Recurrent Neural Network&#xff0c;简称RNN&#xff09;是一种处理序列数据的神经网络结构&#xff0c;它具有记忆能力&#xff0c;能够捕捉序列中的时序信息。RNN在自然语言处理、时间序列预测等方面有着很多的应用。 一、RNN 的基本结构 RNN的包…

【鸿蒙 HarmonyOS 4.0】常用组件:List/Grid/Tabs

一、背景 列表页面&#xff1a;List组件和Grid组件&#xff1b; 页签切换&#xff1a;Tabs组件&#xff1b; 二、列表页面 在我们常用的手机应用中&#xff0c;经常会见到一些数据列表&#xff0c;如设置页面、通讯录、商品列表等。下图中两个页面都包含列表&#xff0c;“…

STL容器之哈希

哈希 ​ 哈希本质上还是一个数组&#xff0c;只是数组的每一个位置要存储的值进行了映射&#xff1b; ​ 哈希也可以叫做散列&#xff1b; ​ 哈希比红黑树快是因为&#xff0c;不需要重复进行比较大小&#xff0c;直接用映射关系进行查找&#xff1b; ​ 哈希函数的设计应…

华为北向网管NCE开发教程(2)REST接口开发

华为北向网管NCE开发教程&#xff08;1&#xff09;闭坑选接口协议 华为北向网管NCE开发教程&#xff08;2&#xff09;REST接口开发 华为北向网管NCE开发教程&#xff08;3&#xff09;CORBA协议开发 假设你现在要开始华为北向接口REST协议之前&#xff0c;需要准备如环境 1准…

Vue中用户权限如何处理?

Vue中用户权限如何处理&#xff1f; 在 Vue 中&#xff0c;可以采用多种方式来处理用户权限&#xff0c;以下是一些常见的方法&#xff1a; 1. 使用路由守卫 Vue Router 提供了 beforeEach 导航守卫&#xff0c;可以在路由跳转之前进行权限检查。例如&#xff1a; router.be…

Leetcode3069. 将元素分配到两个数组中 I

Every day a Leetcode 题目来源&#xff1a;3069. 将元素分配到两个数组中 I 解法1&#xff1a;模拟 简单地按题意模拟。 代码&#xff1a; /** lc appleetcode.cn id3069 langcpp** [3069] 将元素分配到两个数组中 I*/// lc codestart class Solution { public:vector<…

【libwebrtc】基于m114

libwebrtc A C++ wrapper for binary release, mainly used for flutter-webrtc desktop (windows, linux, embedded).是 基于m114版本的webrtc 最新(20240309 ) 的是m122了。官方给出的构建过程 .gclient 文件 solutions = [{"name" : src,"url