首页
关于
友链
推荐
肥啾解析
百度一下
肥啾GPT
Search
1
宝塔面板登录 phpMyAdmin 提示服务器和客户端上指示的HTTPS之间不匹配
269 阅读
2
Customer complaints evolve with in-car tech
188 阅读
3
JavaScript解析
153 阅读
4
内连接,左连接,右连接作用及区别
111 阅读
5
所谓关系
109 阅读
默认分类
网游架设
手机游戏
python
PHP
Mysql
VBA
C++
JAVASCRIPT
javascript基础
Oracle
生产管理
计划控制
ERP系统开发
APS排产
MES研究
考勤系统
CPA
财管
实务
经济法
战略
审计
税法
藏书架
古典名著
世界名著
编程秘籍
攻防渗透
经管书籍
大佬传经
风雅读物
考试相关
心情格言
拾玉良言
外文报刊
外刊随选
Facebook
Twitter
China Daily
软考
登录
Search
标签搜索
期刊读物
古文
何瑜明
累计撰写
160
篇文章
累计收到
154
条评论
首页
栏目
默认分类
网游架设
手机游戏
python
PHP
Mysql
VBA
C++
JAVASCRIPT
javascript基础
Oracle
生产管理
计划控制
ERP系统开发
APS排产
MES研究
考勤系统
CPA
财管
实务
经济法
战略
审计
税法
藏书架
古典名著
世界名著
编程秘籍
攻防渗透
经管书籍
大佬传经
风雅读物
考试相关
心情格言
拾玉良言
外文报刊
外刊随选
Facebook
Twitter
China Daily
软考
页面
关于
友链
推荐
肥啾解析
百度一下
肥啾GPT
搜索到
26
篇与
的结果
2026-01-07
软工知识点
函数调用时实参向形式参数传递相应类型的值,则称为是传值调用。这种方式下形式参数不能向实参传递信息。实参可以是变量,也可以是常量和表达式。引用调用的实质是将实参变量的地址传递给形参,因此,形参是指针类型,而实参必须具有左值。变量具有左值,常量没有左值。被调用函数对形参的访问和修改实际上就是针对相应实际参数所作的访问和改变,从而实现形参和实参间双向传递数据的效果。{callout color="#f0ad4e"}传值调用(就像“复印一份”)做法:你把文件的完整复印一份,把这份复印件交给朋友。朋友的操作:他可以在复印件上任意涂改、做笔记。对你原件的影响:没有任何影响。你手里的原件还是原来那份,干干净净。在编程中的体现:函数内部修改的是“复印件”(形参),而外部的原始数据(实参)完全不变。实参可以是任何数据(变量、数字5、一个算式的结果)。引用调用(就像“共享电子文档链接”)做法:你把文件存储在云盘(如Google Docs),然后只把文件的访问链接(地址) 发给朋友。朋友的操作:他点击这个链接,打开的就是你电脑里的那个唯一原件。他做的任何修改都会直接保存到这份原件上。对你原件的影响:直接影响。你再打开文件,看到的就是他修改后的版本。在编程中的体现:函数内部通过“链接”(地址)直接操作外部的原始数据(实参)。为了实现这一点:实参必须是一个“有位置的变量”(就像一个实际存在的云盘文件)。你不能把一个纯数字(比如5)或者一句话的链接发给别人,因为这些东西没有“存储位置”可供修改。这也就是解析里说的,实参必须有 “左值” (可以简单理解为 “是一个可以存放东西的容器/位置”)。{/callout}为什么只有变量才有存储位置问题简单来说就是内存寻址的概念。计算机中,程序运行时,数据需要存储在内存中特定的位置(地址)。变量在程序中定义时,编译器或解释器会为它分配一块内存空间,因此变量有存储位置(地址)。而常量和表达式的结果(除非被赋给变量)通常是临时性的,它们可能存放在寄存器或临时栈空间,但程序通常不提供直接访问其地址的机制(尤其是常量,往往在编译时就确定了值,可能直接嵌入指令中,没有运行时内存地址)。对于引用调用(传递地址),需要实参有一个固定的、可寻址的内存位置,以便形参(指针)能够指向它,从而通过指针修改其内容。常量没有可修改的内存位置(常量通常存储在只读内存区或直接编码在指令中),表达式的结果是临时值,也没有持久的内存地址(除非先赋给变量)。因此,只有变量(或更广义的左值)才能进行引用传递。左值(lvalue)是一个历史术语,意指可以出现在赋值语句左边的表达式,即它标识了一个可存储对象的位置。变量是典型的左值。常量和算术表达式的结果是右值(rvalue),它们没有可标识的存储位置(或者说是临时值)。引用调用需要左值,因为需要取地址。举例:假设有函数 void f(int &x) { x = 10; }调用时:int a = 5; f(a); // 正确,a是变量,有地址f(5); // 错误,5是常量,没有可修改的地址f(a+1); // 错误,a+1是表达式结果,临时值,没有持久地址因此,引用调用要求实参必须是左值(变量)。
2026年01月07日
1 阅读
0 评论
0 点赞
2025-12-25
学习路径
你说得非常对。如果不知道“为什么学”,再好的知识也是死知识。抽象的知识必须落地到具体的“用处”上,才能产生价值。让我彻底换个角度回答你:我们就从你熟悉的“用网页建立功能”出发,看看当你试图把功能做得更好、更大、更专业时,那些“其它知识”是如何一个个跳出来,成为你绕不过去的坎的。它们不是“要学的一堆东西”,而是“你在成长路上不得不解决的问题的答案”。故事:从个人博客到下一个“微博”假设你现在已经能用 PHP + SQL + JavaScript 建一个不错的个人博客了。用户能注册、登录、发表文章、评论。接下来,你想把它做大。你会遇到什么?这些“其它知识”的用处就来了。第一阶段:你的博客开始卡顿、出Bug问题1:网站越来越慢。 一篇文章有几千条评论时,你的 SELECT * FROM comments WHERE post_id=... 查询要好几秒。SQL底层知识(索引、执行计划) 的用处:你会知道,在 post_id 字段上加一个索引,可以让这个查询从几秒变成几毫秒。这就叫“优化”。问题2:你改了段PHP代码,结果整个网站白屏,还搞乱了之前的正常功能。Git 的用处:有了Git,你可以在改代码前“存个档”。改坏了?一键回滚到昨天正常的状态。这是你代码的“时光机”和“保险箱”。问题3:你想在服务器上找出为什么慢,或者批量修改一万个用户的后缀名。Linux命令行 的用处:你需要登录到那台远程的Linux服务器。看日志用 tail -f error.log,找慢查询用 grep 'slow',批量修改数据可以写个Shell脚本,一分钟搞定。没有命令行,你就像被关在机房玻璃门外,干着急。👉 第一阶段小结: 为了让你已有的功能更稳定、更快、更可控,你需要数据库优化、版本控制和服务器操作知识。这不是“额外学的”,而是维护和优化你的作品所必需的技能。第二阶段:你想吸引更多用户,功能变复杂问题4:用户数破万,搜索功能变得奇慢无比。算法与数据结构 的用处:你会理解,为什么简单的循环匹配不行,而用“倒排索引”(想想书的目录)这种数据结构能瞬间找到结果。你就能理解为什么要用Elasticsearch这样的专业搜索引擎,而不是自己瞎写SQL LIKE。问题5:图片上传功能被坏人利用,上传了木马,或者有人用脚本疯狂注册垃圾账号。网络与安全基础 的用处:你会理解文件类型校验、SQL注入、XSS攻击的原理。你知道怎么给PHP配置防火墙,怎么设计安全的API。你的功能不再只是一个玩具,而是一个需要负责的产品。问题6:你和朋友一起开发,代码合并冲突,分工混乱。Git高级用法(分支管理) 的用处:你们可以各开一个“分支”开发新功能,互不干扰,开发完再优雅地合并。这就是团队协作的基石。👉 第二阶段小结: 为了让你能开发更高级、更安全、需要协作的功能,你需要理解程序效率的根本(算法)、安全的基础和团队工作的流程。第三阶段:你的网站火了,需要面对海量用户问题7:每天百万人访问,你的单台服务器瞬间宕机。系统设计 的用处:这时你会思考:数据库读写分离(一台负责写,多台负责读)、加缓存(用Redis把热门文章存起来,不用每次都查数据库)、把图片扔到对象存储(比如阿里云OSS)、用负载均衡把流量分给十台服务器。这时,你不再是一个写PHP页面的程序员,而是一个系统架构师。你画的系统架构图,决定了网站能承载的极限。问题8:你需要管理几十台服务器,手动操作已不可能。Linux命令行 + Shell脚本 + 自动化工具 的用处:你会写脚本自动部署代码、监控服务器健康、批量处理日志。你从手动劳动中解放出来,让机器为你工作。问题9:你需要向投资人解释你的技术优势,或者给新同事讲解系统。清晰的写作与沟通 的用处:你能画出一张清晰的架构图,写一份易懂的技术文档。这是让你的技术和想法产生更大影响力的“乘数技能”。👉 第三阶段小结: 为了让你亲手构建的功能能承载百万、千万级的用户,并高效地管理它,你需要有设计复杂系统的思维和自动化一切的效率工具。这时,你的天花板被无限拔高。所以,它们到底能做什么?—— 一句话总结SQL底层原理:让你手里的数据库这把枪,从“烧火棍”变成“狙击步枪”,指哪打哪,又快又准。Linux命令行:让你获得操作服务器的“超能力”,从门外汉变成机房的主人。算法与数据结构:让你在遇到性能瓶颈时,知道问题的本质,并知道用什么“武器”去解决,而不是永远只会蛮力循环。Git:让你写代码时有胆量创新、有后悔药可吃、能与人合作。网络与系统设计:让你能从 “盖一个狗窝” 进阶到 “设计一座摩天大楼” ,并且知道如何防震、防火、防拥堵。清晰的沟通:让你所有的技术和努力能被别人看见、理解并认可,将你的价值放大10倍。最终结论:你学 PHP + SQL + JS,是在学习 “如何制造零件和组装一辆自行车”。而学习那些底层知识,是在学习 “内燃机原理、道路规划、交通法规、车队管理”。当你想造一辆汽车,甚至管理一个物流网络时,后者是决定性因素。给你的行动建议:继续用你喜欢的网页技术做项目,这是你的动力源泉和试验田。当项目遇到实际问题时(比如慢了、崩了、难合作了),把这当作学习那些“底层知识”的绝佳入口。带着问题去学习:比如今天网站慢了,你就去研究“SQL索引优化”;明天要团队开发,就去学“Git分支模型”。这样学来的知识,立刻就能用上,你立刻就能感受到它的“用处”。你不是在学一堆无用的理论,你是在为你亲手创造的世界,打下越来越坚实的地基,并获得建造更高大厦的蓝图与工具。
2025年12月25日
2 阅读
0 评论
0 点赞
2025-12-16
正则表达式核心用法
三、常见模式示例(直接拿来用) 现在我们把上面的规则组合起来,看看实际应用。 匹配手机号(中国大陆):1[3-9]\d{9} 1:以1开头 [3-9]:第二位是3-9 \d{9}:后面跟着9个数字 示例匹配:13800138000 匹配电子邮箱:\w+@\w+\.\w+ \w+:一个或多个单词字符(用户名) @:字面量@ \w+:一个或多个单词字符(域名) \.:转义的点号(.是元字符,需要\转义) \w+:一个或多个单词字符(顶级域名,如com) 简单示例匹配:test@example.com(实际邮箱更复杂,这是简化版) 提取日期(YYYY-MM-DD格式):(\d{4})-(\d{2})-(\d{2}) 这里引入了 () 分组 的概念。括号内的内容会被单独“捕获”,方便你提取。 匹配 2023-10-27 后,可以分别获得 2023、10、27 三个部分。 匹配空白行:^\s*$ ^:行首 \s*:0个或多个空白字符 $:行尾 这行除了空白什么都没有,所以是空白行。
2025年12月16日
1 阅读
0 评论
0 点赞
2025-09-26
include重复匹配解决办法
for (const exhaust of CONFIG_VALUES['护顶架']) { if (allText.includes(exhaust)) { values['护顶架'] = exhaust; //break; } }此代码会检测CONFIG_VALUES['护顶架']所有包含exhaust元素,当exhaust匹配到多个元素时导致类似前后蓝光灯,后蓝光灯的结果同时出现const matchedValues = []; let remainingText = allText; // 保存剩余未匹配文本 for (const exhaust of CONFIG_VALUES['护顶架']) { const matchIndex = remainingText.indexOf(exhaust); if (matchIndex !== -1) { matchedValues.push(exhaust); // 直接移除已匹配部分(保留前后文) remainingText = remainingText.substring(0, matchIndex) + remainingText.substring(matchIndex + exhaust.length); } } values['护顶架'] = matchedValues.join(', '); 这段代码实现了一个文本匹配和标记功能,主要用于从allText中提取特定配置值。以下是分步解释: 初始化变量: matchedValues数组用于存储匹配到的结果 remainingText初始化为原始文本allText的副本 循环匹配过程: 遍历CONFIG_VALUES['护顶架']中的每个配置项 使用indexOf查找配置项在当前剩余文本中的位置 如果找到匹配项,执行两个操作: a) 将匹配项加入结果数组 b) 从剩余文本中物理移除该匹配项 结果处理: 将匹配结果用逗号连接后存入values['护顶架'] 原始allText不会被修改(除非显式赋值) 特点说明: 采用字符串切割方式确保每个配置项只匹配一次 保持前后文连续性(移除时保留前后部分) 结果输出格式为逗号分隔的字符串 适合处理需要精确匹配且避免重复的场景 remainingText.substring(0, matchIndex) 截取从字符串开头到匹配位置之前的内容(保留匹配项前面的部分) remainingText.substring(matchIndex + exhaust.length) 截取从匹配项结束位置到字符串末尾的内容(保留匹配项后面的部分) 用+将前后两部分拼接 相当于在原字符串中"挖掉"匹配到的部分 举例说明: 假设原文本是"ABC护顶架123护顶架XYZ",匹配"护顶架"时: 第一次匹配:保留"ABC" + "123护顶架XYZ" → 新字符串为"ABC123护顶架XYZ" 第二次匹配时就不会重复匹配第一个"护顶架"了 这种处理方式比用特殊字符标记更彻底,直接从物理上移除已匹配内容。 用更直观的方式解释substring()的工作原理: 字符串切割原理: 可以把字符串想象成一列火车车厢,每个字符就是一个车厢 substring(start,end)就是指定要保留哪几节车厢 具体到这段代码: 假设原字符串是:"ABC护顶架123护顶架XYZ"(长度15) 匹配到"护顶架"(长度3)在位置3 matchIndex=3, exhaust.length=3 切割过程: substring(0,3) → "ABC"(保留匹配项前面的车厢) substring(3+3) → "123护顶架XYZ"(跳过匹配项,保留后面的车厢) 拼接结果:"ABC" + "123护顶架XYZ" = "ABC123护顶架XYZ" 关键特性: 不修改原字符串(生成新字符串) 第二个参数可省略表示截取到末尾 位置计算从0开始(第一个字符是位置0) 基础概念: substring(start) 表示从start位置开始截取到字符串末尾 substring(start, end) 表示截取start到end-1位置的子串 具体到您的例子: 原字符串:"ABC护顶架123护顶架XYZ" 第一次匹配"护顶架"在位置3(长度3) matchIndex + exhaust.length = 3 + 3 = 6 所以substring(6)就是从第6个字符开始截取 字符位置可视化: A(0) B(1) C(2) 护(3) 顶(4) 架(5) 1(6) 2(7) 3(8) 护(9) 顶(10) 架(11) X(12) Y(13) Z(14) 位置6正好是第一个"护顶架"后面的"1" 为什么是3+3: 第一个3是匹配项的起始位置("护"字的位置) 第二个3是"护顶架"的长度(3个字符) 相加得到的就是匹配项结束后的第一个位置 实际效果: 相当于在原字符串中"跳过"了已匹配的3个字符 从匹配项结束后的位置继续处理剩余字符串 这种写法是字符串处理的常用模式,确保: 已处理的内容不会重复处理 保持字符串处理的连续性 避免使用特殊字符标记带来的副作用matchIndex !== -1 这个条件是用来判断字符串是否包含目标子串的,具体原理如下: indexOf()方法的行为: 当子串存在时,返回该子串首次出现的索引位置(0或正整数) 当子串不存在时,固定返回-1 为什么用-1判断: 这是JavaScript语言的设计规范 -1作为"未找到"的专用标识值(不会与有效索引冲突,因为有效索引从0开始) 实际意义: matchIndex !== -1 表示"找到了匹配项" matchIndex === -1 表示"未找到匹配项"
2025年09月26日
1 阅读
0 评论
0 点赞
2025-09-16
navicat破解方法记录
客户端 Navicat16和17补丁.rar 正常安装完成后,不要打开navicat,先将网盘下载的Navicat16和17补丁压缩包解压,解压之后你会看到winmm.dll文件,将它移动到你刚刚安装navicat17的目录下,操作完成后,打开navicat,如果没有提示试用,则说明激活成功,可永久使用
2025年09月16日
4 阅读
0 评论
0 点赞
1
2
...
6
0:00