AI无法解决的Bug系列(一)跨时区日期过滤问题

跨时区开发中,React Native如何处理新西兰的日期过滤问题

有些Bug,不是你写错代码,而是现实太魔幻

比如我最近给新西兰客户开发一个React Native应用,功能非常朴素:用户选一个日期范围,系统返回该范围内的日志。

很简单对吧?结果客户连着几天发消息抱怨:

“我选 4 月 30 日,结果一个日志都没有。”
“我选 29 到 30 日,它却只给我 28 日的内容?”

我这边一看,数据库明明有数据,接口逻辑也没问题。我自己一测,一切正常。

奇怪的分界线:12 点

后来我逐渐发现一个微妙的规律:客户上午测试就报错,我这边是中午12点以后测试的,每次都正常。

这让我突然意识到一个关键问题——新西兰时区比UTC快整整 12 或 13 小时(取决于是否夏令时)

所以客户早上选“今天”的时候,其实是:

  • 新西兰时间:2025-04-30 09:00
  • 转成UTC:2025-04-29 21:00

后台拿到UTC一查:29 号?当然没有 30 号的日志,客户当然觉得你系统出错。

AI登场:一本正经地告诉我“你没转换时区”

我让AI帮忙分析,它第一句话就是:

“请将前端的日期转换为 Pacific/Auckland 时区再传给后端。”

我笑了。这当然是“正解”,可惜我们用的前端组件(DatePicker那一类)永远返回的是UTC,你再怎么本地转换,它最后还是给你一个 2025-04-29T12:00:00.000Z

这不就等于我洗了一遍手,又摸回原来的脏东西上。

插曲一:传字符串行不行?

我一度觉得,既然组件不行,那干脆直接传字符串吧,比如 "2025-04-30" 这种明明白白的格式。

于是我建议大家传字符串,再在后端统一用 new Date("2025-04-30") 来解析。

听起来确实不错,结果一试……全系统几十个地方涉及日期格式解析、比较、展示,全都要重写,组件也不认字符串了,还得加一堆格式化处理。

我沉默了 5 秒钟,打回这个提议。

还是太重了,伤筋动骨,放弃。

插曲二:传个“假UTC”看看?

我灵光一闪:如果我硬要前端传 UTC 时间,那我干脆就“骗”它一下好了!

用户选 2025-04-30,我就手动往这个时间里加 12 或 13 小时,让它看起来像 UTC,但其实它表示的是新西兰时间。

比如:

// dateFrom: 2025-04-30T00:00:00 NZT
// -> 调整后发送:2025-04-29T12:00:00Z(UTC格式)

这样一来:

  • 组件依旧开心,传的是 Date
  • 后端逻辑不动,处理的是 UTC
  • 看上去合规,实际上我们偷偷塞了个“假的UTC”进去

我把这个方案告诉AI,它思考了两秒钟,回答说:

“唯一的缺点是,从技术严格性角度来看,这不是一个‘正确’的解决方案。但从实用角度看,它完全解决了问题,并且代码干净简洁。”
“这种方法本质上是通过人为调整时间来补偿时区差异,而不是通过标准的时区转换机制。”

我:???
你前面怎么没提这个方案?

只能说,AI的知识面再广,它也想不到“骗时间”这种歪招——因为它不敢提这种方案,它太“正直”了,不像人类程序员这样“又懒又坏还有效”。

最后的实现

我的方案非常简单,只做两件事:

  1. Intl.DateTimeFormat 获取新西兰当前偏移量(动态判断是否夏令时)
  2. 在用户选完日期后,手动加上这个小时数,直接塞进 Date 对象里传给后端

后端收到的是标准UTC,但时间已经被我偷偷换过了。

业务逻辑不动,UI正常,所有日志都对上了。

