开发体育赛事直播系统:实现聊天交友的私聊功能技术实现全方案解析
基于“东莞梦幻网络科技”体育赛事直播系统,展示前后端技术(PHP ThinkPHP + Vue.js + Android Java + iOS OC)实现的“用户与用户之间私聊”完整方案,包括功能描述、界面效果、技术实现、数据结构、接口设计及关键代码示例。
一、私聊聊天功能模块包含:
1、用户与用户之间一对一私聊。
2、显示聊天记录、发送时间。
3、未读消息红点提示。
4、消息免打扰(可切换)。
5、聊天窗口置顶。
6、删除聊天、清空聊天记录。
7、发送消息、图片、表情等。
二、技术实现方案技术栈:
1、后端: PHP (ThinkPHP)
2、数据库: MySQL
3、实时通信: WebSocket + Redis(用于消息推送 & 未读消息计数)
4、前端(H5/PC): Vue.js
5、移动端: Java (Android)、Objective-C (iOS)
三、数据结构设计(MySQL)
1、用户表 users
CREATE TABLE `users` (`id` INT AUTO_INCREMENT PRIMARY KEY,`username` VARCHAR(50),`avatar` VARCHAR(255),`status` TINYINT DEFAULT 1
);
2、聊天消息表 chat_messages
CREATE TABLE `chat_messages` (`id` INT AUTO_INCREMENT PRIMARY KEY,`sender_id` INT,`receiver_id` INT,`content` TEXT,`send_time` DATETIME,`is_read` TINYINT DEFAULT 0,`is_deleted` TINYINT DEFAULT 0
);
3、聊天设置表 chat_settings
CREATE TABLE `chat_settings` (`id` INT AUTO_INCREMENT PRIMARY KEY,`user_id` INT,`chat_user_id` INT,`is_top` TINYINT DEFAULT 0,`no_disturb` TINYINT DEFAULT 0
);
四、后端接口设计(ThinkPHP)
1、获取聊天列表
public function getChatList($userId)
{$chats = ChatModel::getChatListByUser($userId); // 关联读取chat_settings、last_messagereturn json(['status' => 1, 'data' => $chats]);
}
2、获取聊天记录
public function getMessages(Request $request)
{$userId = $request->param('user_id');$peerId = $request->param('peer_id');$messages = ChatMessageModel::getMessages($userId, $peerId);return json(['status' => 1, 'data' => $messages]);
}
3、发送消息
public function sendMessage(Request $request)
{$data = $request->post();ChatMessageModel::send($data['sender_id'], $data['receiver_id'], $data['content']);// WebSocket推送WebSocketService::pushToUser($data['receiver_id'], $data);return json(['status' => 1, 'msg' => '发送成功']);
}
五、Vue 前端页面实现(关键代码)
1、聊天列表组件
<template><div class="chat-list"><div v-for="chat in chatList" :key="chat.user_id" class="chat-item"><div class="avatar"><img :src="chat.avatar"></div><div class="info"><div class="name">{{ chat.username }}</div><div class="last-msg">{{ chat.last_message }}</div><div class="time">{{ chat.last_time }}</div><div v-if="chat.unread_count > 0" class="red-dot">{{ chat.unread_count }}</div></div><el-dropdown><span class="el-dropdown-link">···</span><el-dropdown-menu slot="dropdown"><el-dropdown-item @click.native="setTop(chat)">置顶聊天</el-dropdown-item><el-dropdown-item @click.native="deleteChat(chat)">删除聊天</el-dropdown-item><el-dropdown-item @click.native="clearMessages(chat)">清空消息</el-dropdown-item></el-dropdown-menu></el-dropdown></div></div>
</template>
2、聊天窗口
<template><div class="chat-window"><div class="header">{{ targetUser.username }}<el-switch v-model="noDisturb" @change="toggleNoDisturb">消息免打扰</el-switch></div><div class="chat-content"><div v-for="msg in messages" :class="{'mine': msg.sender_id === userId}"><div class="message">{{ msg.content }}</div><div class="time">{{ msg.send_time }}</div></div></div><div class="input-area"><el-input v-model="input" @keyup.enter="sendMessage" placeholder="请输入消息..." /></div></div>
</template>
六、Android Java 实现(部分代码)
public class ChatListActivity extends AppCompatActivity {private RecyclerView chatListView;private ChatListAdapter adapter;private List<ChatItem> chatItems = new ArrayList<>();@Overrideprotected void onCreate(Bundle savedInstanceState) {super.onCreate(savedInstanceState);setContentView(R.layout.activity_chat_list);chatListView = findViewById(R.id.chat_list_view);chatListView.setLayoutManager(new LinearLayoutManager(this));adapter = new ChatListAdapter(chatItems, new ChatListAdapter.OnItemClickListener() {@Overridepublic void onItemClick(ChatItem item) {openChatWindow(item);}@Overridepublic void onMoreClick(ChatItem item, View view) {showChatMenu(item, view);}});chatListView.setAdapter(adapter);loadChatList();}private void loadChatList() {// 调用API获取聊天列表ApiService.getInstance().getChatList(new ApiCallback<List<ChatItem>>() {@Overridepublic void onSuccess(List<ChatItem> result) {chatItems.clear();chatItems.addAll(result);adapter.notifyDataSetChanged();}@Overridepublic void onFailure(String error) {Toast.makeText(ChatListActivity.this, error, Toast.LENGTH_SHORT).show();}});}private void openChatWindow(ChatItem item) {Intent intent = new Intent(this, ChatActivity.class);intent.putExtra("chat_id", item.getId());intent.putExtra("user_name", item.getUsername());startActivity(intent);}private void showChatMenu(ChatItem item, View anchorView) {PopupMenu popupMenu = new PopupMenu(this, anchorView);popupMenu.getMenuInflater().inflate(R.menu.chat_item_menu, popupMenu.getMenu());// 设置菜单项状态popupMenu.getMenu().findItem(R.id.menu_top).setTitle(item.isTop() ? "取消置顶" : "置顶");popupMenu.getMenu().findItem(R.id.menu_mute).setTitle(item.isMuted() ? "关闭免打扰" : "消息免打扰");popupMenu.setOnMenuItemClickListener(menuItem -> {switch (menuItem.getItemId()) {case R.id.menu_top:toggleTopChat(item, !item.isTop());return true;case R.id.menu_mute:toggleMuteChat(item, !item.isMuted());return true;case R.id.menu_delete:deleteChat(item);return true;case R.id.menu_clear:clearMessages(item);return true;default:return false;}});popupMenu.show();}private void toggleTopChat(ChatItem item, boolean isTop) {ApiService.getInstance().topChat(item.getId(), isTop, new ApiCallback<Void>() {@Overridepublic void onSuccess(Void result) {loadChatList();}@Overridepublic void onFailure(String error) {Toast.makeText(ChatListActivity.this, error, Toast.LENGTH_SHORT).show();}});}private void toggleMuteChat(ChatItem item, boolean isMuted) {ApiService.getInstance().muteChat(item.getId(), isMuted, new ApiCallback<Void>() {@Overridepublic void onSuccess(Void result) {loadChatList();}@Overridepublic void onFailure(String error) {Toast.makeText(ChatListActivity.this, error, Toast.LENGTH_SHORT).show();}});}private void deleteChat(ChatItem item) {new AlertDialog.Builder(this).setTitle("删除聊天").setMessage("确定要删除此聊天记录吗?").setPositiveButton("确定", (dialog, which) -> {ApiService.getInstance().deleteChat(item.getId(), new ApiCallback<Void>() {@Overridepublic void onSuccess(Void result) {loadChatList();}@Overridepublic void onFailure(String error) {Toast.makeText(ChatListActivity.this, error, Toast.LENGTH_SHORT).show();}});}).setNegativeButton("取消", null).show();}private void clearMessages(ChatItem item) {new AlertDialog.Builder(this).setTitle("清空消息").setMessage("确定要清空此聊天中的所有消息吗?").setPositiveButton("确定", (dialog, which) -> {ApiService.getInstance().clearMessages(item.getId(), new ApiCallback<Void>() {@Overridepublic void onSuccess(Void result) {loadChatList();}@Overridepublic void onFailure(String error) {Toast.makeText(ChatListActivity.this, error, Toast.LENGTH_SHORT).show();}});}).setNegativeButton("取消", null).show();}
}
七、iOS Objective-C 实现(部分代码)
#import "ChatListViewController.h"
#import "ChatItem.h"
#import "ChatViewController.h"
#import "ApiService.h"@interface ChatListViewController ()@end@implementation ChatListViewController- (void)viewDidLoad {[super viewDidLoad];self.title = @"私聊";self.chatItems = [NSMutableArray array];// 设置表格视图self.tableView = [[UITableView alloc] initWithFrame:self.view.bounds style:UITableViewStylePlain];self.tableView.delegate = self;self.tableView.dataSource = self;[self.tableView registerClass:[UITableViewCell class] forCellReuseIdentifier:@"ChatCell"];[self.view addSubview:self.tableView];// 加载数据[self loadChatList];
}- (void)loadChatList {[[ApiService sharedInstance] getChatListWithCompletion:^(NSArray *chatItems, NSError *error) {if (error) {NSLog(@"Error loading chat list: %@", error.localizedDescription);return;}[self.chatItems removeAllObjects];[self.chatItems addObjectsFromArray:chatItems];[self.tableView reloadData];}];
}#pragma mark - UITableViewDataSource- (NSInteger)tableView:(UITableView *)tableView numberOfRowsInSection:(NSInteger)section {return self.chatItems.count;
}- (UITableViewCell *)tableView:(UITableView *)tableView cellForRowAtIndexPath:(NSIndexPath *)indexPath {UITableViewCell *cell = [tableView dequeueReusableCellWithIdentifier:@"ChatCell" forIndexPath:indexPath];ChatItem *chatItem = self.chatItems[indexPath.row];// 配置单元格cell.textLabel.text = chatItem.username;cell.detailTextLabel.text = chatItem.lastMessage;cell.imageView.image = [UIImage imageNamed:chatItem.avatar ?: @"default_avatar"];// 显示未读消息数if (chatItem.unreadCount > 0) {UILabel *badge = [[UILabel alloc] initWithFrame:CGRectMake(0, 0, 20, 20)];badge.text = [NSString stringWithFormat:@"%ld", (long)chatItem.unreadCount];badge.textColor = [UIColor whiteColor];badge.backgroundColor = [UIColor redColor];badge.textAlignment = NSTextAlignmentCenter;badge.layer.cornerRadius = 10;badge.layer.masksToBounds = YES;cell.accessoryView = badge;} else {cell.accessoryView = nil;}// 置顶聊天背景色if (chatItem.isTop) {cell.backgroundColor = [UIColor colorWithRed:0.9 green:0.95 blue:1.0 alpha:1.0];} else {cell.backgroundColor = [UIColor whiteColor];}return cell;
}#pragma mark - UITableViewDelegate- (void)tableView:(UITableView *)tableView didSelectRowAtIndexPath:(NSIndexPath *)indexPath {[tableView deselectRowAtIndexPath:indexPath animated:YES];ChatItem *chatItem = self.chatItems[indexPath.row];[self openChatWithChatItem:chatItem];
}- (NSArray<UITableViewRowAction *> *)tableView:(UITableView *)tableView editActionsForRowAtIndexPath:(NSIndexPath *)indexPath {ChatItem *chatItem = self.chatItems[indexPath.row];// 置顶/取消置顶UITableViewRowAction *topAction = [UITableViewRowAction rowActionWithStyle:UITableViewRowActionStyleNormal title:chatItem.isTop ? @"取消置顶" : @"置顶" handler:^(UITableViewRowAction * _Nonnull action, NSIndexPath * _Nonnull indexPath) {[self toggleTopChat:chatItem];}];topAction.backgroundColor = [UIColor blueColor];// 删除UITableViewRowAction *deleteAction = [UITableViewRowAction rowActionWithStyle:UITableViewRowActionStyleDestructive title:@"删除" handler:^(UITableViewRowAction * _Nonnull action, NSIndexPath * _Nonnull indexPath) {[self deleteChat:chatItem];}];return @[deleteAction, topAction];
}- (void)openChatWithChatItem:(ChatItem *)chatItem {ChatViewController *chatVC = [[ChatViewController alloc] init];chatVC.chatId = chatItem.chatId;chatVC.chatTitle = chatItem.username;[self.navigationController pushViewController:chatVC animated:YES];
}- (void)toggleTopChat:(ChatItem *)chatItem {[[ApiService sharedInstance] topChat:chatItem.chatId isTop:!chatItem.isTop completion:^(BOOL success, NSError *error) {if (success) {[self loadChatList];} else {NSLog(@"Error toggling top chat: %@", error.localizedDescription);}}];
}- (void)deleteChat:(ChatItem *)chatItem {UIAlertController *alert = [UIAlertController alertControllerWithTitle:@"删除聊天" message:@"确定要删除此聊天记录吗?" preferredStyle:UIAlertControllerStyleAlert];[alert addAction:[UIAlertAction actionWithTitle:@"取消" style:UIAlertActionStyleCancel handler:nil]];[alert addAction:[UIAlertAction actionWithTitle:@"确定" style:UIAlertActionStyleDestructive handler:^(UIAlertAction * _Nonnull action) {[[ApiService sharedInstance] deleteChat:chatItem.chatId completion:^(BOOL success, NSError *error) {if (success) {[self loadChatList];} else {NSLog(@"Error deleting chat: %@", error.localizedDescription);}}];}]];[self presentViewController:alert animated:YES completion:nil];
}@end
相关文章:
开发体育赛事直播系统:实现聊天交友的私聊功能技术实现全方案解析
基于“东莞梦幻网络科技”体育赛事直播系统,展示前后端技术(PHP ThinkPHP Vue.js Android Java iOS OC)实现的“用户与用户之间私聊”完整方案,包括功能描述、界面效果、技术实现、数据结构、接口设计及关键代码示例。 一、私…...
UTF-8和GBK编码的区别和详细解释
各位看官,大家早安午安晚安呀~~~ 如果您觉得这篇文章对您有帮助的话 欢迎您一键三连,小编尽全力做到更好 欢迎您分享给更多人哦 今天我们来学习:一个小的知识点—UTF-8和GBK编码的解释 1.关于bite位和进制的关系 1 个比特(bit&am…...
java导入excel更新设备经纬度度数或者度分秒
文章目录 一、背景介绍二、页面效果三、代码0.pom.xml1.ImportDevice.vue2.ImportDeviceError.vue3.system.js4.DeviceManageControl5.DeviceManageUserControl6.Repeater7.FileUtils8.ResponseModel9.EnumLongitudeLatitude10.词条 四、注意点本人其他相关文章链接 一、背景介…...
使用python访问mindie部署的vl多模态模型
说明 今天使用mindie1.0部署了qwen2_7b_vl模型,测试过程出现一些问题,这里总结下。 问题1:transformers版本太低 报错信息: [ERROR] [model_deploy_config.cpp:159] Failed to get vocab size from tokenizer wrapper with ex…...
github发布个人中英文简历网站CaoYongshengcys.github.io
在GitHub上创建个人主页(也称为GitHub Pages)是一个展示个人项目、技能和经历的好方法。以下是详细步骤: 1. 创建GitHub账号 • 如果你还没有GitHub账号,先访问GitHub官网注册一个账号。 • 选择一个专业的用户名,因…...
动态规划算法深度解析:0-1背包问题(含完整流程)
简介: 0-1背包问题是经典的组合优化问题:给定一组物品(每个物品有重量和价值),在背包容量限制下选择物品装入背包,要求总价值最大化且每个物品不可重复选取。 动态规划核心思想 通过构建二维状态表dp[i]…...
QML面试笔记--UI设计篇04交互控件
1. QML中常用交互控件 1.1. Button1.2. Slider1.3. ProgressBar1.4. TextField1.5. TextArea1.6. ComboBox1.7. CheckBox1.8. RadioButton1.9. Menu1.10. Dialog 1. QML中常用交互控件 在万物互联的智能时代,QML凭借其声明式语法和跨平台能力,…...
【数学】线性代数(Python)
参考:https://aibydoing.com/notebooks/appendix01-01-linear-algebra-with-python 目录 矩阵的定义矩阵的运算矩阵的属性矩阵的分解矩阵的本质遗留问题 矩阵的定义 通过数组的维度来区分向量(1 维数组)、矩阵(2 维数组࿰…...
ragflow开启https访问:添加证书后,使用浏览器还是有警告,如何解决?
如果在 Windows 系统中安装了 PEM 证书(使用方法一通过证书管理器 MMC 导入),但浏览器仍然提示安全警告,可能有以下几个原因及解决方法: 1. 证书未正确安装到受信任的存储位置 问题:如果证书被导入到错误的存储位置(如“个人”而非“受信任的根证书颁发机构”),浏览器…...
vue.config.js配置代理(输出代理前后的地址)
devServer: {host: 0.0.0.0,port: port,open: true,before(app) {app.use((req, res, next) > {// console.log(原始地址:, req.originalUrl) // 原始地址,如 /api/some-api/xxxxxnext()})},proxy: {[process.env.VUE_APP_BASE_API]: {target: http://192.168.50…...
【八股文】http1.0和1.1的区别
http1.0默认使用短连接,每次请求都需要建立TCP连接(三次握手),响应完成后立即关闭连接,导致资源浪费和延迟增加。 支持通过Connection:Keep-alive 手动开启长连接,但需客户端和服务端显式协商 …...
【Prompt实战】邮件分类专家
本文原创作者:姚瑞南 AI-agent 大模型运营专家,先后任职于美团、猎聘等中大厂AI训练专家和智能运营专家岗;多年人工智能行业智能产品运营及大模型落地经验,拥有AI外呼方向国家专利与PMP项目管理证书。(转载需经授权&am…...
K8S核心技术点
Pod,Service和Deployment的关系 Pod:Kubernetes 中最小的部署单元,用于运行容器化应用。 Service:提供服务发现和负载均衡,为 Pod 提供稳定的网络端点,ClusterIP,NodePort,LoadBala…...
Python手写“随机森林”解决鸢尾花数据集分类问题
Python使用“随机森林”解决鸢尾花数据集分类问题 任务描述解题1. 导入必要的库2. 数据采样函数 sample3. 设置随机种子和超参数4. 定义随机森林类 random_forest5. 加载数据集并划分训练集和测试集6. 创建并训练随机森林模型7. 进行预测并计算准确率 代码 任务描述 您的任务是…...
Python 字典和集合(泛映射类型)
本章内容的大纲如下: 常见的字典方法 如何处理查找不到的键 标准库中 dict 类型的变种set 和 frozenset 类型 散列表的工作原理 散列表带来的潜在影响(什么样的数据类型可作为键、不可预知的 顺序,等等) 泛映射类型 collections.…...
CrystalDiskInfo电脑硬盘监控工具 v9.6.0中文绿色便携版
前言 CrystalDiskInfo是一个不用花钱的硬盘小帮手软件,它可以帮你看看你的电脑硬盘工作得怎么样,健不健康。这个软件能显示硬盘的温度高不高、还有多少地方没用、传输东西快不快等等好多信息。用了它,你就能很容易地知道硬盘现在是什么情况&…...
rqlite:一个基于SQLite构建的分布式数据库
今天给大家介绍一个基于 SQLite 构建的轻量级分布式关系型数据库:rqlite。 rqlite 基于 Raft 协议,结合了 SQLite 的简洁性以及高可用分布式系统的稳健性,对开发者友好,操作极其简便,其核心设计理念是以最低的复杂度实…...
网络1 网络设备
计算机网络设备 集线器: 易发生阻塞:所有端口共享一条带宽,两个端口发生传输时,其他端口若想传输数据给这两个端口,需等待这两个端口传输数据完毕。 端口数量限制:10M带宽下可用15口。15口共享10Md带宽 集线…...
mybatis 某些特殊的 ORA-00979:not a GROUP BY expression
打印的日志sql执行都是正常的 但是 就是报ORA-00979: not a GROUP BY expression 可能是 GROUP BY中不能使用动态参数 或特殊方法 使用 硬编码可以解决问题 <if test"statisticsInVo.timeTypeSql!null and statisticsInVo.timeTypeSql yyyy">TO_CHAR(CARD_T…...
基于OpenCV的图像处理程序设计实践
一.安装OpenCV3.x # 安装依赖 sudo apt update sudo apt install build-essential cmake git libgtk2.0-dev pkg-config libavcodec-dev libavformat-dev libswscale-dev# 下载OpenCV源码 git clone https://github.com/opencv/opencv.git -b 3.4 cd opencv mkdir build &…...
DeepSeek 全套汇总资料pdf免费下载(最新更新8篇)
DeepSeek 全套汇总资料pdf目前仍然在持续更新中,今天更新了8篇,合计的汇总都在这里了,有需要的朋友可以直接去下载了。 后续更新请关注文章:DeepSeek 全套汇总资料pdf免费下载(持续更新) _ 潘子夜个人博客…...
前端面试题(六):HTTP和HTTPS的区别以及他们如何保障数据安全
HTTP(HyperText Transfer Protocol)和HTTPS(HyperText Transfer Protocol Secure)都是用于在互联网上传输数据的协议,但它们之间有一个重要的区别:安全性。 1. HTTP(超文本传输协议)…...
Buffer Pool 的核心作用与工作机制
Buffer Pool 的核心作用与工作机制 1. Buffer Pool 是什么? Buffer Pool 是 InnoDB 存储引擎的核心内存区域,用于 缓存磁盘中的数据页。 作用:通过内存缓存减少直接磁盘 I/O,加速数据库的读写操作。默认大小:通常设…...
使用uglifyjs对静态引入的js文件进行压缩
前言 因为有时候js文件没有npm包,或者需要修改,只能引入静态的js,那么这个时候就可以对js进行压缩了。我其实想通过vite、webpack等插件进行压缩的,可是他都不能定位到public目录下面的文件,所以我只能自己压缩了。编…...
Vue 3 的<Teleport>功能与用法
Vue 3 的 <Teleport> 功能与用法 1. 基本用法 <Teleport> 是 Vue 3 的一个内置组件,允许将组件的内容渲染到 DOM 中的任意位置,而不改变其逻辑结构。以下是基本用法: 定义目标 DOM 元素:<div id"teleport-…...
2025 年江苏交安安全员考试:借助本地培训资源提升能力
江苏拥有丰富的教育和培训资源,为交安安全员备考提供了有力支持。考生可关注本地专业培训机构开设的交安安全员培训课程,这些课程往往由经验丰富的讲师授课,他们熟悉本地考试特点和行业实际需求。课程内容不仅涵盖考试大纲的知识点࿰…...
Umi Max 和 Ant Design Pro 的区别
1、前言: Ant Design Pro Umi Max Umi Max 和 Ant Design Pro 其实关系很紧密,但用途不同、定位不同。 我们一起来搞清楚它们的区别、联系、使用场景👇 2、一句话总结 名称作用Umi Max是现代前端框架,用来构建中后台项目&#x…...
《 Scikit-learn与MySQL的深度协同:构建智能数据生态系统的架构哲学》
在机器学习工程实践中,数据存储与模型训练的割裂始终是制约算法效能的关键瓶颈。Scikit-learn作为经典机器学习库,其与MySQL的深度协同并非简单的数据管道连接,而是构建了一个具备自组织能力的智能数据生态系统。这种集成突破了传统ETL流程的…...
无公网实体服务器加装多个操作系统供多个用户互不打扰使用_part1
背景介绍 因笔者业务需求,入手了一个实体服务器,但为了避免出现在一个操作系统中搭建编程环境后有许多相关的进程和服务,拖慢日常的使用,也能让其他人短期使用,更好的利用服务器的性能,让服务器专注于“什…...
C#调用Lua方法1+C#调用Lua方法2,3
xLua中Lua调用C#代码 原因:C#实现的系统,因为Lua可以调用,所以完全可以换成Lua实现,因为Lua可以即时更改,即时运行,所以游戏的代码逻辑就可以随时更改。 实现和C#相同效果的系统,如何实现&#…...
浅层神经网络:从数学原理到实战应用的全面解析
浅层神经网络:从数学原理到实战应用的全面解析 前些天发现了一个巨牛的人工智能学习网站,通俗易懂,风趣幽默,可以分享一下给大家。点击跳转到网站。 https://www.captainbed.cn/ccc 一、神经网络演进简史:浅层网络的奠…...
【深度学习:理论篇】--Pytorch基础入门
目录 1.Pytorch--安装 2.Pytorch--张量 3.Pytorch--定义 4.Pytorch--运算 4.1.Tensor数据类型 4.2.Tensor创建 4.3.Tensor运算 4.4.Tensor--Numpy转换 4.5.Tensor--CUDA(GPU) 5.Pytorch--自动微分 (autograd) 5.1.back…...
C++中数组的概念
文章目录 一、数组的定义二、什么是一维数组?2.1 一维数组的声明2.2 一维数组的初始化2.3 一维数组的使用 三、什么是一维数组的数组名?四、一维数组与指针的关系五、数组指针和指针数组的区别5.1 指针数组(array of pointers)5.2…...
996引擎-源码学习:Cocos2d-Lua 的 class(classname, ...)
996引擎-源码学习:Cocos2d-Lua 的 class(classname, ...) 一、核心方法调用顺序用户调用入口完整调用链二、__create 工厂方法的三种情形情形1:父类为函数(自定义工厂)情形2:父类为Cocos原生类情形3:父类为普通Lua表三、方法职责与内存管理对照表四、正确使用示例示例1…...
@linux系统SSL证书转换(Openssl转换PFX)
在Linux中,你可以使用OpenSSL工具将PFX/P12格式的证书转换为单独的CRT(证书)、KEY(私钥)文件以及提取证书链 1. 提取私钥文件(.key) openssl pkcs12 -in your_certificate.pfx -nocerts -out private.key -nodes系统会…...
flask返回json或者中文字符串不要编码
在 Flask 中返回中文字符串时,如果希望浏览器直接显示中文(而非编码后的 Unicode 转义字符如 \uXXXX),需确保以下两点: 正确设置 HTTP 响应的字符集(如 utf-8)。 避免 Flask 默认的 JSON 序列化转义中文字符。 以下是具体实现方法: 方法 1:直接返回纯文本(非 JSON) …...
打造船岸“5G+AI”智能慧眼 智驱力赋能客船数智管理
项目介绍 船舶在航行、作业过程中有着严格的规范要求,但在实际航行与作业中往往会因为人为的疏忽,发生事故,导致人员重大伤亡和财产损失; 为推动安全治理模式向事前预防转型,实现不安全状态和行为智能预警,…...
【Proteus仿真】【32单片机-A007】PT100热敏温度检测系统设计
目录 一、主要功能 二、使用步骤 三、硬件资源 四、软件设计 五、实验现象 联系作者 一、主要功能 1、LCD1602显示当前检测的温度值以及温度阈值 2、超过上限温度,降温模块启动 3、PT100热敏电阻测量-60C-135C 4、按键设置温度阈值 5、超过阈值࿰…...
MPDrive:利用基于标记的提示学习提高自动驾驶的空间理解能力
25年4月来自南方科技大学、百度、英国 KCL和琶洲实验室(广东 AI 和数字经济实验室)的论文“MPDrive: Improving Spatial Understanding with Marker-Based Prompt Learning for Autonomous Driving”。 自动驾驶视觉问答(AD-VQA)…...
PhotoShop学习08
1.应用滤镜 PhotoShop提供了很多滤镜,借助滤镜可以打造很多有趣的效果。滤镜可以通过点击菜单栏的滤镜,并选择滤镜库进入滤镜调整界面。 进入到滤镜库后,左侧是实时进行预览的图片,右侧可以选择滤镜效果,最右边可以调…...
Photoshop2025最新版v26超详细图文安装教程(附安装包)
前言 Photoshop是一款基于位图的图像处理软件,专注于对已有图像的编辑、修复、合成及特效制作。其核心功能包括图层管理、色彩校正、选区工具、滤镜效果等,支持多种颜色模型(如RGB、CMYK、CIELAB)和文件格式(如.PSD、…...
Plusar集群搭建-Ubuntu20.04-Winterm
1 背景 已经部署了Pulsar集群在生产上,新项目需要用到Pulsar。对Pulsar不熟,故搭建练手。 环境:Windows10vmwareUbuntu20.04,ssh工具使用的Winterm。 使用的是root账户,ubuntu防火墙都ufw disable了。 2 参考文档 集…...
Qt与C++数据类型转换
本文深入探讨Qt与C中相似但不同的数据类型处理技巧。 一、QString与std::string的相互转换 1. QString → std::string 方法1:使用toStdString()(推荐) QString qstr "你好,Qt世界"; std::string str qstr.toStdS…...
Excel处理控件Aspose.Cells指南:如何查看、编辑和删除 Excel 元数据
本文是如何使用Aspose.Cells的在线工具和编码解决方案查看、编辑和删除 Excel 元数据的综合指南。无论您是寻找快速Excel 元数据查看器的普通用户,还是寻求强大的Excel 元数据编辑器的开发人员,本指南都能满足您的需求。您可以选择使用简单的在线转换器来…...
Rust 在汽车 MCU 编程中的进展及安全特性剖析
在当今汽车行业,软件定义汽车的趋势正深刻改变着汽车的设计与用户体验。随着汽车电子系统复杂性的不断提升,对汽车微控制器(MCU)编程的安全性、可靠性和效率提出了更高要求。Rust 作为一种新兴的编程语言,凭借其独特的…...
Pytorch 第十四回:神经网络编码器——变分自动编解码器
Pytorch 第十四回:神经网络编码器——变分自动编解码器 本次开启深度学习第十四回,基于Pytorch的神经网络编码器。本回分享VAE变分自动编码器。在本回中,通过minist数据集来分享如何建立一个变分自动编码器。接下来给大家分享具体思路。 本次…...
hive排序函数
在 Hive 中,排序可以通过几种不同的方法来实现,通常依赖于 ORDER BY 或 SORT BY 等函数。这里简要介绍这几种排序方法: 1. ORDER BY ORDER BY 用于对结果集进行全局排序。它会将所有数据加载到一个节点进行排序,因此可能会导致性能问题,尤其是在数据量很大的时候。 语法…...
Android测试王炸:Appium + UI Automator2
Android平台主流开源框架简介 在Android平台上,有多个开源且好用的自动化测试框架。以下是几个被广泛使用和认可的框架: 1.1 Appium Appium是一个跨平台的移动测试工具,支持iOS和Android上的原生、混合及移动Web应用。 它使用了供应商提供的…...
用Python打造增强现实的魔法:实时对象叠加系统全解析
友友们好! 我是Echo_Wish,我的的新专栏《Python进阶》以及《Python!实战!》正式启动啦!这是专为那些渴望提升Python技能的朋友们量身打造的专栏,无论你是已经有一定基础的开发者,还是希望深入挖掘Python潜力的爱好者,这里都将是你不可错过的宝藏。 在这个专栏中,你将会…...
const let var 在react jsx中的使用方法 。
在 JavaScript 里,const 和 let 都是 ES6(ES2015)引入的用于声明变量的关键字,它们和之前的 var 关键字有所不同。下面为你详细介绍 const 和 let 的区别: 1. 块级作用域 const 和 let 都具备块级作用域,…...