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

12 中断

12 中断

  • 1、内核中断编程
  • 2、顶半部和底半部机制
    • 2.1 任务的相关概念
      • 2.1.1 分类
      • 2.1.2 优先级
      • 2.1.3 进程调度
      • 2.1.4 休眠sleep
    • 2.2 顶半部和底半部实现机制
      • 2.2.1 顶半部特点
      • 2.2.2 底半部特点
      • 2.2.3 底半部实现方法之:tasklet
      • 2.2.4 底半部实现机制之工作队列
      • 2.2.5 底半部实现机制之软中断
      • 2.2.6 总结

1、内核中断编程

函数原型:

int request_irq(unsigned int irq, irq_handler_t handler, unsigned long flags, const char *name, void *dev)
- 功能:在linux内核中,处理器的任何一个硬件中断资源对于linux内核来说都是一种宝贵的资源,如果驱动想要访问某个硬件中断资源,必须先向内核申请这个硬件中断资源,一旦申请成功,然后向内核注册这个硬件中断对应的中断处理函数,一旦注册成功,静静等待着硬件中断触发,一旦触发将来内核自动调用注册的中断处理函数
所以此函数完成两个工作:1.申请硬件中断资源2.注册中断处理函数
- 参数:- irq:在linux内核中,linux内核给每个硬件中断都分配一个软件编号- handler:传递要注册的中断处理函数,其实就是传递要注册的中断处理函数名- flags:中断触发的类型- name:指定中断的名称void free_irq(int irq, void *dev)
功能:如果驱动不再使用某个硬件中断资源,必须要释放这个硬件中断资源并且删除之前注册的中断处理函数
参数:
irq:传递要释放的硬件中断的中断号
dev:传递给中断处理函数的参数,此参数务必要和request_irq的最后一个参数保持一致,否则系统崩溃
  • 函数说明