const getNZOffsetHours = () => {try {const now = new Date();const formatter = new Intl.DateTimeFormat('en-US', {timeZone: 'Pacific/Auckland',timeZoneName: 'short'});const formatted = formatter.format(now); // e.g., "4/30/2025, NZST"const match = formatted.match(/GMT([+-]\d+)/);return match && match[1] ? parseInt(match[1], 10) : 12;} catch {return 12;}
};

有时候,最聪明的不是AI

你可以让AI写代码、查bug、做重构。但它无法替代你站在“真实用户”和“现有代码”的缝隙中,找到那个最合适的、最省事的方案

这种Bug,就是典型的:

  • 你说它不是Bug吧,它确实出错了;
  • 你说它是Bug吧,代码哪哪都没写错。

最终解决它的不是完美设计,而是一点点工程直觉和一点点狡猾。


这就是“AI无法解决的Bug系列”的第一篇。
如果你也踩过这种坑,别急着问AI,先问问自己:
我能不能骗一骗它?

下集见。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/web/80665.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

基于天猫 API 的高效商品详情页实时数据接入方法解析

一、引言 在电商大数据分析、竞品监控及智能选品等场景中,实时获取天猫商品详情页数据是关键需求。本文将详细解析通过天猫开放平台 API 高效接入商品详情数据的技术方案,涵盖接口申请、数据获取逻辑及代码实现,帮助开发者快速构建实时数据采…

系分论文《论遗产系统演化》

系统分析师论文范文系列 摘要 2022年6月,某金融机构启动核心业务系统的技术升级项目,旨在对其运行超过十年的遗留系统进行演化改造。该系统承担着账户管理、支付结算等关键业务功能,但其技术架构陈旧、扩展性不足,难以适应数字化转型与业务快速增长的需求。作为系统分析师,…

Spark Core基础与源码剖析全景手册

Spark Core基础与源码剖析全景手册 Spark作为大数据领域的明星计算引擎,其核心原理、源码实现与调优方法一直是面试和实战中的高频考点。本文将系统梳理Spark Core与Hadoop生态的关系、经典案例、聚合与分区优化、算子底层原理、集群架构和源码剖析,结合…

人工智能赋能产业升级:AI在智能制造、智慧城市等领域的应用实践

人工智能赋能产业升级:AI在智能制造、智慧城市等领域的应用实践 近年来,人工智能(AI)技术的快速发展为各行各业带来了深刻的变革。无论是制造业、城市管理,还是交通、医疗等领域,AI技术都展现出了强大的应用…

React Native打包报错: Task :react-native-picker:verifyReleaseResources FAILE

RN打包报错: Task :react-native-picker:verifyReleaseResources FAILED Execution failed for task :react-native-picker:verifyReleaseResources. 解决方法: 修改文件react-native-picker中的版本信息。 路径:node_modules/react-native-p…

虚拟网络编辑器

vmnet1 仅主机模式 hostonly 功能:虚拟机只能和宿主机通过vmnet1通信,不可连接其他网络(包括互联网) vmnet8 地址转换模式 NAT 功能:虚拟机可以和宿主通过vmnet8通信,并且可以连接其他网络,但是…

docker环境和dockerfile制作

docker 一、环境和安装 1、 docker安装 使用 root 权限登录 CentOS。确保 yum 包更新到最新sudo yum update卸载旧版本yum remove docker \docker-client \docker-client-latest \docker-common \docker-latest \docker-latest-logrotate \docker-logrotate \docker-selinux …

[luogu12542] [APIO2025] 排列游戏 - 交互 - 博弈 - 分类讨论 - 构造

传送门:https://www.luogu.com.cn/problem/P12542 题目大意:给定一个长为 n n n 的排列和一张 m m m 个点 e e e 条边的简单连通图。每次你可以在图上每个点设置一个 0 ∼ n − 1 0\sim n-1 0∼n−1、两两不同的权值发给交互库,交互库会…

智能体agent概述

智能体概述 智能体是一个能够感知环境并在环境中自主行动以实现特定目标的系统。它具有以下几个关键特征: 自主性 - 智能体可以在没有直接人为干预的情况下运作,能够自行决策和行动。 响应性 - 能够感知环境并对环境变化做出及时响应。 主动性 - 不仅…

2:OpenCV—加载显示图像

加载和显示图像 从文件和显示加载图像 在本节中&#xff0c;我将向您展示如何使用 OpenCV 库函数从文件加载图像并在窗口中显示图像。 首先&#xff0c;打开C IDE并创建一个新项目。然后&#xff0c;必须为 OpenCV 配置新项目。 #include <iostream> #include <ope…

python训练 60天挑战-day31

知识点回顾 规范的文件命名规范的文件夹管理机器学习项目的拆分编码格式和类型注解 昨天我们已经介绍了如何在不同的文件中&#xff0c;导入其他目录的文件&#xff0c;核心在于了解导入方式和python解释器检索目录的方式。 搞清楚了这些&#xff0c;那我们就可以来看看&#x…

构建自动收集并总结互联网热门话题的网站

构建自动收集并总结互联网热门话题的网站的具体方案&#xff1a; 一、系统架构设计 数据采集层 • 使用Python的Scrapy或BeautifulSoup抓取新闻网站/社交媒体API # 示例&#xff1a;微博热点爬虫 import requests def fetch_weibo_hot():url "https://weibo.com/ajax/st…

pycharm无需科学上网工具下载插件的解决方案

以下是两种无需科学上网即可下载 PyCharm 插件的解决思路&#xff1a; 方法 1&#xff1a;设置 PyCharm 代理 打开 PyCharm选择菜单&#xff1a;File → Settings → Appearance & Behavior → System Settings → HTTP Proxy在代理设置中进行如下配置&#xff1a; 代理地…

机器学习自然语言处理

在自然语言处理&#xff08;NLP&#xff09;领域&#xff0c;词向量&#xff08;Word Embedding&#xff09;是将人类语言转化为计算机可理解形式的关键技术。它通过数学空间中的向量表示&#xff0c;捕捉词语的语义和语法信息&#xff0c;有效解决了传统离散表示的 “维数灾难…

如何自学FPGA设计?

众所周知&#xff0c;FPGA设计自学难度不小&#xff0c;更不存在速成的捷径。这里简单说一下学习的规划&#xff0c;希望能给入门者提供一些方向。 学会相应的知识 不论是科班毕业还是理工科专业出身&#xff0c;想要入行FPGA开发&#xff0c;基础知识必须扎实。尤其是在高校…

南航无人机大规模户外环境视觉导航框架!SM-CERL:基于语义地图与认知逃逸强化学习的无人机户外视觉导航

作者&#xff1a; Shijin Zhao, Fuhui Zhou, Qihui Wu单位&#xff1a;南京航空航天大学电子信息工程学院论文标题&#xff1a; UAV Visual Navigation in the Large-Scale Outdoor Environment: A Semantic Map-Based Cognitive Escape Reinforcement Learning Method论文链接…

Linux-进程间通信

1.进程间通信介绍 1.1通信目的 数据传输&#xff1a;⼀个进程需要将它的数据发送给另⼀个进程 资源共享&#xff1a;多个进程之间共享同样的资源。 通知事件&#xff1a;⼀个进程需要向另⼀个或⼀组进程发送消息&#xff0c;通知它&#xff08;它们&#xff09;发⽣了某种事…

精益数据分析(69/126):最小可行化产品(MVP)的设计、验证与数据驱动迭代

精益数据分析&#xff08;69/126&#xff09;&#xff1a;最小可行化产品&#xff08;MVP&#xff09;的设计、验证与数据驱动迭代 在创业旅程中&#xff0c;从需求洞察到产品落地的关键一跃是打造最小可行化产品&#xff08;MVP&#xff09;。今天&#xff0c;我们结合《精益…

从JavaScript快速上手Python:关键差异与核心技巧

引言 如果你是JavaScript开发者&#xff0c;可能会对Python的简洁语法和丰富的生态感兴趣。但两种语言的设计哲学和实现细节存在显著差异。本文将通过对比JS与Python的核心概念&#xff0c;帮助你快速过渡&#xff0c;避免“踩坑”。 一、语法差异&#xff1a;告别大括号&#…

TransmittableThreadLocal实现上下文传递-笔记

1.TransmittableThreadLocal简介 com.alibaba.ttl.TransmittableThreadLocal&#xff08;简称 TTL&#xff09;是阿里巴巴开源的一个工具类&#xff0c;旨在解决 ThreadLocal 在线程池中无法传递上下文变量 的问题。它是对 InheritableThreadLocal 的增强&#xff0c;尤其适用…