GPM合并资料整理-GEM部分
一、性能数据上报项
1. CPU模块
| 上报键值 | 说明 | 采集平台 |
|---|---|---|
| cpu | 当前进程cpu使用率平均值 | Android & iOS |
| totcpu | 系统cpu总使用率平均值 | Android & iOS |
| cpu_temp_max | cpu最高温度 | Android |
| cpu_temp_avg | cpu温度平均值 | Android |
| gpu_temp_avg | gpu温度平均值 | Android |
| gpu_temp_max | gpu最高温度 | Android |
| gpu | gpu使用率平均值 | Android |
| gpu_model | gpu型号 | Android |
| cpu_model | cpu型号 | Android |
| cpu_core | cpu核心数 | Android |
| cpu_freq | cpu最大时钟频率 | Android |
2. memory及存储模块
| 上报键值 | 说明 | 采集平台 |
|---|---|---|
| mem | 当前进程内存使用量平均值 | Android & iOS |
| availmem | 当前设备可用内存量平均值 | Android & iOS |
| max_mem | 内存使用量最大值 | Android & iOS |
| start_mem | 开始对局时内存使用量 | Android & iOS |
| end_mem | 结束对局时内存使用量 | Android & iOS |
| totalmem | 当前设备总内存量 | Android & iOS |
| total_storage | 当前设备总存储空间大小 | Android & iOS |
| free_storage | 当前设备可用存储空间大小 | Android & iOS |
3. 网卡模块
| 上报键值 | 说明 | 采集平台 |
|---|---|---|
| wsndpkt | 无线网卡发包总数 | Android & iOS |
| wrcvpkt | 无线网卡收包总数 | Android & iOS |
| wsnddrop | 无线网卡发包丢包 | Android & iOS |
| wrcvdrop | 无线网卡收包丢包 | Android & iOS |
| wsnderr | 无线网卡发包错包 | Android & iOS |
| wrcverr | 无线网卡收包错包 | Android & iOS |
| msndpkt | 移动网卡发包总数 | Android & iOS |
| mrcvpkt | 移动网卡收包总数 | Android & iOS |
| msnddrop | 移动网卡发包丢包 | Android & iOS |
| mrcvdrop | 移动网卡收包丢包 | Android & iOS |
| msnderr | 移动网卡发包错包 | Android & iOS |
| mrcverr | 移动网卡收包错包 | Android & iOS |
4. FPS模块
| 上报键值 | 说明 | 采集平台 |
|---|---|---|
| fmin | fps最小值 | Android & iOS |
| fmax | fps最大值 | Android & iOS |
| favg | fps平均值 | Android & iOS |
| fheavy | fps严重抖动个数(本次fps值比上次fps值低10以上) | Android & iOS |
| flight | fps轻微抖动个数(本次fps值比上次fps值低4以上,10以下) | Android & iOS |
| ftotal | fps采集总个数 | Android & iOS |
| fcntx0 | fps自定义抖动个数(阈值由云控下发) | Android & iOS |
| lfps1 | 低于云控下发的lfps1阈值的个数 | Android & iOS |
| lfps2 | 低于云控下发的lfps2阈值的个数 | Android & iOS |
| lfps3 | 低于云控下发的lfps3阈值的个数 | Android & iOS |
5. 电量模块
| 上报键值 | 说明 | 采集平台 |
|---|---|---|
| battery | 电量消耗(开始-结束) | Android & iOS |
| start_battery | 开始对局时电量值 | Android & iOS |
| end_battery | 结束对局时电量值 | Android & iOS |
| bs | 对局过程中是否有充电操作 | Android & iOS |
| bt | 电池温度平均值 | Android |
| max_battery_temp | 电池温度最大值 | Android |
6. 网络相关模块
| 上报键值 | 说明 | 采集平台 |
|---|---|---|
| netflow | 流量消耗 | Android & iOS |
| devices | 当前wifi下连接设备数 | Android & iOS |
| wifi_num | wifi个数 | Android |
| wifi_rssi | 当前wifi信号强度 | Android |
| wifi_speed | 当前wifi链接速度 | Android |
| gate_delay | 到网关延迟(ping) | Android & iOS |
| signal_level | 移动信号强度 | Android |
| xg | 当前网络类型 | Android & iOS |
| ldns | 本机DNS服务器 | Android & iOS |
7. 机型相关
| 上报键值 | 说明 | 采集平台 |
|---|---|---|
| manufacturer | 厂商 | Android |
| brand | 品牌 | Android |
| model | 型号 | Android |
| resolution | 分辨率 | Android |
cpu&memory采集具体实现代码
1. cpu
-
Android采集代码:
public static float totalCpuUsageRate() {return getTotalCpuUsageRate(USAGE_RATE_CAL_INTERVAL_MILLS_DEFAULT);}public static float getTotalCpuUsageRate(long calIntervalMills) {if (0 > calIntervalMills) {return VALUE_GET_FAILED;}float totalCpuUsageRate = VALUE_GET_FAILED;try {TotalCpuStatInfo totalCpuStatInfo1 = TotalCpuStatInfo.get();long cpuTotal1 = totalCpuStatInfo1.getCpuTotal();if (0 > cpuTotal1) {return totalCpuUsageRate;}long total1 = totalCpuStatInfo1.getTotal();if (0 > total1) {return totalCpuUsageRate;}try {Thread.sleep(calIntervalMills);} catch (Exception e) {GPMLogger.w(e, "getTotalCpuUsageRate failed");}TotalCpuStatInfo totalCpuStatInfo2 = TotalCpuStatInfo.get();long cpuTotal2 = totalCpuStatInfo2.getCpuTotal();if (0 > cpuTotal2) {return totalCpuUsageRate;}long total2 = totalCpuStatInfo2.getTotal();if (0 > total2) {return totalCpuUsageRate;}long totalDiff = total2 - total1;if (0 == totalDiff) {// NOTE: totalDiff为分母return totalCpuUsageRate;}long cpuTotalDiff = cpuTotal2 - cpuTotal1;return 100 * cpuTotalDiff / (totalDiff + 0f);} catch (Exception e) {GPMLogger.w(e, "getTotalCpuUsageRate failed");}return totalCpuUsageRate;}public static float myCpuUsageRate() {return getMyCpuUsageRate(USAGE_RATE_CAL_INTERVAL_MILLS_DEFAULT);}public static float getMyCpuUsageRate(long calIntervalMills) {if (0 > calIntervalMills) {return VALUE_GET_FAILED;}float myCpuUsageRate = VALUE_GET_FAILED;try {TotalCpuStatInfo totalCpuStatInfo1 = TotalCpuStatInfo.get();long total1 = totalCpuStatInfo1.getTotal();if (0 > total1) {return myCpuUsageRate;}MyCpuStatInfo myCpuStatInfo1 = MyCpuStatInfo.get();long myCpuTotal1 = myCpuStatInfo1.getCpuTotal();if (0 > myCpuTotal1) {return myCpuUsageRate;}try {Thread.sleep(calIntervalMills);} catch (Exception e) {GPMLogger.w(e, "getMyCpuUsageRate failed");}TotalCpuStatInfo totalCpuStatInfo2 = TotalCpuStatInfo.get();long total2 = totalCpuStatInfo2.getTotal();if (0 > total2) {return myCpuUsageRate;}MyCpuStatInfo myCpuStatInfo2 = MyCpuStatInfo.get();long myCpuTotal2 = myCpuStatInfo2.getCpuTotal();if (0 > myCpuTotal2) {return myCpuUsageRate;}long totalDiff = total2 - total1;if (0 == totalDiff) {// NOTE: totalDiff为分母return myCpuUsageRate;}long myCpuTotalDiff = myCpuTotal2 - myCpuTotal1;return 100 * myCpuTotalDiff / (totalDiff + 0f);} catch (Exception e) {GPMLogger.w(e, "getTotalCpuUsageRate failed");}return myCpuUsageRate;}private static class TotalCpuStatInfo {private static final int MIN_CPU_STAT_ITEM_NUM = 9;private static final String[] INVALID_RAW_CPU_STAT_ITEMS =new String[MIN_CPU_STAT_ITEM_NUM];public final long user;public final long nice;public final long system;public final long idle;public final long iowait;public final long irq;public final long softirq;public static TotalCpuStatInfo get() {BufferedReader cpuStatInfoReader = null;try {cpuStatInfoReader = new BufferedReader(new InputStreamReader(new FileInputStream(STAT_ABS_DIR), UTF8_CHARSET));return new TotalCpuStatInfo(cpuStatInfoReader.readLine());} catch (Exception e) {// NOTE: 高版本上获取不到, 不打印堆栈GPMLogger.d("get total cpu stat info failed");return new TotalCpuStatInfo(null);} finally {if (null != cpuStatInfoReader) {try {cpuStatInfoReader.close();} catch (IOException ignored) {}}}}private TotalCpuStatInfo(String cpuStatLine) {String[] rawCpuStatItems = CpuStatInfoHelper.buildRawCpuStatItems(cpuStatLine, MIN_CPU_STAT_ITEM_NUM, INVALID_RAW_CPU_STAT_ITEMS);user = CpuStatInfoHelper.buildCpuStatItem(rawCpuStatItems[2]);nice = CpuStatInfoHelper.buildCpuStatItem(rawCpuStatItems[3]);system = CpuStatInfoHelper.buildCpuStatItem(rawCpuStatItems[4]);idle = CpuStatInfoHelper.buildCpuStatItem(rawCpuStatItems[5]);iowait = CpuStatInfoHelper.buildCpuStatItem(rawCpuStatItems[6]);irq = CpuStatInfoHelper.buildCpuStatItem(rawCpuStatItems[7]);softirq = CpuStatInfoHelper.buildCpuStatItem(rawCpuStatItems[8]);}public long getCpuTotal() {return user + nice + system + iowait + irq + softirq;}public long getTotal() {return user + nice + system + idle + iowait + irq + softirq;}}private static class MyCpuStatInfo {private static final int MIN_CPU_STAT_ITEM_NUM = 17;private static final String[] INVALID_RAW_CPU_STAT_ITEMS = new String[MIN_CPU_STAT_ITEM_NUM];public final long utime;public final long stime;public final long cutime;public final long cstime;public static MyCpuStatInfo get() {BufferedReader cpuStatInfoReader = null;try {cpuStatInfoReader = new BufferedReader(new InputStreamReader(new FileInputStream(MY_STAT_ABS_DIR), UTF8_CHARSET));return new MyCpuStatInfo(cpuStatInfoReader.readLine());} catch (Exception e) {GPMLogger.w(e, "get my cpu stat info failed");return new MyCpuStatInfo(null);} finally {if (null != cpuStatInfoReader) {try {cpuStatInfoReader.close();} catch (IOException ignored) {}}}}private MyCpuStatInfo(String cpuStatLine) {String[] rawCpuStatItems = CpuStatInfoHelper.buildRawCpuStatItems(cpuStatLine, MIN_CPU_STAT_ITEM_NUM, INVALID_RAW_CPU_STAT_ITEMS);utime = CpuStatInfoHelper.buildCpuStatItem(rawCpuStatItems[13]);stime = CpuStatInfoHelper.buildCpuStatItem(rawCpuStatItems[14]);cutime = CpuStatInfoHelper.buildCpuStatItem(rawCpuStatItems[15]);cstime = CpuStatInfoHelper.buildCpuStatItem(rawCpuStatItems[16]);}public long getCurrentThreadCpuTotal() {return utime + stime;}public long getCpuTotal() {return utime + stime + cutime + cstime;}} -
IOS采集代码:
// ============当前进程cpu使用率============- (double) getCPU {kern_return_t kr;task_info_data_t tinfo;mach_msg_type_number_t task_info_count;task_info_count = TASK_INFO_MAX;kr = task_info(mach_task_self(), TASK_BASIC_INFO, (task_info_t)tinfo, &task_info_count);if (kr != KERN_SUCCESS) {GSDKLOG(@"================CPU:%.2f",-1.0f);return -1;}task_basic_info_t basic_info;thread_array_t thread_list;mach_msg_type_number_t thread_count;thread_info_data_t thinfo;mach_msg_type_number_t thread_info_count;thread_basic_info_t basic_info_th;uint32_t stat_thread = 0; // Mach threadsbasic_info = (task_basic_info_t)tinfo;// get threads in the taskkr = task_threads(mach_task_self(), &thread_list, &thread_count);if (kr != KERN_SUCCESS) {GSDKLOG(@"=============CPU:%.2f",-1.0f);return -1;}if (thread_count > 0)stat_thread += thread_count;long tot_sec = 0;long tot_usec = 0;float tot_cpu = 0;int j;for (j = 0; j < thread_count; j++) {thread_info_count = THREAD_INFO_MAX;kr = thread_info(thread_list[j], THREAD_BASIC_INFO, (thread_info_t)thinfo, &thread_info_count);if (kr != KERN_SUCCESS) {GSDKLOG(@"=========CPU:%.2f",-1.0f);return -1;}basic_info_th = (thread_basic_info_t)thinfo;if (!(basic_info_th->flags & TH_FLAGS_IDLE)) {tot_sec = tot_sec + basic_info_th->user_time.seconds + basic_info_th->system_time.seconds;tot_usec = tot_usec + basic_info_th->system_time.microseconds + basic_info_th->system_time.microseconds;tot_cpu = tot_cpu + basic_info_th->cpu_usage / (float)TH_USAGE_SCALE * 100.0;}} // for each threadkr = vm_deallocate(mach_task_self(), (vm_offset_t)thread_list, thread_count * sizeof(thread_t));GSDKLOG(@"=============CPU:%.2f",tot_cpu);return tot_cpu;}// ============当前进程cpu使用率============processor_info_array_t cpuInfo, prevCpuInfo;mach_msg_type_number_t numCpuInfo, numPrevCpuInfo;unsigned numCPUs;NSLock * CPUUsageLock;- (void) getSystemCPU {int mib[2U] = { CTL_HW, HW_NCPU };size_t sizeOfNumCPUs = sizeof(numCPUs);int status = sysctl(mib, 2U, &numCPUs, &sizeOfNumCPUs, NULL, 0U);if (status)numCPUs = 1;CPUUsageLock = [[NSLock alloc] init];}- (double) getSystemCPUCircle {natural_t numCPUsU = 0U;kern_return_t err = host_processor_info(mach_host_self(), PROCESSOR_CPU_LOAD_INFO, &numCPUsU, &cpuInfo, &numCpuInfo);if (err == KERN_SUCCESS) {[CPUUsageLock lock];float tot_inUse = 0;float tot_total = 0;for(unsigned i = 0U; i < numCPUs; ++i) {float inUse, total;if(prevCpuInfo) {inUse = ((cpuInfo[(CPU_STATE_MAX * i) + CPU_STATE_USER] - prevCpuInfo[(CPU_STATE_MAX * i) + CPU_STATE_USER])+ (cpuInfo[(CPU_STATE_MAX * i) + CPU_STATE_SYSTEM] - prevCpuInfo[(CPU_STATE_MAX * i) + CPU_STATE_SYSTEM])+ (cpuInfo[(CPU_STATE_MAX * i) + CPU_STATE_NICE] - prevCpuInfo[(CPU_STATE_MAX * i) + CPU_STATE_NICE]));total = inUse + (cpuInfo[(CPU_STATE_MAX * i) + CPU_STATE_IDLE] - prevCpuInfo[(CPU_STATE_MAX * i) + CPU_STATE_IDLE]);} else {inUse = cpuInfo[(CPU_STATE_MAX * i) + CPU_STATE_USER] + cpuInfo[(CPU_STATE_MAX * i) + CPU_STATE_SYSTEM] + cpuInfo[(CPU_STATE_MAX * i) + CPU_STATE_NICE];total = inUse + cpuInfo[(CPU_STATE_MAX * i) + CPU_STATE_IDLE];}tot_inUse += inUse;tot_total += total;}[CPUUsageLock unlock];if (prevCpuInfo) {size_t prevCpuInfoSize = sizeof(integer_t) * numPrevCpuInfo;vm_deallocate(mach_task_self(), (vm_address_t)prevCpuInfo, prevCpuInfoSize);}prevCpuInfo = cpuInfo;numPrevCpuInfo = numCpuInfo;cpuInfo = NULL;numCpuInfo = 0U;if (tot_total > 0) {GSDKLOG(@"CPU Usage: %.2f%%",tot_inUse/tot_total * 100.f);return tot_inUse/tot_total * 100.f;} else {return -1;}} else {GSDKLOG(@"Error!");return -1;}}
2. memory
-
Android采集代码:
public static long getAvailableMemory(Context context) {if (null == context) {return VALUE_GET_FAILED;}@SuppressWarnings("AlibabaLowerCamelCaseVariableNaming")long availableMemoryInMB = VALUE_GET_FAILED;try {ActivityManager activityManager =(ActivityManager) context.getSystemService(Context.ACTIVITY_SERVICE);if (null == activityManager) {return availableMemoryInMB;}ActivityManager.MemoryInfo memoryInfo = new ActivityManager.MemoryInfo();activityManager.getMemoryInfo(memoryInfo);availableMemoryInMB = memoryInfo.availMem / (1024 * 1024);} catch (Exception e) {GPMLogger.w(e, "availableMemoryInMB failed");}return availableMemoryInMB;}// ============当前设备可用内存大小(原方案)============public static long getProcessMemery() {// TODO: 厂商反馈Debug.getPss()计算还是过于复杂,后续考虑使用Process.getPss()或者仿照Process.getPss()实现// NOTE: 当前实现应该在低优先级后台线程调用if (Build.VERSION_CODES.ICE_CREAM_SANDWICH <= Build.VERSION.SDK_INT) {return Debug.getPss() / 1024;}// NOTE: 仅在Android14下使用,不涉及私有API访问限制// Android 2.3上Process已有getPss方法// https://android.googlesource.com/platform/frameworks/base/+/refs/heads/gingerbread/core/java/android/os/Process.javatry {Method getPssMethod = Process.class.getMethod(GET_PSS_METHOD_NAME, int.class);return ((long) getPssMethod.invoke(null, Process.myPid())) / 1024;} catch (Exception e) {return VALUE_GET_FAILED;}}// ============当前设备可用内存大小(优化后方案)============private static ActivityManager sActivityMgr = null;private static int sPid = 0;public static int getProcessMemery(Context context) {try {if (sActivityMgr == null) {sActivityMgr = (ActivityManager) context.getSystemService(context.ACTIVITY_SERVICE);}if (sPid == 0) {sPid = android.os.Process.myPid();}if (sActivityMgr == null || sPid == 0) {return -1;}int[] myMempid = new int[]{sPid};Debug.MemoryInfo[] memoryInfo = sActivityMgr.getProcessMemoryInfo(myMempid);int memSize = 0;if (memoryInfo != null && memoryInfo.length > 0) {memSize = memoryInfo[0].getTotalPss();}return memSize;} catch (Exception e) {Logger.e("PSS fetch error: " + e.getMessage());}return -1;} -
IOS采集代码:
// ============当前设备可用内存大小============- (double) getSystemAvailableMemory {// 获取当前设备可用内存(单位:MB)vm_statistics_data_t vmStats;mach_msg_type_number_t infoCount = HOST_VM_INFO_COUNT;kern_return_t kernReturn = host_statistics(mach_host_self(), HOST_VM_INFO, (host_info_t)&vmStats, &infoCount);if (kernReturn != KERN_SUCCESS) {GSDKLOG(@"AvailableMemory=====%.2f",-1.0f);return -1;}double availMem = (vm_page_size * vmStats.free_count + vm_page_size * vmStats.inactive_count) / 1024.0 / 1024.0;GSDKLOG(@"AvailableMemory=====%.2f",availMem);return availMem;}// ============当前进程使用内存大小(原方案)============- (double) getFootPrint {task_vm_info_data_t vmInfo;mach_msg_type_number_t count = TASK_VM_INFO_COUNT;kern_return_t result = task_info(mach_task_self(), TASK_VM_INFO, (task_info_t) &vmInfo, &count);if (result != KERN_SUCCESS) {GSDKLOG(@"FootPrint=====%.2f",-1.0f);return -1;}GSDKLOG(@"FootPrint=====%i",(int)((vmInfo.phys_footprint) / 1024.0 / 1024.0));return vmInfo.phys_footprint / 1024.0 / 1024.0;}// ============当前进程使用内存大小(优化后方案)============- (instancetype) init {if (self = [super init]) {_isLowLevelDevice = NO;struct utsname systemInfo;uname(&systemInfo);NSString *platform = [NSString stringWithCString:systemInfo.machine encoding:NSASCIIStringEncoding];if ([platform isEqualToString:@"iPhone7,1"] || [platform isEqualToString:@"iPhone7,2"] || [platform isEqualToString:@"iPhone6,1"] || [platform isEqualToString:@"iPhone6,2"]) {_isLowLevelDevice = YES;}}return self;}- (double) getFootPrint {task_vm_info_data_t vmInfo;mach_msg_type_number_t count = TASK_VM_INFO_COUNT;kern_return_t result = task_info(mach_task_self(), TASK_VM_INFO, (task_info_t) &vmInfo, &count);if (result != KERN_SUCCESS) {GSDKLOG(@"FootPrint=====%.2f",-1.0f);return -1;}double footPrint = -1;if (_isLowLevelDevice || [UIDevice.currentDevice.systemVersion doubleValue] >= 12.0) {footPrint = vmInfo.phys_footprint / 1024.0 / 1024.0;}if ([UIDevice.currentDevice.systemVersion doubleValue] < 12.0) {footPrint = (vmInfo.internal + vmInfo.compressed - vmInfo.purgeable_volatile_pmap) / 1024.0 / 1024.0;}GSDKLOG(@"FootPrint=====%i",int((vmInfo.phys_footprint) / 1024.0 / 1024.0));return footPrint;}
二、性能数据统一上报类示例
使用同一个TDMReportHelper实例进行上报即可:
TDMReportHelper eventReportHandler = new TDMReportHelper(eventName);
eventReportHandler.addSS(key, value);
eventReportHandler.report();
eventReportHandler.destory();
相关文章:
GPM合并资料整理-GEM部分
一、性能数据上报项 1. CPU模块 上报键值说明采集平台cpu当前进程cpu使用率平均值Android & iOStotcpu系统cpu总使用率平均值Android & iOScpu_temp_maxcpu最高温度Androidcpu_temp_avgcpu温度平均值Androidgpu_temp_avggpu温度平均值Androidgpu_temp_maxgpu最高温度…...
STM32使用1.69寸液晶显示模块使用缓冲区实现快速刷新全屏显示字符串功能
一个1.69寸SPI接口的液晶显示模块,有320*24076800个点,每个点有2个字节表示RGB的颜色,所以需要153.6K个字节的数据来刷新全屏,如果SPI口输出数据不是高速并且不紧密排列的话,刷新就会比较慢,有从下到下的肉…...
SpringBoot AOP
依赖引入 <dependency><groupId>org.springframework.boot</groupId><artifactId>spring-boot-starter-aop</artifactId> </dependency>代码实现 以给公共字段注入值为例 公共字段与枚举类: private LocalDateTime createT…...
鉴源论坛 · 观模丨浅谈Web渗透之信息收集(下)
作者 | 林海文 上海控安可信软件创新研究院汽车网络安全组 版块 | 鉴源论坛 观模 社群 | 添加微信号“TICPShanghai”加入“上海控安51fusa安全社区” 信息收集在渗透测试过程中是最重要的一环,“浅谈web渗透之信息收集”将通过上下两篇,对信息收集、…...
构建自己的私人GPT-支持中文
上一篇已经讲解了如何构建自己的私人GPT,这一篇主要讲如何让GPT支持中文。 privateGPT 本地部署目前只支持基于llama.cpp 的 gguf格式模型,GGUF 是 llama.cpp 团队于 2023 年 8 月 21 日推出的一种新格式。它是 GGML 的替代品,llama.cpp 不再…...
php将文本内容写入一个文件(面向过程写法)
一、封装2个函数,读写文件 /*** desc 读取文件内容* param string $filename* return array*/ private function readContent(string $filename): array {$text file_get_contents($filename);if (!$text) {return [];}$result json_decode($text,true);return…...
SPDK As IPU Firmware
对于不熟悉术语Infrastructure Processing Unit (IPU, 基础设施处理器)的同学,IPU是PCIe形态的卡,连接到主机系统后可以卸载主机的“基础设施”工作。它通常是面向云服务商或者超融合服务提供商的。对于熟悉SPDK的开发人员来理解,这些卡通常具…...
快速删除node_modules文件夹
文章目录 快速删除node_modules文件夹PowerShell命令快速删除使用npm提供的命令删除node_modules 快速删除node_modules文件夹 前端开发过程中,经常会遇到npm操作问题,有时候不得不需要删除node_modules目录下所有的文件,然后重新npm install npm cache clean --force rm -rf…...
Mac安装nvm以及使用nvm安装node
1. 安装nvm命令 git clone https://gitee.com/mirrors/nvm.git ~/.nvm && cd ~/.nvm && git checkout git describe --abbrev0 --tags2. 配置环境变量 vi ~/.bash_profileexport NVM_DIR"$HOME/.nvm" [ -s "$NVM_DIR/nvm.sh" ] &&…...
vue element-ui的table列表中展示缩略图片效果实例
这篇文章主要给大家介绍了关于vue element-ui的table列表中展示多张图片(可放大)效果的相关资料,文中通过代码示例介绍的非常详细,需要的朋友可以参考下 一、效果图 二、代码部分 1、原理 使用 <el-table-column> 和 <el-image> 组件来在表格中插入缩略图 2、te…...
C/C++动态内存管理
文章目录 前言1.C/C内存分布2.C语言中动态内存管理方式:malloc/calloc/realloc/free3.C内存管理方式3.1 new/delete操作内置类型3.2 new和delete操作自定义类型 4. operator new与operator delete函数4.1 operator new与operator delete函数 5. new和delete的实现原…...
矩阵中的最长递增路径
题目链接 矩阵中的最长递增路径 题目描述 注意点 不能 在 对角线 方向上移动或移动到 边界外(即不允许环绕) 解答思路 因为最长递增路径一定是连续的,所以想到使用深度优先遍历来做。如果只使用深度优先遍历会导致超时(同一个…...
vue2 element 弹出框拖拽会出现一层阴影问题
问题如图所示: 因增加 draggable 属性导致我弹窗表单清空文本框时,从右向左选中字体会出现拖拽阴影效果 去掉 draggable 即可 <template><div class"sys-jobTrigger-container"><el-dialog:visible.sync"state.isShowD…...
idea git回滚之前提交记录
提交代码时,如果不小心提交了不需要提交的内容,在本地仓库中,此时需要回滚版本,如何回滚 1.打开git控制台,左下角git,选择要处理的分支,选择刷新获取最新git提交记录 2)选中自己commit需要回滚…...
什么是Modbus协议?
Modbus协议是一种在工业自动化领域广泛应用的通信协议,它允许不同设备之间进行可靠的数据交换和控制。该协议最初由Modicon公司于1979年创建,旨在提供一种简单而有效的方法,使PLC(可编程逻辑控制器)和其他自动化设备能…...
222.【2023年华为OD机试真题(C卷)】分配土地(扫描线算法-JavaPythonC++JS实现)
🚀点击这里可直接跳转到本专栏,可查阅顶置最新的华为OD机试宝典~ 本专栏所有题目均包含优质解题思路,高质量解题代码(Java&Python&C++&JS分别实现),详细代码讲解,助你深入学习,深度掌握! 文章目录 一. 题目-分配土地二.解题思路三.题解代码Python题解代码…...
Linux网络编程(一-网络相关知识点)
目录 一、网络相关知识简介 二、网络协议的分层模型 2.1 OSI七层模型 2.2 TCP/IP五层模型 2.3 协议层报文间的封装与拆封 三、IP协议 3.1 MAC地址 3.2 IP地址 3.3 MAC地址与IP地址区别 一、网络相关知识简介 互联网通信的本质是数字通信,任何数字通信都离…...
IO进程线程day5
1.实现互斥机制 #include <head.h>char buf[128]; //全局数组,临界资源//1、创建一个互斥锁 pthread_mutex_t mutex;//定义分支线程 void *task(void *arg) {while(1){//3、获取锁资源pthread_mutex_lock(&mutex);printf("分支线程中&…...
读元宇宙改变一切笔记04_网络化
1. 思想实验 1.1. 如果森林中的一棵树倒下,但周围没有人听到,那它是否会发出声音? 1.1.1. “贝克莱的树” 1.2. 主观唯心主义哲学家乔治贝克莱(George Berkeley)提出的,他认为“存在就是被感知” 1.2.1. 如果有人或有其他事物…...
用Promise实现util函数
有些时候,我们需要依赖于异步的返回结果做一些后续处理,until函数在这种场景下非常有用,你能实现它吗 ? 让我们来试试吧 👇: <script setup langts> import { ref,watch } from "vue"const count ref(0)/*** I…...
铭豹扩展坞 USB转网口 突然无法识别解决方法
当 USB 转网口扩展坞在一台笔记本上无法识别,但在其他电脑上正常工作时,问题通常出在笔记本自身或其与扩展坞的兼容性上。以下是系统化的定位思路和排查步骤,帮助你快速找到故障原因: 背景: 一个M-pard(铭豹)扩展坞的网卡突然无法识别了,扩展出来的三个USB接口正常。…...
Qwen3-Embedding-0.6B深度解析:多语言语义检索的轻量级利器
第一章 引言:语义表示的新时代挑战与Qwen3的破局之路 1.1 文本嵌入的核心价值与技术演进 在人工智能领域,文本嵌入技术如同连接自然语言与机器理解的“神经突触”——它将人类语言转化为计算机可计算的语义向量,支撑着搜索引擎、推荐系统、…...
现代密码学 | 椭圆曲线密码学—附py代码
Elliptic Curve Cryptography 椭圆曲线密码学(ECC)是一种基于有限域上椭圆曲线数学特性的公钥加密技术。其核心原理涉及椭圆曲线的代数性质、离散对数问题以及有限域上的运算。 椭圆曲线密码学是多种数字签名算法的基础,例如椭圆曲线数字签…...
JDK 17 新特性
#JDK 17 新特性 /**************** 文本块 *****************/ python/scala中早就支持,不稀奇 String json “”" { “name”: “Java”, “version”: 17 } “”"; /**************** Switch 语句 -> 表达式 *****************/ 挺好的ÿ…...
佰力博科技与您探讨热释电测量的几种方法
热释电的测量主要涉及热释电系数的测定,这是表征热释电材料性能的重要参数。热释电系数的测量方法主要包括静态法、动态法和积分电荷法。其中,积分电荷法最为常用,其原理是通过测量在电容器上积累的热释电电荷,从而确定热释电系数…...
Mysql8 忘记密码重置,以及问题解决
1.使用免密登录 找到配置MySQL文件,我的文件路径是/etc/mysql/my.cnf,有的人的是/etc/mysql/mysql.cnf 在里最后加入 skip-grant-tables重启MySQL服务 service mysql restartShutting down MySQL… SUCCESS! Starting MySQL… SUCCESS! 重启成功 2.登…...
关于uniapp展示PDF的解决方案
在 UniApp 的 H5 环境中使用 pdf-vue3 组件可以实现完整的 PDF 预览功能。以下是详细实现步骤和注意事项: 一、安装依赖 安装 pdf-vue3 和 PDF.js 核心库: npm install pdf-vue3 pdfjs-dist二、基本使用示例 <template><view class"con…...
【Kafka】Kafka从入门到实战:构建高吞吐量分布式消息系统
Kafka从入门到实战:构建高吞吐量分布式消息系统 一、Kafka概述 Apache Kafka是一个分布式流处理平台,最初由LinkedIn开发,后成为Apache顶级项目。它被设计用于高吞吐量、低延迟的消息处理,能够处理来自多个生产者的海量数据,并将这些数据实时传递给消费者。 Kafka核心特…...
Canal环境搭建并实现和ES数据同步
作者:田超凡 日期:2025年6月7日 Canal安装,启动端口11111、8082: 安装canal-deployer服务端: https://github.com/alibaba/canal/releases/1.1.7/canal.deployer-1.1.7.tar.gz cd /opt/homebrew/etc mkdir canal…...
二叉树-144.二叉树的前序遍历-力扣(LeetCode)
一、题目解析 对于递归方法的前序遍历十分简单,但对于一位合格的程序猿而言,需要掌握将递归转化为非递归的能力,毕竟递归调用的时候会调用大量的栈帧,存在栈溢出风险。 二、算法原理 递归调用本质是系统建立栈帧,而非…...