中断号:中断号由GPIO编号经过gpio_to_irq函数进行换算而得:硬件GPIO		GPIO编号		     中断号GPIOA28		PAD_GPIO_A+28  	gpio_to_irq(PAD_GPIO_A + 28);GPIOB9		PAD_GPIO_B+9	gpio_to_irq(PAD_GPIO_B + 9);...	        	...	        	...
中断处理函数:一旦注册完毕,静静等待硬件中断触发,一旦触发,内核自动调用此函数编写一个中断处理函数例子:irqreturn_t 中断处理函数名(int  irq, void *dev) {//根据用户需求编写中断处理函数....return IRQ_NONE; //中断处理函数执行失败或者return IRQ_HANDLED; //中断处理函数执行成功	}注意中断处理函数形参问题:irq:保存当前触发中断的中断号,例如:GPIOA28产生的中断,irq=gpio_to_irq(PAD_GPIO_A+28);dev:保存给中断处理函数传递的参数问:谁来传递参数呢?答:request_irq函数的最后一个形参(void *dev)用来给中断处理函数传递参数而中断处理函数的第二个形参dev来保存传递的参数!
中断触发的类型:IRQF_TRIGGER_HIGH:指定为高电平触发IRQF_TRIGGER_LOW:指定为低电平触发IRQF_TRIGGER_FALLING:指定为下降沿触发IRQF_TRIGGER_RISING:指定为上升沿触发IRQF_TRIGGER_FALLING|IRQF_TRIGGER_RISING:指定为双边沿触发对于内部中断(就是各种控制器给中断控制器发送的中断,此中断线不可见),一律给0
  • 案例
#include <linux/init.h>
#include <linux/module.h>
#include <linux/irq.h>
#include <linux/interrupt.h>
#include <linux/gpio.h>
#include <mach/platform.h>// 声明gpio
struct key_gpio{int gpio;char* name;
};
// 定义GPIO
static struct key_gpio key_info[]={{.name="key_1",.gpio=PAD_GPIO_A+28},{.name="key_2",.gpio=PAD_GPIO_B+9}
};
// 中断处理函数
static irqreturn_t key_interupt (int irq,void *dev){struct key_gpio * key = (struct key_gpio *)dev;//获取按键的状态int kstate;kstate = gpio_get_value(key->gpio);//打印按键的状态printk("%s: 按键[%s]的状态是[%s]\n", __func__, key->name, kstate?"松开":"按下");return IRQ_HANDLED; //成功,失败返回IRQ_NONE
}
static int key_init(void){// 申请GPIO资源int i=0;for(i=0;i<ARRAY_SIZE(key_info);i++){gpio_request(key_info[i].gpio,key_info[i].name);gpio_direction_input(key_info[i].gpio);// 配置中断int irq = gpio_to_irq(key_info[i].gpio); // 生成中断号request_irq(irq,key_interupt,IRQF_TRIGGER_FALLING|IRQF_TRIGGER_RISING,"key_interupt",&key_info[i]);// 申请硬件中断资源printk("%s init success\n",key_info[i].name);}return 0;
};static void key_exit(void){	int i=0;for(i=0;i<ARRAY_SIZE(key_info);i++){gpio_free(key_info[i].gpio);int irq = gpio_to_irq(key_info[i].gpio); // 生成中断号free_irq(irq,&key_info[i]);// 释放硬件中断资源printk("%s free success\n",key_info[i].name);}
};
module_init(key_init);
module_exit(key_exit);
MODULE_LICENSE("GPL");
  • 前置要求
    配置linux内核去除官方的按键驱动:
make menuconfigDevice Drivers->Input device support-><*>Keyboard-><*>..... //最后一个选项,这个选项对应的按键驱动就是官方的按键驱动按N键去除
保存退出

2、顶半部和底半部机制

2.1 任务的相关概念

2.1.1 分类

计算机中的任务细分三类:进程,硬件中断和软中断

  • 进程:进程一开始在用户空间运行,一旦调用系统调用立刻陷入内核空间继续运行,运行完毕又回到用户空间继续运行
  • 硬件中断:外设给CPU发送的中断信号,内核执行其硬件中断处理函数,此函数永远运行在内核空间
  • 软中断:软件单独调用swi或svc指令立刻触发软中断异常,立刻执行其软中断处理函数,此函数同样位于内核空间
    注意:任何一种任务要想运行必须先获取到CPU资源!

2.1.2 优先级

优先级越高,获取CPU资源的能力越强,越能够及早运行,在linux内核中,三类任务的优先级划分:

  • 硬件中断高于软中断,软中断高于进程
  • 进程之间存在优先级之分(nice命令可以设置优先级)
  • 软中断之间存在优先级
  • 硬件中断无优先级之分(哪怕中断控制器支持优先级,内核不认)

2.1.3 进程调度

inux内核会给每个进程分配时间片,进程一旦轮到其运行,在此时间片之内可以一直运行,直到时间片到期,进程调度器会将当前进程的CPU资源撤下给其他进程使用
切记:中断不参与进程调度,中断来了,直接会抢夺CPU资源,因为优先级高

2.1.4 休眠sleep

休眠只能用于进程,不可用于中断,当进程进入休眠时,进程会立马释放占用的CPU资源给其他进程

结论:由以上概念得到:在linux内核中,内核希望中断处理函数的执行速度要越快越好,如果中断处理函数长时间占用CPU资源,势必影响系统的并发能力(其他任务无法获取CPU资源投入运行)和响应能力(其他的硬件中断再也无法得到响应,各种卡)。
问:不可能所有的中断处理函数都能够满足内核的希望
例如:网卡利用中断获取网络数据包,其中断处理函数本身执行的速度就很慢,如果长时间占用CPU资源,就会造成丢包现象!
答:对于此种情况,必须要采用内核提供的顶半部和底半部机制来优化

2.2 顶半部和底半部实现机制

在这里插入图片描述

2.2.1 顶半部特点

  • 硬件中断触发,立刻执行
  • 顶半部本质就是中断处理函数,只是现在里面做紧急,耗时较短的内容
  • CPU在执行顶半部中断处理函数期间不允许发生CPU资源的切换
  • 顶半部同样不能休眠

2.2.2 底半部特点

  • 底半部对应的处理函数做不紧急,并且耗时较长的内容
  • CPU在"适当"的时候执行底半部的处理函数,在执行期间允许高优先级的任务来抢夺CPU资源,等处理完毕再回到底半部继续运行,所以底半部的处理函数实现可以基于软中断或者进程实现
    底半部实现方法三种:tasklet,工作队列,软中断
  • 底半部的本质就是延后执行的一种手段,并不是非要和顶半部配合使用,也就是可以单独用底半部来将你想要延后执行的事情进行延后,可以将宝贵的CPU资源给其他高优先级的任务使用

2.2.3 底半部实现方法之:tasklet

  • 特点:
    基于软中断实现,它对应的处理函数的优先级高于进程而低于硬件中断
    tasklet对应的处理函数中不能进行休眠操作
    tasklet对应的处理函数又称延后处理函数,里面做不紧急,耗时较长的内容
  • 描述tasklet属性的结构体
struct tasklet_struct {void (*func)(unsigned long data);unsigned long data;...
};	
- 功能:描述tasklet的属性
- func:指定tasklet的延后处理函数,将来内核会在适当时候调用其延后处理函数,不能进行休眠操作,形参data保存给这个延后处理函数传递的参数		
- data:给延后处理函数传递的参数
  • 相关函数
void tasklet_init(struct tasklet_struct *tasklet,void (*func)(unsigned long),unsigned long data)	
- 功能:初始化tasklet对象,给tasklet对象指定一个延后处理函数并且给延后处理函数传递参数
- 参数:- tasklet:tasklet对象的地址- func:给tasklet指定一个延后处理函数- data:给延后处理函数传递的参数
void tasklet_schedule(struct tasklet_struct *tasklet)
- 功能:向内核注册tasklet对象和其延后处理函数,一旦注册成功,内核会在适当的时候执行其延后处理函数
  • 案例:优化上面的按键中断,使里面的printk使用tasklet实现
// 底半部
static struct tasklet_struct key_tasklet;
struct key_gpio *key; // 指向按键按下的GPIO
// 定义tasklet处理函数
static void key_tasklet_function(unsigned long data){//获取按键的状态int kstate;kstate = gpio_get_value(key->gpio);//打印按键的状态printk("%s: 按键[%s]的状态是[%s]\n",__func__, key->name,kstate?"松开":"按下");
}
// 顶半部 中断处理函数
static irqreturn_t key_interupt (int irq,void *dev){// 保存按下的按键信息key = (struct key_gpio*) dev;// 向内核注册tasklet延后处理函数tasklet_schedule(&key_tasklet);return IRQ_HANDLED; //成功,失败返回IRQ_NONE
}
static int key_init(void){// 申请GPIO资源int i=0;for(i=0;i<ARRAY_SIZE(key_info);i++){gpio_request(key_info[i].gpio,key_info[i].name);gpio_direction_input(key_info[i].gpio);// 配置中断int irq = gpio_to_irq(key_info[i].gpio); // 生成中断号request_irq(irq,key_interupt,IRQF_TRIGGER_FALLING|IRQF_TRIGGER_RISING,"key_interupt",&key_info[i]);// 申请硬件中断资源printk("%s init success\n",key_info[i].name);}// 初始化tasklet对象,指定延后处理函数tasklet_init(&key_tasklet,key_tasklet_function,0);return 0;
};

2.2.4 底半部实现机制之工作队列

  • 工作队列特点:
    工作队列基于进程实现,所以其延后处理函数可以进行休眠操作
    工作队列诞生的本质就是解决tasklet的延后处理函数不能休眠的问题,所以如果在延后执行的内容中有休眠操作,必须采用工作队列
    工作队列的延后处理函数的优先级也是最低的
  • 工作队列属性的数据结构:
struct work_struct {void (*func)(struct work_struct *work);
};
- func:工作队列的延后处理函数,基于进程实现,可以进行休眠操作形参work:指向驱动定义初始化的work_struct对象,work指向自己用于给延后处理函数传递参数
问:如何利用自己的地址给延后处理函数传递参数呢?
答:必须配合container_of宏来实现传递参数!
  • 相关函数
INIT_WORK(struct work_struct *work, void (*func)(struct work_struct *work));
- 功能:给work对象指定一个延后处理函数
- 参数:- work:work对象的地址- func:指定延后处理函数
schedule_work(struct work_struct *work);
- 功能:向内核登记注册一个延后处理函数,一旦注册成功,内核在适当的时候调用其延后处理函数
  • 案例:优化上面的按键中断,使里面的printk使用工作队列实现
// 底半部
static struct work_struct key_work;
struct key_gpio *key; // 指向按键按下的GPIO
// 定义work处理函数
static void key_work_function(struct work_struct *work){//获取按键的状态int kstate;kstate = gpio_get_value(key->gpio);//打印按键的状态printk("%s: 按键[%s]的状态是[%s]\n",__func__, key->name,kstate?"松开":"按下");
}
// 顶半部 中断处理函数
static irqreturn_t key_interupt (int irq,void *dev){// 保存按下的按键信息key = (struct key_gpio*) dev;// 向内核注册工作队列延后处理函数schedule_work(&key_work);return IRQ_HANDLED; //成功,失败返回IRQ_NONE
}
static int key_init(void){// 申请GPIO资源int i=0;for(i=0;i<ARRAY_SIZE(key_info);i++){gpio_request(key_info[i].gpio,key_info[i].name);gpio_direction_input(key_info[i].gpio);// 配置中断int irq = gpio_to_irq(key_info[i].gpio); // 生成中断号request_irq(irq,key_interupt,IRQF_TRIGGER_FALLING|IRQF_TRIGGER_RISING,"key_interupt",&key_info[i]);// 申请硬件中断资源printk("%s init success\n",key_info[i].name);}// 初始化work对象,指定延后处理函数INIT_WORK(&key_work,key_work_function);return 0;
};

2.2.5 底半部实现机制之软中断

  • 软中断特点:
    软中断同样有对应的延后处理函数,此函数可以同时运行在多个CPU核上,效率极其高,这就要求其延后处理函数如果进行全局变量的访问,记得要做好互斥保护,当一个CPU核在访问全局变量是,禁止其他CPU核访问,但是这种互斥保护势必降低代码的效率
    tasklet基于软中断实现,但是它的延后处理函数同一时刻使能运行在一个CPU核上也不用关心互斥访问的问题!
    软中断的延后处理函数不能insmod和rmmod动态的安装和卸载,必须和uImage编写在一起编译在一起,无形加大了开发的难度和加大了代码的维护难度,但是tasklet就可以动态的insmod和rmmod

2.2.6 总结

  • tasklet基于软中断实现,工作队列基于进程实现
  • 如果要进行延后执行,并且延后执行的内容中有休眠操作,只能用工作队列
  • 如果要进行延后执行,延后执行的内容中无休眠操作,但又要考虑效率问题,建议使用tasklet
  • 如果要进行延后执行,延后执行的内容中无休眠操作,但又不考虑效率问题,建议使用工作队列
  • 如果要进行延后执行,延后执行的内容中无休眠操作,并且对效率要求极高,并且想让多核同时运行处理,建议采用软中断,如果有对全局变量共享资源的同时访问,建议还是tasklet吧!

相关文章:

12 中断

12 中断 1、内核中断编程2、顶半部和底半部机制2.1 任务的相关概念2.1.1 分类2.1.2 优先级2.1.3 进程调度2.1.4 休眠sleep 2.2 顶半部和底半部实现机制2.2.1 顶半部特点2.2.2 底半部特点2.2.3 底半部实现方法之:tasklet2.2.4 底半部实现机制之工作队列2.2.5 底半部实现机制之软…...

经典算法题总结:十大排序算法,外部排序和Google排序简介

十大排序算法 就地性&#xff1a;顾名思义&#xff0c;原地排序通过在原数组上直接操作实现排序&#xff0c;无须借助额外的辅助数组&#xff0c;从而节省内存。通常情况下&#xff0c;原地排序的数据搬运操作较少&#xff0c;运行速度也更快。 稳定性&#xff1a;稳定排序在完…...

服务器是什么?怎么选择适合自己的服务器?

在这个数字化的世界中&#xff0c;我们每天都在与各种网站打交道&#xff0c;浏览新闻、购物、看视频等。你是否曾经好奇过&#xff0c;这些网站是如何运行的&#xff1f;它们又是如何实现随时随地可访问的呢&#xff1f; 在这背后&#xff0c;有一个神秘的角色在默默地支撑着…...

区块链技术的应用场景

区块链技术是一种分布式数据库或公共分类账的形式&#xff0c;它保证了数据的完整性和透明性。它最初是为了支持比特币这种加密货币而被发明的&#xff0c;但现在已经被广泛应用于多种领域&#xff0c;包括供应链管理、投票系统、数字身份验证等。 基本概念 区块 (Block) 区块…...

凤凰端子音频矩阵应用领域

凤凰端子音频矩阵&#xff0c;作为一种集成了凤凰端子接口的音频矩阵设备&#xff0c;具有广泛的应用领域。以下是其主要应用领域&#xff1a; 一、专业音响系统 会议系统&#xff1a;在会议室中&#xff0c;凤凰端子音频矩阵能够处理多个话筒和音频源的信号&#xff0c;实现…...

LeetCode-字母异位词分组

题目描述 给你一个字符串数组&#xff0c;请你将 字母异位词 组合在一起。可以按任意顺序返回结果列表。 字母异位词 是由重新排列源单词的所有字母得到的一个新单词。 示例 1: 输入: strs ["eat", "tea", "tan", "ate", "na…...

《Linux运维总结:基于x86_64架构CPU使用docker-compose一键离线部署etcd 3.5.15容器版分布式集群》

总结&#xff1a;整理不易&#xff0c;如果对你有帮助&#xff0c;可否点赞关注一下&#xff1f; 更多详细内容请参考&#xff1a;《Linux运维篇&#xff1a;Linux系统运维指南》 一、部署背景 由于业务系统的特殊性&#xff0c;我们需要面对不同的客户部署业务系统&#xff0…...

WPF动画

补间动画&#xff1a;动画本质就是在一个时间段内对象尺寸、位移、旋转角度、缩放、颜色、透明度等属性值的连续变化。也包括图形变形的属性。时间、变化的对象、变化的值 工业应用场景&#xff1a;蚂蚁线、旋转、高度变化、指针偏移、小车 WPF动画与分类 特定对象处理动画过…...

大数据系列之:统计hive表的详细信息,生成csv统计表

大数据系列之:统计hive表的详细信息,生成csv统计表 一、获取源数据库、源数据库类型、hive数据库名称二、获取hive数据库名、hive表名、数仓层级、空间、维护者信息三、统计hive表信息四、统计源库信息五、合并hive表信息六、生成csv统计表七、完整代码一、获取源数据库、源数…...

flutter 画转盘

import package:flutter/material.dart; import dart:math;const double spacingAngle 45.0; // 每两个文字之间的角度 // 自定义绘制器&#xff0c;ArcTextPainter 用于在圆弧上绘制文字 class ArcTextPainter extends CustomPainter {final double rotationAngle; // 动画旋…...

图像识别,图片线条检测

import cv2 import numpy as np # 读取图片 img cv2.imread(1.png)# 灰度化 gray cv2.cvtColor(img, cv2.COLOR_BGR2GRAY)# 边缘检测 edges cv2.Canny(gray, 100, 200) 当某个像素点的梯度强度低于 threshold1 时&#xff0c;该像素点被认为是非边缘&#xff1b;当梯度强度…...

python crawler web page

npm install or pip install 插件 import json import time from openpyxl import load_workbook from pip._vendor import requests from bs4 import BeautifulSoup import pandas as pd import re import xlsxwriter 設置request header header {user-agent: Mozilla/5.0…...

基于QT实现的TCP连接的网络通信(客户端)

上篇介绍了QT实现网络通信的服务器端&#xff0c;还没看服务器的朋友们先去上篇了解&#xff0c;这篇我来实现一下客户端的实现。 首先还是新建一个项目 选择mainwindow类 在通信前将.pro文件的第一行代码中追加network 窗口搭建 在mainwindow.ui中完成一下窗口的搭建 首先在…...

Vue2中watch与Vue3中watch对比

上一节说到了 computed计算属性对比 &#xff0c;虽然计算属性在大多数情况下更合适&#xff0c;但有时也需要一个自定义的侦听器。这就是为什么 Vue 通过 watch 选项提供了一个更通用的方法&#xff0c;来响应数据的变化。当需要在数据变化时执行异步或开销较大的操作时&#…...

Web 3 一些常见术语

目录 Provider 提供者Signer 签名者Transaction 交易Contract 合约Receipt 收据 首先&#xff0c;从高层次上对可用对象的类型及其负责的内容有一个基本的了解是很有用的。 Provider 提供者 一个 Provider 是与区块链的只读连接&#xff0c;允许查询区块链状态&#xff0c;例…...

揭开数据分析中的规范性分析:从入门到精通

目录 引言1. 规范性分析的基本概念2. 规范性分析的方法论2.1 线性规划&#xff1a;资源利用最大化2.2 决策树分析&#xff1a;直观的选择路径2.3 贝叶斯网络&#xff1a;应对不确定性的利器2.4 多目标优化&#xff1a;平衡多重目标的艺术 3. 规范性分析的实际应用3.1 商业决策中…...

Linux文件IO

目录 前言 一.文件操作 系统调用接口 1.打开文件 2.关闭文件 3.读取文件 4.写入文件 二.文件描述符 重定向 三.动静态库 前言 在Linux操作系统中&#xff0c;文件I/O是一个核心概念&#xff0c;涉及如何读写文件、与设备通信以及如何管理数据流。Linux下一切皆文件, …...

ccfcsp-202309(1、2、3)

202309-1 坐标变换&#xff08;其一&#xff09; #include <bits/stdc.h> using namespace std; int main() {ios::sync_with_stdio(false);cin.tie(0);cout.tie(0);int n, m;cin >> n >> m;int x, y;int opx 0, opy 0;for(int i 0; i < n; i){cin &g…...

数据结构--数据结构概述

一、数据结构三要素 1. 数据的逻辑结构 数据的逻辑结构是指数据元素之间的关系和组织方式&#xff0c;通常分为线性结构和非线性结构。 线性结构&#xff1a;例如线性表&#xff0c;其中数据元素按照顺序排列&#xff0c;彼此之间存在一对一的关系。 非线性结构&#xff1a;…...

Spring中的BeanFactoryAware

BeanFactoryAware 是 Spring 框架中的一个接口&#xff0c;用于在 Spring 容器中获取 BeanFactory 实例。实现这个接口的类可以在其属性被设置后获取到 BeanFactory&#xff0c;从而可以访问 Spring 容器中的其他 bean。 BeanFactoryAware 接口概述 BeanFactoryAware 接口位于…...

Neo4j service is not installed

问题&#xff1a; Starting Neo4j. Neo4j service is not installed Unable to start. See user log for details. Run with --verbose for a more detailed error message.解决&#xff1a; neo4j windows-service install neo4j start ok了...

LeetCode 3132.找出与数组相加的整数 II:排序+3次尝试(nlog n)

【LetMeFly】3132.找出与数组相加的整数 II&#xff1a;排序3次尝试(nlog n) 力扣题目链接&#xff1a;https://leetcode.cn/problems/find-the-integer-added-to-array-ii/ 给你两个整数数组 nums1 和 nums2。 从 nums1 中移除两个元素&#xff0c;并且所有其他元素都与变量…...

微信小程序--26(全局配置-1)

一、全局配置文件 1.标志 app.json 2.配置项 pages 记录当前小程序所有页面的存放路径 window 全局配置小程序窗口配置 tabBar 设置小程序底部的tabBar效果 style 是否启用新版本的组将样式 3.window 导航栏区域 navigationBar …...

汽车4S店管理系统-计算机毕设Java|springboot实战项目

&#x1f34a;作者&#xff1a;计算机毕设残哥 &#x1f34a;简介&#xff1a;毕业后就一直专业从事计算机软件程序开发&#xff0c;至今也有8年工作经验。擅长Java、Python、微信小程序、安卓、大数据、PHP、.NET|C#、Golang等。 擅长&#xff1a;按照需求定制化开发项目、 源…...

bug的常见排查和分析思路以及相关的原因分类

作为开发人员&#xff0c;经常会收到来自用户和QA&#xff0c;领导反馈的各种问题。 为了快速问题&#xff0c;我们有时需要站在更高的角度&#xff0c;更全面的看待问题。才能更快锁定问题。 具体的bug还需要结合企业实际业务情况&#xff0c;相关的框架&#xff0c;依赖库&…...

Nature:7个提升科研产出的实用建议

我是娜姐 迪娜学姐 &#xff0c;一个SCI医学期刊编辑&#xff0c;探索用AI工具提效论文写作和发表。 一个值得思考的问题是&#xff1a;层出不穷的效率工具到底是提升还是降低了科研产出&#xff1f; 大学教授萨拉 (Sara) 描述了她典型的工作日场景&#xff1a;"…...

react-native从入门到实战系列教程-页面之间的跳转

路由的跳转,是app开发中需要处理的问题,一个页面不可能装下那么多的内容。在react-native中,我们使用的路由组件跟reactjs中还是有区别的,这里贴出官网的文档:https://reactnavigation.org/docs/navigating 实现效果 安装 按照官网的指导安装即可。代码实现 app.jsx中改造…...

HarmonyOS应用开发者高级认证(一)

1、依次点击A、B、C、D四个按钮&#xff0c;其中不会触发UI刷新的是&#xff1a; 答案&#xff1a; Button("C").onClick(() > {this.nameList[0].name "Jim"})分析&#xff1a;直接更新非一级数据不会触发UI刷新 2、如果要实现Row组件内的子元素均匀…...

【网络】套接字(socket)编程——UDP版

1.socket 1.1.什么是socket Socket 的中文翻译过来就是“套接字”。 套接字是什么&#xff0c;我们先来看看它的英文含义&#xff1a;插座。 Socket 就像一个电话插座&#xff0c;负责连通两端的电话&#xff0c;进行点对点通信&#xff0c;让电话可以进行通信&#xff0c;端…...

一篇文章让你彻底掌握 Shell

大家好&#xff0c;这里是 Lucifer三思而后行&#xff0c;专注于提升数据库运维效率。 文章目录 一篇文章让你彻底掌握 Shell简介什么是 shell什么是 shell 脚本Shell 环境指定脚本解释器 模式交互模式非交互模式 基本语法解释器注释echoprintfprintf 的转义符 变量变量命名原则…...

洛阳网站开发/seo关键词优化技术

xpath 省略中间路径在我的职业生涯的大部分时间里&#xff0c;我一直在从事软件开发工作&#xff0c;因此&#xff0c;即使我不止一次涉足解决方案工程&#xff0c;我还是把自己视为软件开发人员&#xff08;或软件架构师&#xff09;。 这肯定会对我如何看待架构景观产生影响&…...

盐城大丰建设局网站/郑州网站建设

前言&#xff1a;反射库&#xff08;reflection library&#xff09;是Java组件的体系结构&#xff0c;提供了一个精心设计的丰富的工具集&#xff0c;以便能够编写动态操纵Java代码的程序。反射被大量应用于JavaBeans中&#xff0c;使Java可以支持Visual Basic用户习惯使用的工…...

最新版在线 网/百度seo运营工作内容

这是在网上找到的一张流程图&#xff0c;写的比较好&#xff0c;大家可以先看图&#xff0c;然后看详细阅读下面的各个步骤。执行流程&#xff1a;1.连接验证及解析客户端与MySQL Server建立连接&#xff0c;发送语句给MySQL Server&#xff0c;接收到后会针对这条语句创建一个…...

wordpress视频略缩图/域名解析查询工具

这篇文章主要为大家详细介绍了python小程序: 剪子&#xff0c;石头&#xff0c;布实例代码,具有一定的参考价值&#xff0c;感兴趣的小伙伴们可以参考一下 闲来无事&#xff0c;写一个小程序&#xff0c;练习一下python&#xff0c;哈哈&#xff1a; #!/usr/bin/env python #co…...

网站备案需要年检吗/新闻稿发布

写在前面今天带给大家一个突破点选验证码的案例&#xff0c;利用爬虫模拟登陆哔哩哔哩&#xff0c;并且把一些采坑的地方给大家强调一下&#xff01;一、需求分析模拟登陆哔哩哔哩网站链接: https://passport.bilibili.com/login效果图如下&#xff1a;验证成功后会自动跳转B站…...

建设企业网站企业/2024的新闻有哪些

其中Ryzen 5 4500U 和 Ryzen 7 4700U 两款处理器来自于外媒手头上现成的&#xff0c;而 Ryzen 7 Pro 4750U(8核16线程)的跑分则是由读者 Tomas 通过 SSH 提供 ThinkPad X13 远程连接获取的。Ryzen 7 Pro 4750U的性能接近于拥有8核16线程的 Ryzen 7 4800U 处理器&#xff0c;不过…...