Android 一体机研发之修改系统设置————屏幕亮度
Android 一体机研发之修改系统设置————屏幕亮度
Android 一体机研发之修改系统设置————声音
Android 一体机研发之修改系统设置————自动锁屏
前言
最近工作略微有点儿空闲,抽空给大家总结一下:近期一直搞得一体机app研发,适用于医疗渠道。
一体机找工厂定制了一下板子和系统,找他们fw后期app会以apk的形式封装到系统中,当然了开机logo也会封装进去。
在这版一体机,有一个可以更改系统设置的功能版块,记得之前总结过Android 调用系统设置,有兴趣的可以去看一下;这一篇将把部分功能做一个细分化
讲解。
但是在调用系统设置的时候,有些系统功能让用户一看就和手机一样的功能,并且有些功能是我们不需要的,这里就需要我们自己去实现修改系统权限的功能。
接下来,会给大家出几篇一体机研发之修改系统设置系列文章,欢迎我们共同学习进步!
屏幕亮度
修改系统屏幕亮度
这种操作还是挺常见的,一般在多媒体
开发中多少会涉及到。

从上图中虽然很难看出效果展示,但是大概都能猜到功能的具体实现,就是通过seekBar来控制亮度的百分比。
如果想实现修改屏幕亮度功能,这里涉及了一个高级
隐私权限,需要用户在app设置页面手动授权
。
设计思路
-
AndroidManifest设置权限;
-
获取系统屏幕亮度;
-
修改系统Settings 中屏幕亮度(注册监听屏幕亮度变化),影响所有页面和App;
3.1 判断权限
3.2 有则修改屏幕亮度
3.3 无则引导用户授权
具体实现
AndroidManifest设置权限
<!-- 修改系统设置 --><uses-permission android:name="android.permission.WRITE_SETTINGS" /><uses-permission android:name="android.permission.READ_CONTACTS" /><uses-permission android:name="com.android.launcher.permission.READ_SETTINGS" /><uses-permission android:name="android.permission.HARDWARE_TEST" />
获取系统屏幕亮度
- Java
/*** 获取app屏幕亮度** @param activity* @return*/public static int getScreenBrightness(Activity activity) {try {return Settings.System.getInt(activity.getContentResolver(), Settings.System.SCREEN_BRIGHTNESS);} catch (Settings.SettingNotFoundException e) {e.printStackTrace();}return 0;}
- Kotlin
/*** 获取系统屏幕亮度(0-255)*/private fun getScreenBrightness(): Int {try {return Settings.System.getInt(this.contentResolver, Settings.System.SCREEN_BRIGHTNESS)} catch (e: SettingNotFoundException) {e.printStackTrace()}return 0}
修改系统Settings 中屏幕亮度,影响所有页面和App
注册监听 系统屏幕亮度变化
- Java
private void registerContentObserver() {ContentResolver contentResolver = getContentResolver();if (contentResolver != null) {contentResolver.registerContentObserver(Settings.System.getUriFor(Settings.System.SCREEN_BRIGHTNESS),true,mBrightnessObserver);}}
- Kotlin
private fun registerContentObserver() {this.contentResolver?.registerContentObserver(Settings.System.getUriFor(Settings.System.SCREEN_BRIGHTNESS),true,mBrightnessObserver)}
监听系统亮度变化
- Java
private ContentObserver mBrightnessObserver = new ContentObserver(new Handler()) { public void onChange(boolean selfChange) {super.onChange(selfChange);ContentResolver contentResolver = getContentResolver();if (contentResolver != null) {mScreenBrightness = getScreenBrightness(BrightActivity.this);Log.e("监听亮度 >>>", "init: " + mScreenBrightness);updateNum(mScreenBrightness);setWindowBrightness(mScreenBrightness);}}};
- Kotlin
private val mBrightnessObserver = object : ContentObserver(Handler(Looper.getMainLooper())) {override fun onChange(selfChange: Boolean) {super.onChange(selfChange)try {this.contentResolver?.let {mScreenBrightness = Settings.System.getInt(it, Settings.System.SCREEN_BRIGHTNESS)updateNum(mScreenBrightness)setWindowBrightness(mScreenBrightness)}} catch (e: SettingNotFoundException) {e.printStackTrace()}}}
注销监听
- Java
void onDestroy() {super.onDestroy();ContentResolver contentResolver = getContentResolver();if (contentResolver != null) {contentResolver.unregisterContentObserver((ContentObserver) mBrightnessObserver);}}
protected
- Kotlin
override fun onDestroy() {super.onDestroy()//注销监听this.contentResolver?.unregisterContentObserver(mBrightnessObserver)}
通过seekBar修改系统Settings 中屏幕亮度
- Java
brightBar.setOnSeekBarChangeListener(new SeekBar.OnSeekBarChangeListener() {(api = Build.VERSION_CODES.M) public void onProgressChanged(SeekBar seekBar, int progress, boolean fromUser) {Log.e("动态屏幕亮度 >>>", "onProgressChanged: " + progress);mScreenBrightness = progress * ratio;if (Settings.System.canWrite(BrightActivity.this)) {setScreenBrightness(mScreenBrightness);updateNum(mScreenBrightness);} else {Toast.makeText(BrightActivity.this, "没有修改权限", Toast.LENGTH_SHORT).show();// 打开允许修改Setting 权限的界面Intent intent = new Intent(Settings.ACTION_MANAGE_WRITE_SETTINGS, Uri.parse("package:"+ getPackageName()));startActivityForResult(intent,mRequestCode);}} public void onStartTrackingTouch(SeekBar seekBar) {} public void onStopTrackingTouch(SeekBar seekBar) {}});
- Kotlin
seekBar.setOnSeekBarChangeListener(object : SeekBar.OnSeekBarChangeListener {override fun onProgressChanged(seekBar: SeekBar?, progress: Int, fromUser: Boolean) {Log.i("onProgressChanged----", "" + progress)mScreenBrightness = progress * ratio//判断是否有修改系统设置权限if (Settings.System.canWrite(this)) {setScreenBrightness(mScreenBrightness)updateNum(mScreenBrightness)} else {Toast.makeText(this, "没有修改权限", Toast.LENGTH_SHORT).show()// 打开允许修改系统设置权限的页面val intent = Intent(Settings.ACTION_MANAGE_WRITE_SETTINGS, Uri.parse("package:$packageName"))startActivityForResult(intent, mRequestCode)}}override fun onStartTrackingTouch(seekBar: SeekBar?) {}override fun onStopTrackingTouch(seekBar: SeekBar?) {}})
用户已授权,设置屏幕亮度
- Java
/*** 设置系统屏幕亮度,影响所有页面和app* 注意:这种方式是需要手动权限的(android.permission.WRITE_SETTINGS)*/private final void setScreenBrightness(int brightness) {//先检测调节模式setScreenManualMode();//再设置Settings.System.putInt(getContentResolver(), Settings.System.SCREEN_BRIGHTNESS, brightness);}private final void setScreenManualMode() {try {//获取当前系统亮度调节模式int mode = Settings.System.getInt(getContentResolver(), Settings.System.SCREEN_BRIGHTNESS_MODE);//如果是自动,则改为手动if (mode == Settings.System.SCREEN_BRIGHTNESS_MODE_AUTOMATIC) {Settings.System.putInt(getContentResolver(),Settings.System.SCREEN_BRIGHTNESS_MODE,Settings.System.SCREEN_BRIGHTNESS_MODE_MANUAL);}} catch (Settings.SettingNotFoundException var2) {var2.printStackTrace();}}
- Kotlin
/*** 设置系统屏幕亮度,影响所有页面和app* 注意:这种方式是需要手动权限的(android.permission.WRITE_SETTINGS)*/private fun setScreenBrightness(brightness: Int) {try {//先检测调节模式setScreenManualMode()//再设置Settings.System.putInt(this.contentResolver, Settings.System.SCREEN_BRIGHTNESS, brightness)} catch (e: SettingNotFoundException) {e.printStackTrace()}}/*** 设置系统亮度调节模式(SCREEN_BRIGHTNESS_MODE)* SCREEN_BRIGHTNESS_MODE_MANUAL 手动调节* SCREEN_BRIGHTNESS_MODE_AUTOMATIC 自动调节*/private fun setScreenManualMode() {try {//获取当前系统亮度调节模式val mode = Settings.System.getInt(this.contentResolver, Settings.System.SCREEN_BRIGHTNESS_MODE)//如果是自动,则改为手动if (mode == Settings.System.SCREEN_BRIGHTNESS_MODE_AUTOMATIC) {Settings.System.putInt(this.contentResolver,Settings.System.SCREEN_BRIGHTNESS_MODE,Settings.System.SCREEN_BRIGHTNESS_MODE_MANUAL)}} catch (e: SettingNotFoundException) {e.printStackTrace()}}
监听系统按键
//监听系统按键 public boolean onKeyDown(int keyCode, KeyEvent event) {switch (keyCode) {case KeyEvent.KEYCODE_VOLUME_DOWN:if (mScreenBrightness > ratio) {mScreenBrightness -= ratio;} else {mScreenBrightness = 1;}Log.e("Down >>>", "onKeyDown: " + mScreenBrightness);setWindowBrightness(mScreenBrightness);updateNum(mScreenBrightness);return true;case KeyEvent.KEYCODE_VOLUME_UP:if (mScreenBrightness < (255 - ratio)) {mScreenBrightness += ratio;} else {mScreenBrightness = 255;}Log.e("Up >>>", "onKeyDown: " + mScreenBrightness);setWindowBrightness(mScreenBrightness);updateNum(mScreenBrightness);return true;/* case KeyEvent.KEYCODE_VOLUME_MUTE:return true;*/}return super.onKeyDown(keyCode, event);}
完整操作
- Java
/*** @author 拉莫帅* @date 2023/2/8* @address* @Desc 修改系统亮度*/
public class BrightActivity extends Activity {/*** 非系统签名应用,引导用户手动授权修改Settings 权限**/private int mRequestCode = 1;private SeekBar brightBar;//当前屏幕亮度private int mScreenBrightness = 0;//每次加减的比例private int ratio = 25;private ContentObserver mBrightnessObserver = new ContentObserver(new Handler()) { public void onChange(boolean selfChange) {super.onChange(selfChange);ContentResolver contentResolver = getContentResolver();if (contentResolver != null) {mScreenBrightness = getScreenBrightness(BrightActivity.this);Log.e("监听亮度 >>>", "init: " + mScreenBrightness);updateNum(mScreenBrightness);setWindowBrightness(mScreenBrightness);}}};(api = Build.VERSION_CODES.M) protected void onCreate(Bundle savedInstanceState) {super.onCreate(savedInstanceState);setContentView(R.layout.activity_bright);init();registerContentObserver();setListener();}private void init() {brightBar = findViewById(R.id.brightBar);ImageView back = findViewById(R.id.back);TextView title = findViewById(R.id.title);title.setText("亮度");//获取当前亮度mScreenBrightness = getScreenBrightness(BrightActivity.this);Log.e("当前亮度 >>>", "init: " + mScreenBrightness);updateNum(mScreenBrightness);back.setOnClickListener(new View.OnClickListener() { public void onClick(View v) {finish();}});}private void registerContentObserver() {ContentResolver contentResolver = getContentResolver();if (contentResolver != null) {contentResolver.registerContentObserver(Settings.System.getUriFor(Settings.System.SCREEN_BRIGHTNESS),true,mBrightnessObserver);}} protected void onDestroy() {super.onDestroy();ContentResolver contentResolver = getContentResolver();if (contentResolver != null) {contentResolver.unregisterContentObserver((ContentObserver) mBrightnessObserver);}}private void setListener() {brightBar.setOnSeekBarChangeListener(new SeekBar.OnSeekBarChangeListener() {(api = Build.VERSION_CODES.M) public void onProgressChanged(SeekBar seekBar, int progress, boolean fromUser) {Log.e("动态屏幕亮度 >>>", "onProgressChanged: " + progress);mScreenBrightness = progress * ratio;if (Settings.System.canWrite(BrightActivity.this)) {setScreenBrightness(mScreenBrightness);updateNum(mScreenBrightness);} else {Toast.makeText(BrightActivity.this, "没有修改权限", Toast.LENGTH_SHORT).show();// 打开允许修改Setting 权限的界面Intent intent = new Intent(Settings.ACTION_MANAGE_WRITE_SETTINGS, Uri.parse("package:"+ getPackageName()));startActivityForResult(intent,mRequestCode);}} public void onStartTrackingTouch(SeekBar seekBar) {} public void onStopTrackingTouch(SeekBar seekBar) {}});}(api = Build.VERSION_CODES.M) protected void onActivityResult(int requestCode, int resultCode, Intent data) {super.onActivityResult(requestCode, resultCode, data);if (requestCode == mRequestCode) {if (Settings.System.canWrite((Context) BrightActivity.this)) {setScreenBrightness(mScreenBrightness);updateNum(mScreenBrightness);} else {Toast.makeText((Context) this, "您已拒绝修系统Setting的屏幕亮度权限", Toast.LENGTH_SHORT).show();}}}/*** 获取app屏幕亮度** @param activity* @return*/public static int getScreenBrightness(Activity activity) {try {return Settings.System.getInt(activity.getContentResolver(), Settings.System.SCREEN_BRIGHTNESS);} catch (Settings.SettingNotFoundException e) {e.printStackTrace();}return 0;}/*** 更新页面显示** @param mScreenBrightness*/private final void updateNum(int mScreenBrightness) {//四舍五入int i = (int) Math.floor(mScreenBrightness / ratio);brightBar.setProgress(i);}/*** 设置系统屏幕亮度,影响所有页面和app* 注意:这种方式是需要手动权限的(android.permission.WRITE_SETTINGS)*/private final void setScreenBrightness(int brightness) {//先检测调节模式setScreenManualMode();//再设置Settings.System.putInt(getContentResolver(), Settings.System.SCREEN_BRIGHTNESS, brightness);}private final void setScreenManualMode() {try {//获取当前系统亮度调节模式int mode = Settings.System.getInt(getContentResolver(), Settings.System.SCREEN_BRIGHTNESS_MODE);//如果是自动,则改为手动if (mode == Settings.System.SCREEN_BRIGHTNESS_MODE_AUTOMATIC) {Settings.System.putInt(getContentResolver(),Settings.System.SCREEN_BRIGHTNESS_MODE,Settings.System.SCREEN_BRIGHTNESS_MODE_MANUAL);}} catch (Settings.SettingNotFoundException var2) {var2.printStackTrace();}}/*** 设置当前应用屏幕亮度,只当前有效*/private final void setWindowBrightness(int brightness) {Window window = this.getWindow();WindowManager.LayoutParams lp = window.getAttributes();lp.screenBrightness = (float) brightness / 255.0F;window.setAttributes(lp);}//监听系统按键 public boolean onKeyDown(int keyCode, KeyEvent event) {switch (keyCode) {case KeyEvent.KEYCODE_VOLUME_DOWN:if (mScreenBrightness > ratio) {mScreenBrightness -= ratio;} else {mScreenBrightness = 1;}Log.e("Down >>>", "onKeyDown: " + mScreenBrightness);setWindowBrightness(mScreenBrightness);updateNum(mScreenBrightness);return true;case KeyEvent.KEYCODE_VOLUME_UP:if (mScreenBrightness < (255 - ratio)) {mScreenBrightness += ratio;} else {mScreenBrightness = 255;}Log.e("Up >>>", "onKeyDown: " + mScreenBrightness);setWindowBrightness(mScreenBrightness);updateNum(mScreenBrightness);return true;/* case KeyEvent.KEYCODE_VOLUME_MUTE:return true;*/}return super.onKeyDown(keyCode, event);}
}
- Kotlin
class BrightnessActivity : AppCompatActivity() {//当前屏幕亮度private var mScreenBrightness: Int = 0//每次加减的比例private var ratio: Int = 25private var mRequestCode = 1override fun onCreate(savedInstanceState: Bundle?) {super.onCreate(savedInstanceState)setContentView(R.layout.activity_brightness)init()registerContentObserver()setListener()}private fun init() {mScreenBrightness = getScreenBrightness()updateNum(mScreenBrightness)}/*** 注册监听 系统屏幕亮度变化*/private fun registerContentObserver() {this.contentResolver?.registerContentObserver(Settings.System.getUriFor(Settings.System.SCREEN_BRIGHTNESS),true,mBrightnessObserver)}/*** 监听系统亮度变化*/private val mBrightnessObserver = object : ContentObserver(Handler(Looper.getMainLooper())) {override fun onChange(selfChange: Boolean) {super.onChange(selfChange)try {this.contentResolver?.let {mScreenBrightness = Settings.System.getInt(it, Settings.System.SCREEN_BRIGHTNESS)updateNum(mScreenBrightness)setWindowBrightness(mScreenBrightness)}} catch (e: SettingNotFoundException) {e.printStackTrace()}}}override fun onDestroy() {super.onDestroy()//注销监听this.contentResolver?.unregisterContentObserver(mBrightnessObserver)}private fun setListener() {seekBar.setOnSeekBarChangeListener(object : SeekBar.OnSeekBarChangeListener {override fun onProgressChanged(seekBar: SeekBar?, progress: Int, fromUser: Boolean) {Log.i("onProgressChanged----", "" + progress)mScreenBrightness = progress * ratio//判断是否有修改系统设置权限if (Settings.System.canWrite(this)) {setScreenBrightness(mScreenBrightness)updateNum(mScreenBrightness)} else {Toast.makeText(this, "没有修改权限", Toast.LENGTH_SHORT).show()// 打开允许修改系统设置权限的页面val intent = Intent(Settings.ACTION_MANAGE_WRITE_SETTINGS, Uri.parse("package:$packageName"))startActivityForResult(intent, mRequestCode)}}override fun onStartTrackingTouch(seekBar: SeekBar?) {}override fun onStopTrackingTouch(seekBar: SeekBar?) {}})}/*** 处理返回结果*/override fun onActivityResult(requestCode: Int, resultCode: Int, data: Intent?) {super.onActivityResult(requestCode, resultCode, data)if (requestCode == mRequestCode) {if (Settings.System.canWrite(this)) {setScreenBrightness(mScreenBrightness)updateNum(mScreenBrightness)} else {Toast.makeText(this, "拒绝了权限", Toast.LENGTH_SHORT).show()}}}/*** 更新页面显示*/private fun updateNum(mScreenBrightness: Int) {//转float 取四舍五入val i: Int = (mScreenBrightness / (ratio.toFloat())).roundToInt()tv_brightness.text = i.toString()seekBar.progress = i}/*** 获取系统屏幕亮度(0-255)*/private fun getScreenBrightness(): Int {try {return Settings.System.getInt(this.contentResolver, Settings.System.SCREEN_BRIGHTNESS)} catch (e: SettingNotFoundException) {e.printStackTrace()}return 0}/*** 设置系统屏幕亮度,影响所有页面和app* 注意:这种方式是需要手动权限的(android.permission.WRITE_SETTINGS)*/private fun setScreenBrightness(brightness: Int) {try {//先检测调节模式setScreenManualMode()//再设置Settings.System.putInt(this.contentResolver, Settings.System.SCREEN_BRIGHTNESS, brightness)} catch (e: SettingNotFoundException) {e.printStackTrace()}}/*** 设置系统亮度调节模式(SCREEN_BRIGHTNESS_MODE)* SCREEN_BRIGHTNESS_MODE_MANUAL 手动调节* SCREEN_BRIGHTNESS_MODE_AUTOMATIC 自动调节*/private fun setScreenManualMode() {try {//获取当前系统亮度调节模式val mode = Settings.System.getInt(this.contentResolver, Settings.System.SCREEN_BRIGHTNESS_MODE)//如果是自动,则改为手动if (mode == Settings.System.SCREEN_BRIGHTNESS_MODE_AUTOMATIC) {Settings.System.putInt(this.contentResolver,Settings.System.SCREEN_BRIGHTNESS_MODE,Settings.System.SCREEN_BRIGHTNESS_MODE_MANUAL)}} catch (e: SettingNotFoundException) {e.printStackTrace()}}/*** 设置当前应用屏幕亮度,只当前有效*/private fun setWindowBrightness(brightness: Int) {val window = windowval lp = window.attributeslp.screenBrightness = brightness / 255.0fwindow.attributes = lp}
}
最近忙里偷闲,↓↓↓↓【谁家de码农陈先生】↓↓↓↓,里面定时给大家分享技术博文、前方高能资讯内容!欢迎各位老板点赞关注,你们就是我的动力源泉!
相关文章:

Android 一体机研发之修改系统设置————屏幕亮度
Android 一体机研发之修改系统设置————屏幕亮度 Android 一体机研发之修改系统设置————声音 Android 一体机研发之修改系统设置————自动锁屏 前言 最近工作略微有点儿空闲,抽空给大家总结一下:近期一直搞得一体机app研发,适用…...
C++通用算法
1.概述根据名字就知道如何使用相关算法,比如copy函数,就是复制的意思,它需要一个范围,以及要复制的位置copy(begin, end, container_begin);#include <iostream> #include<vector> #include<algorithm> #includ…...
Springboot停机方式
1. 介绍 简单的说,就是向应用进程发出停止指令之后,能保证正在执行的业务操作不受影响,直到操作运行完毕之后再停止服务。应用程序接收到停止指令之后,会进行如下操作: 1.停止接收新的访问请求 2.正在处理的请求&…...
Linux perf_event_open 简介
文章目录前言一、简介二、struct perf_event_attr2.1 type2.2 size2.3 config2.3.1 PERF_TYPE_HARDWARE2.3.2 PERF_TYPE_SOFTWARE2.3.3 PERF_TYPE_TRACEPOINT2.3.4 PERF_TYPE_HW_CACHE2.3.5 其他类型三、sample相关参数3.1 sample_period3.2 sample_freq3.3 sample_type四、其他…...
Java给定两组起止日期,求交集
/*** 判断2个时间段是否有重叠(交集)* param startDate1 时间段1开始时间戳* param endDate1 时间段1结束时间戳* param startDate2 时间段2开始时间戳* param endDate2 时间段2结束时间戳* param isStrict 是否严格重叠,true 严格࿰…...

数组的复制与二维数组的用法
今天学习的主要内容有 数组的复制 数组的复制 利用循环进行数组的复制 import java.util.Arrays; public class Main3 {public static void main(String[] args) {int []arr new int[]{1,2,3,4,5,6};int []arr1 new int[arr.length];for (int i 0; i < arr.length; i…...
JS判断两个table数据是否完全相等(判断两个数组对象是否完全相等)
需求 现有的table为tableA,有多个要做对比的table为一个数组 CompareArray 涉及到的问题 外层是数组,但是内部数据都是对象,对象属性名的排序不一样外层数组也涉及到 顺序不一样的问题 思路 对compareArray做长度筛选 filter 得到 同长度…...

关于小程序,你想知道的这些
近年来,各大平台纷纷上架小程序,迎来了小程序的爆发式增长。今天就来跟大家简单分享一下小程序基本的运行机制和安全机制。 小程序的由来 在小程序没有出来之前,最初微信WebView逐渐成为移动web重要入口,微信发布了一整套网页开…...
WuThreat身份安全云-TVD每日漏洞情报-2023-02-13
漏洞名称:THORSTEN PHPMYFAQ 跨站点脚本 漏洞级别:高危 漏洞编号:CVE-2023-0791 相关涉及:THORSTEN PHPMYFAQ 3.1.10 漏洞状态:POC 参考链接:https://tvd.wuthreat.com/#/listDetail?TVD_IDTVD-2023-03506 漏洞名称:TENDA AC23 越界写入 漏洞级别:高危 漏洞编号:CVE-2023-078…...

【Linux】软件安装(三分钟教会你如何在linux下安装软件)
🔥🔥 欢迎来到小林的博客!! 🛰️博客主页:✈️小林爱敲代码 🛰️博客专栏:✈️Linux之路 🛰️社区:✈️进步学堂 目录&…...
Fluent Python 笔记 第 10 章 序列的修改、散列和切片
本章将以第 9 章定义的二维向量 Vector2d 类为基础,向前迈出一大步,定义表示多维向量的 Vector 类。这个类的行为与 Python 中标准的不可变扁平序列一样。 10.3 协议和鸭子类型 在 Python 中创建功能完善的序列类型无需使用继承,只需实现符…...

在中国程序员工作是青春饭吗?
上个月公司告诉我毕业了。 我打开boss直聘,一溜溜的外包公司和我打招呼。 我寻思我说不定啥时候就离开深圳了,外包不外包也无所谓钱到位就行。(大公司学历不够格也进不去) 结果华为、平安的外包告诉我,不好意思呀&a…...

Linux tcpdump
tcpdump - 转储网络上的数据流 是不是感觉很懵?全方位描述tcpdump: 通俗:tcpdump是一个抓包工具,用于抓取网络中传输的数据包形象:tcpdump如同国家海关,凡是入境和出境的货物,海关都要抽样检查࿰…...

redis知识汇总(部署、高可用、集群)
文章目录一、redis知识汇总什么是redisredis的优缺点:为什么要用redis做缓存redis为什么这么快什么是持久化redis持久化机制是什么?各自优缺点?AOF和RDB怎么选择redis持久化数据和缓存怎么做扩容什么是事务redis事务的概念ACID概念主从复制re…...

【手写 Vuex 源码】第十篇 - Vuex 命名空间的实现
一,前言 上一篇,主要介绍了 Vuex 响应式数据和缓存的实现,主要涉及以下几个点: Vuex 的响应式实现原理;响应式核心方法 resetStoreVM;commit 和 dispatch 的处理; 本篇,继续介绍 …...

面试腾讯测试岗后感想,真的很后悔这5年一直都干的是基础测试....
前两天,我的一个朋友去大厂面试,跟我聊天时说:输的很彻底… 我问她:什么情况?她说:很后悔这5年来一直都干的是功能测试… 相信许多测试人也跟我朋友一样,从事了软件测试很多年,却依…...
知识图谱 方法、实践与应用 王昊奋 读书笔记(下)
最近读了这本书,在思路上很有启发,对知识图谱有了初步的认识,以下是原书后半部分的内容,可以购买实体书获取更多内容。 知识图谱推理 结合已有规则,推出新的事实,例如持有股份就能控制一家公司࿰…...

vue实现打印浏览器页面功能(两种方法)
推荐使用方法二 方法一:通过npm 安装插件 1,安装 npm install vue-print-nb --save 2,引入 安装好以后在main.js文件中引入 import Print from vue-print-nbVue.use(Print); //注册 3,现在就可以使用了 div id"printTest…...

【VictoriaMetrics】VictoriaMetrics单机版批量和单条数据写入(Prometheus格式)
VictoriaMetrics单机版支持以Prometheus格式的数据写入,写入支持单条数据写入以及多条数据写入,下面操作演示下如何使用 1、首先需要启动VictoriaMetrics单机版服务 2、使用postman插入单机版VictoriaMetrics,以当前时间插入数据 地址为 http://victoriaMetricsIP:8428/api…...

【青训营】分布式定时任务简述
这是我参与「第五届青训营 」伴学笔记创作活动的第 13 天 分布式定时任务简述 定义 定时任务是指系统为了自动完成特定任务,实时、延时、周期性完成任务调度的过程。分布式定时任务是把分散的、可靠性差的定时任务纳入统一平台,并且实现集群管理调度和…...

深度学习在微纳光子学中的应用
深度学习在微纳光子学中的主要应用方向 深度学习与微纳光子学的结合主要集中在以下几个方向: 逆向设计 通过神经网络快速预测微纳结构的光学响应,替代传统耗时的数值模拟方法。例如设计超表面、光子晶体等结构。 特征提取与优化 从复杂的光学数据中自…...
[2025CVPR]DeepVideo-R1:基于难度感知回归GRPO的视频强化微调框架详解
突破视频大语言模型推理瓶颈,在多个视频基准上实现SOTA性能 一、核心问题与创新亮点 1.1 GRPO在视频任务中的两大挑战 安全措施依赖问题 GRPO使用min和clip函数限制策略更新幅度,导致: 梯度抑制:当新旧策略差异过大时梯度消失收敛困难:策略无法充分优化# 传统GRPO的梯…...

Xshell远程连接Kali(默认 | 私钥)Note版
前言:xshell远程连接,私钥连接和常规默认连接 任务一 开启ssh服务 service ssh status //查看ssh服务状态 service ssh start //开启ssh服务 update-rc.d ssh enable //开启自启动ssh服务 任务二 修改配置文件 vi /etc/ssh/ssh_config //第一…...
React Native在HarmonyOS 5.0阅读类应用开发中的实践
一、技术选型背景 随着HarmonyOS 5.0对Web兼容层的增强,React Native作为跨平台框架可通过重新编译ArkTS组件实现85%以上的代码复用率。阅读类应用具有UI复杂度低、数据流清晰的特点。 二、核心实现方案 1. 环境配置 (1)使用React Native…...
c++ 面试题(1)-----深度优先搜索(DFS)实现
操作系统:ubuntu22.04 IDE:Visual Studio Code 编程语言:C11 题目描述 地上有一个 m 行 n 列的方格,从坐标 [0,0] 起始。一个机器人可以从某一格移动到上下左右四个格子,但不能进入行坐标和列坐标的数位之和大于 k 的格子。 例…...

页面渲染流程与性能优化
页面渲染流程与性能优化详解(完整版) 一、现代浏览器渲染流程(详细说明) 1. 构建DOM树 浏览器接收到HTML文档后,会逐步解析并构建DOM(Document Object Model)树。具体过程如下: (…...

在WSL2的Ubuntu镜像中安装Docker
Docker官网链接: https://docs.docker.com/engine/install/ubuntu/ 1、运行以下命令卸载所有冲突的软件包: for pkg in docker.io docker-doc docker-compose docker-compose-v2 podman-docker containerd runc; do sudo apt-get remove $pkg; done2、设置Docker…...

关键领域软件测试的突围之路:如何破解安全与效率的平衡难题
在数字化浪潮席卷全球的今天,软件系统已成为国家关键领域的核心战斗力。不同于普通商业软件,这些承载着国家安全使命的软件系统面临着前所未有的质量挑战——如何在确保绝对安全的前提下,实现高效测试与快速迭代?这一命题正考验着…...

云原生安全实战:API网关Kong的鉴权与限流详解
🔥「炎码工坊」技术弹药已装填! 点击关注 → 解锁工业级干货【工具实测|项目避坑|源码燃烧指南】 一、基础概念 1. API网关(API Gateway) API网关是微服务架构中的核心组件,负责统一管理所有API的流量入口。它像一座…...
4. TypeScript 类型推断与类型组合
一、类型推断 (一) 什么是类型推断 TypeScript 的类型推断会根据变量、函数返回值、对象和数组的赋值和使用方式,自动确定它们的类型。 这一特性减少了显式类型注解的需要,在保持类型安全的同时简化了代码。通过分析上下文和初始值,TypeSc…...