特斯拉引荐奖励
Posted by quentin 在 Friday, 24 November 2023越过山丘,勇立潮头:20年技术老兵的安泰"破壁"与"重构"
Posted by quentin 在 Tuesday, 9 June 2026在技术领域深耕近二十年,我先后跨越了通信、软件、互联网等多个行业,并在金融科技领域潜心笃行近十年。一路上,我经历了从后端到前端的技能迁移,也完成了从普通工程师到研发管理者的角色跃迁。我曾作为初创成员,从零开始搭建起一支高效的团队;也曾与伙伴们并肩作战,见证了核心业务突破万亿规模的高光时刻。
然而,当技术管理走到深水区,我逐渐感受到了那面无形的玻璃天花板——单纯的技术视角在面对复杂的商业战略、跨部门协同以及宏观市场变化时,常常显得力不从心。
为了突破认知瓶颈,重塑个人品牌,并构建更宽广的资源网络,我选择在职业生涯的黄金期主动求变。2026年,我顺利拿到了上海交通大学安泰MBA综合管理方向的拟录取通知。
这段备考之路,既是一次严苛的自我测试,也是一场关于"取舍"的修行。以下是我的一些实战经验,希望能为正在筹备考研的学弟学妹们提供一些落地、有价值的参考。
一、择校:谋定后动,选择最契合的土壤
对于在职备考的人来说,精力的分配是极其奢侈的,因此择校的精准度决定了备考的性价比。我选择交大安泰MBA,主要基于三个维度的考量:
写下第一行管理代码之前,没人告诉你的事
Posted by quentin 在 Tuesday, 9 June 2026上周和一个刚升 Tech Lead 的朋友吃饭,他半开玩笑说了句:"我以前觉得最焦虑的是线上故障,现在发现最焦虑的是打开 Slack 不知道该回哪条消息。"
他不是在抱怨工作量。他困惑的是一个更根本的问题——他不确定自己现在到底该干什么。
这位朋友技术能力没得说,组里最难的问题都是他啃下来的。升职之后,他给自己定的策略很简单:还是干最难的活,顺便把管理的事也带着做了。三个月下来,最难的技术活他还在干,管理的事全是"顺带"——顺带开个会,顺带审批个需求,顺带和产品对个方案。团队产出反而不如他一个人扛活的时候。
这个故事不新鲜。我见过太多优秀的工程师在走上管理岗之后经历类似的挣扎。不是能力问题,是角色切换的认知滞后——你以为只是多了一些职责,其实是在换一个职业。
升的是 Title,丢的是手感
工程师的身份建立在什么上面?解决问题的能力。一个 bug 搞定,一个功能交付,一个性能瓶颈突破——每一个都是明确的、可感知的成就。这种正反馈循环是工程师职业早期的核心驱动力。
防资损这道题,测试答不了
Posted by quentin 在 Monday, 8 June 2026金融系统出bug和出资损,是两个完全不同的量级。功能写错了,改过来就是;页面丑了,迭代一轮就行;但钱算错了,那是客诉、是赔付、是监管约谈,严重的时候直接停业整改。
我观察到一个很普遍的反应模式:出了资损,先加测试用例;又出一次,加人肉对账;再出一次,加发版审批。每一步都在做加法,每一步都离根本原因更远。因为大部分人把资损当成了一种"严重的bug",用防bug的思路来防资损。这个认知偏差才是资损反复出现的根源。
资损不是bug的严重版
普通bug和资损的核心区别在于:bug是你功能做错了,资损是你的功能没做错,但钱错了。
一个理财产品页面,把年化收益率3.5%展示成3.8%,这是bug。但用户基于3.8%做了购买决策,实际到账按3.5%结算,用户体验上的落差就是资损——即使从功能角度看,展示模块和计算模块各自都"按逻辑运行"。
更典型的场景:用户申购一笔理财,网络超时,前端重试了一次,后端处理了两笔。这两笔处理的每一笔单独看都没"错"——接口接收请求、参数校验通过、数据库写入成功。但因为缺少幂等约束,结果就是资损。
Vibe Coding在生产环境活不过三天
Posted by quentin 在 Monday, 8 June 2026"Vibe Coding"这个词火了有一阵子了。Andrej Karpathy说他写代码时更像是给AI指个方向,然后让AI去实现,自己更像是在"vibing"——感受代码的走向,而不是一行行敲出来。这说法一出,无数开发者深有共鸣。毕竟谁不想当那个只管提需求、不用写实现的人呢?
这体验确实爽。你告诉AI"帮我写一个用户认证模块",唰唰唰生成了一个看起来像模像样的实现。你甚至不用读完每一行代码,直接点运行,测试通过,感觉自己效率起飞。
但我观察到一个现象:Vibe Coding在Demo里无所不能,在生产环境里处处掣肘。那些靠AI快速拼出来的代码,一旦进入有历史包袱的真实业务系统,就开始不断露馅。而且问题往往不是代码本身有Bug,是这些代码跟现有系统格格不入。
这不是AI不够聪明。这是Vibe Coding这个工作方式本身的前提就不成立。
你以为在写代码,其实在丢上下文
Vibe Coding的核心体验是什么?你只需要表达意图,代码自动出来。这个体验让人上瘾,因为它跳过了编程中最痛苦的部分——把模糊的想法翻译成精确的逻辑。
但有一个被忽略的前提:你跳过的那些部分,恰恰是你建立代码上下文的过程。
开会成瘾的技术团队,病根不在日历
Posted by quentin 在 Friday, 5 June 2026上周清理日历的时候顺手做了个统计——我所在的技术团队,10个人,一周62个会议。人均每周6.2个,平均每天1.2个。如果按每个会议40分钟算,将近四小时。还没算上会前准备和会后消化,还没算上那些"5分钟碰一下"的临时通话。
这不是个别现象。我跟同行聊过,金融科技领域尤其严重——合规对齐要开会,风险评审要开会,跨团队排期要开会。一个需求的开发周期里,真正写代码的时间可能还不到一半。
很多团队的第一反应是"减会"——砍掉每日站会,缩短周会,设立无会议日。然后呢?信息断了,对齐塌了,出问题的概率反而上升。砍完的会议像野草一样换个形式长回来。
我后来想明白了这件事:会议不是问题,会议是症状。就像发烧不是病,是身体在对抗感染。你把体温压下去,不等于治好了。
每个砍不掉的会,都在替系统还债
技术团队里的会议,大致可以分几类。每一类背后都藏着不同的问题。你不可能一刀切地减掉它们,因为砍掉会议后露出来的那个洞,可能比会议本身更危险。
同步会:你的模块边界画错了
两个子系统需要"定期同步",这是最常见的一种会。前端和后端每周对齐,A团队和B团队双周同步。听起来很合理,但仔细想想——如果两个模块之间需要定期人工同步,说明什么?
代码的第一读者不是机器,是审计
Posted by quentin 在 Thursday, 4 June 2026上周组里一个产品上线前的合规评审会上,合规专员盯着一段前端代码问了一个问题:"这个收益率计算逻辑,用户在购买前看到的结果和购买后持仓页显示的结果,走的是不是同一条计算链路?"
在场的两个前端工程师面面相觑。答案是"不是"。购买前用的是推荐接口的预计算数据,持仓页用的是资产接口的实时结算数据。两条链路,两套精度处理,两组四舍五入规则。在普通业务里这根本不算事——数据来源不同,展示逻辑不同,非常自然。但在金融业务里,这意味着用户可能看到购买前年化3.52%,购买后变成3.51%。
0.01%的偏差,万亿规模下就是上亿的资金差异预期。合规专员当场拍了桌子,上线延期两周。
这个场景在互联网公司几乎不会发生。但在金融科技团队,它是日常。
金融业务的代码有两套读者
大部分工程师写代码时心里只有一个读者:运行时环境。代码能不能跑,跑得快不快,内存占不占得住——所有的优化方向都指向机器。
金融业务的代码不一样。它有两套读者:机器和审计。而且讽刺的是,审计这个读者往往比机器更难伺候。机器只要逻辑正确就行,审计要的是"逻辑正确且可追溯且可解释且可复现"。多出来的这三个"且",才是金融科技工程真正的成本。
DRY的幻觉:你消灭的重复,正以耦合的形式回来找你
Posted by quentin 在 Wednesday, 3 June 2026DRY——Don't Repeat Yourself。这四个字母可能是软件工程里被引用最多、被误解最深的原则。
每个程序员入行第一天就被告知:重复代码是邪恶的,看到重复就要提取,看到提取就要抽象,看到抽象就要泛化。于是我们疯狂地消灭重复——公共函数、工具类、基础库、共享模块......代码库越来越"干净",重复率越来越低,CI里没有任何duplicate code的警告。
然后某一天,一个业务需求来了——需要改动某个"公共"逻辑。你打开那个被47个地方引用的utils函数,改了一行,跑了一下测试——绿了。上线,结果三个业务线同时报警。你突然发现,那三个业务线依赖的是同一个函数的三种不同行为,被那个"公共"函数强制统一了。
你消灭了重复代码,但你制造了耦合。而耦合,是比重复贵十倍的技术债。
重复代码不是问题,问题是不知道为什么重复
所有关于DRY的讨论,都默认了一个前提:重复等于坏。但这个前提本身就是幻觉。
重复代码至少有三种完全不同的面目。
第一种是意外重复——两个开发者不知道对方写了同样的功能,造了两个轮子。这种重复才是真正需要消灭的,因为它意味着信息浪费和潜在的不一致。
错误处理的谎言:你以为在兜底,其实在埋雷
Posted by quentin 在 Tuesday, 2 June 2026打开任何一个前端项目的代码,搜索 `catch`,你大概率会看到这样的画面:
```javascript
try {
await fetchData();
} catch (e) {
console.error(e);
message.error('操作失败,请稍后重试');
}
```
后端也好不到哪去:
```javascript
try {
await processOrder(orderId);
} catch (err) {
logger.error('订单处理失败', { orderId, error: err.message });
throw new BusinessException('系统异常,请重试');
}
```
这两段代码有一个共同的特质——它们让你觉得错误被"处理"了。日志打了,提示也弹了,异常也抛了,一切看起来都很体面。
但你仔细想想:用户看到"操作失败,请稍后重试"之后能做什么?重试?然后呢——再失败一次?运维看到一条"订单处理失败"的日志,能定位到什么?是库存扣减超时,还是支付回调丢失,还是风控拦截?

