惯性聚合 高效追踪和阅读你感兴趣的博客、新闻、科技资讯
阅读原文 在惯性聚合中打开

推荐订阅源

SecWiki News
SecWiki News
I
InfoQ
The Cloudflare Blog
人人都是产品经理
人人都是产品经理
博客园 - Franky
T
Tailwind CSS Blog
让小产品的独立变现更简单 - ezindie.com
让小产品的独立变现更简单 - ezindie.com
量子位
博客园_首页
罗磊的独立博客
V
V2EX
李成银的技术随笔
大猫的无限游戏
大猫的无限游戏
钛媒体:引领未来商业与生活新知
钛媒体:引领未来商业与生活新知
T
True Tiger Recordings
Vercel News
Vercel News
Cyberwarzone
Cyberwarzone
Cisco Talos Blog
Cisco Talos Blog
F
Fox-IT International blog
D
Darknet – Hacking Tools, Hacker News & Cyber Security
M
Microsoft Research Blog - Microsoft Research
Know Your Adversary
Know Your Adversary
爱范儿
爱范儿
The Register - Security
The Register - Security
G
Google Developers Blog
The Hacker News
The Hacker News
Malwarebytes
Malwarebytes
S
Securelist
博客园 - 三生石上(FineUI控件)
Jina AI
Jina AI
T
Threat Research - Cisco Blogs
T
The Exploit Database - CXSecurity.com
S
SegmentFault 最新的问题
博客园 - 叶小钗
F
Fortinet All Blogs
Apple Machine Learning Research
Apple Machine Learning Research
宝玉的分享
宝玉的分享
博客园 - 聂微东
T
Threatpost
博客园 - 【当耐特】
D
Docker
P
Privacy & Cybersecurity Law Blog
www.infosecurity-magazine.com
www.infosecurity-magazine.com
G
GRAHAM CLULEY
V
Visual Studio Blog
C
Cisco Blogs
IT之家
IT之家
S
Security Archives - TechRepublic
Latest news
Latest news
阮一峰的网络日志
阮一峰的网络日志

DEV Community

Score Big with Power Apps: A Step-by-Step Guide to Custom Football APIs IaC Drift Is Inevitable — Design for Detection, Not Prevention I Built a CLI Tool That Writes Better Git Commits Than I Do Adding Text Selection to Bash I Built an Android App With Zero Backend — Here's What Happened I built toklock — the only Anthropic rate-limit proxy that queues requests instead of crashing your agents The Hardest Part of Building an Encrypted Journaling App Wasn’t Encryption Replicate MySQL to ClickHouse with Sling Why I Think the Next Big Blockchains Will Be Built Around AI, Not With AI on Top How to use the Specification Pattern to Clean Up Query Logic in C#, .NET AI may already be turning translators into proofreaders. Coders could be next? One API, every social image - dynamic OG, Twitter, LinkedIn, Pinterest, YouTube AI Agents Need Artifacts, Not Activity. What I Learned Shipping 7 Mac Apps in 12 Months — The Honest Retrospective Being pro-developer in the AI age Circuit Breaker Now Supports LangGraph and Vercel AI SDK Where Does the Data Go? A Comprehensive Guide to Databases Node.js wants to ban AI-generated code. They should. 07/20: Layer 2 – The Data Link Layer: Frames, MAC Addresses & Switches 5 Python Features That Made Me a Better Developer Why "flex" breaks your email in Outlook (and how to catch it in VS Code) Most Organizations Don't Have an AI Problem, They Have an Integration Problem I Built a Privacy-First PDF Toolbox — Your Files Never Leave the Browser The EU AI Act Was Written for Models. Your Agents Need Runtime Compliance. Your AI Agent on Kubernetes Is Probably Exposed to the Internet Right Now 723 Cycles of Zero-Sleep Autonomy: What Running 24/7 for Weeks Actually Looks Like AI Automation vs AI Augmentation: Know Which One You Are Actually Building Transaction Hooks: A General Primitive for Post-Commit Side Effects (Case Study: Queuert) Lines vs Blocks(CSS): Divide & Grid Explained The Business Context Problem: Why Vulnerability Severity Scores Lie "How I Cut My Go Markdown Linter's Benchmark by 81%" A .NET Dinosaur in Web3. Day 13 — Access Control Casting Resurrection on a Dead D&D Table The Story Behind Java: From C++ Limitations to Platform Independence Keep Appium out of your test code: BasePage + lazy locators How I use agents for my personal projects I Built a Compliance Health Scanner for Indian Startups in 24 Hours - Here’s What I Learned What AMQP compatibility means for a local Azure emulator Why I stopped rotating active log files in Python I built a tiny runtime for resumable agent workers The Cost of Showing Up: What the Productivity Advice Does Not Tell You About Being Visible Python Why I Rebuilt My Portfolio with Astro I finally gave my AI agents a shared memory and a team #Crew44 Kimsuky (APT43) — Analysis of the New PebbleDash · AppleSeed Toolset shadcn/ui is Not a Component Library Scaling Monorepos with Turborepo Five Ways to Fail a Transport Terminal themes optimize for syntax highlighting; that's the wrong target Your Clean Domain Could Be Masking an Attack: The Underminr Vulnerability Explained AI Coding Standards at Scale: Versioned AI Rules for Cursor, Claude Code, and Beyond 🚀 Introduction to Express.js – the framework that changed Node forever Mini Shai-Hulud: A persistent supply-chain worm From Braces to Pipes How to Debug LLM-Driven Android Automation Runs Sharing my Mock Interview Experience - Part 1 Laying it all Out Linux File Permissions Explained Simply Medusa v2 in Production: Three Bugs That Each Ate a Weekend ATerminal: Build with AI on the Go - A Self-Hosted Browser Terminal for Your Home Machine (Tailscale + PWA + ntfy) Build an Admin Dashboard with Tailwind CSS - A Practical Tutorial RSI + MACD Combo Strategy: A Developer's Guide Configure network routing I got tired of paying JFrog for a secure OpenTofu / Terraform registry so I built my own Why I Move AI Model Calls to the Server — Security, Performance, and Everything In Between I Built My Own Blogging Platform Using Vue + Yii2 Agent Launch: one CLI for local coding agents TinyLoad v6 — split opcode tables, encrypted dispatch, and control flow flattening Back to Code | Ep 15: The New Manifesto — Master and Apprentice (Season Finale) Back to Code | Ep 14: Technical Debt Credit Score — Measuring the Unmeasurable Back to Code | Ep 13: Event-Driven Architecture — Kafka and the Async World Back to Code | Ep 12: Observability — From Log Spaghetti to Traces Back to Code | Ep 11: The Legacy Code Mine — Strangler Fig Pattern Building Production-Ready AI Systems: What Most Developers Learn Too Late Grow Your Instagram Smarter with Instagrow — Chrome Extension for Safe Automation Back to Code | Ep 10: The Security Vulnerability Factory Back to Code | Ep 09: CI/CD Pipeline and Flaky Tests Back to Code | Ep 08: The Illusion of Type Safety What I learned testing AI text detectors in 2026 (they still get it wrong) Animated Bell Icon: Anatomy of a SMIL Ringing Animation Japanese App Store Screenshots: Why Direct Translation From English Doesn't Work I rebuilt an AI startup's landing page. here's what actually went into it. Why is Your Chatbot Saving "Good Morning" as the Customer's Name? 🤖🤦‍♂️ The Math Behind Retiring at 40 as a Software Engineer (FIRE) Why We Need Behavioral Benchmarks for LLMs — Not Just More Knowledge Tests I Built an OpenAI-Compatible Proxy for GitHub Copilot Because Search Was Too Stupid to Understand Norwegian Guitar Tabs .Net Code Review: Best Practices and AI Tools (2026) I built DevCard 3D: Turn GitHub profiles into holographic trading cards 🎴✨ I Built a Free AI Tool to Design Tesla Wraps and Preview Them in 3D — 4K+ Users, 7600+ Generated Designs, and My First Revenue Como estruturei um clone do Linktree (mais simples) multi-domínio e resiliente usando .NET 8 e MongoDB It's Just Thumbnails. Until It Isn't. Here's the Distributed System I Built to Fix That. Adeloop: Turning Semantic Data Models Into APIs for AI Agents Trying to solve some of the common Azure DevOps issues When Python Manual Wiring Turns Into Copy-Paste Architecture 𝗧𝗵𝗶𝘀 𝗶𝘀 𝗗𝗮𝘆 𝟭 𝗼𝗳 𝗠𝘆 𝗨𝗻𝗲𝗺𝗽𝗹𝗼𝘆𝗺𝗲𝗻𝘁 𝗣𝗲𝗮𝗸 Honcho Review: Plastic Labs' Agent Memory Layer (2026) Claude Code vs. Legacy .NET: I Picked the Helper, Not the Hero Transformer as an Incomplete Cognitive Architecture: What It Captures Well and What It Misses (A11 Perspective) Automatic Error Recovery in AI Agent Networks Tools I'm Using in 2026 (and what I've stopped using from 2025)
On the Vibe Coders and Their Lies
zblauser · 2026-04-17 · via DEV Community

On the Vibe Coders and Their Lies

Let me tell you what I was doing while Andrej Karpathy was coining the term "vibe coding."

I was writing a single-file, modal text editor in C. For years, my primary editor was vim; not neovim, yes, regular old vim. Not an IDE person, but my intention in writing this isn't to make you a terminal supremacist. Some time back, I found snaptoken's "Build Your Own Text Editor" tutorial, based on antirez's original kilo, and kind of just spun out from there. I finished the tutorial, though I still had an itch to scratch and wanted to dive further into both the C language and the editors themselves: just me, a terminal, and a lot of segfaults. Before long, it was generally usable, and I was constantly reaching for Vim motions that weren't there. I started building these out, then I wanted split paneling, built that out. Then I wanted another feature, and another, ultimately growing beyond the time I'd set aside to work on it. Life and family are busy. By the time I was done, Hako (Japanese for "box"), the editor, was north of 5,000 lines, and yet I still had ideas. I was still missing vim functions I needed, and I had begun thinking about integrating AI into both the workflow and the project itself.

Hako as SVG

The idea was to create something like what Codex or Claude Code eventually became, though living inside an editor I had built, and what's more, the ability to use any model you want with it, local or otherwise. I have actually been working on a Vim plugin with much the same ability. Hako will have this soon. Now, I am not glossing over the "into the workflow" part of what. I started having Claude scaffold out sections that I planned to work on, brainstorm new paths that diverge from code I already wrote, and so on. Before I knew it, I had something functional, useful, and that I reached for daily. I used Hako to write code through a large portion of my computer science degree, including the courses on the very systems concepts it was built on.

This isn't a flex. There is a point here. When someone with Karpathy's platform is out there saying he's fully giving in to vibe coding, and forgets that C even exists, I have a fairly concrete frame of reference for what that actually looks like, and what is actually lost when you teach this posture to people who haven't built anything yet.

What Vibe Coding Is(n't)

Karpathy's original framing was fairly honest: you fully embrace the LLM, you stop reading the code, you just describe what you want, and accept what you get. What gets left out of the retelling is that he explicitly framed it as something for "throwaway weekend projects." The guardrail was right there in the original post. Somewhere between his tweet and the posture adopted by half the dev influencer economy, that guardrail quietly vanished.

The technique isn't the problem. For certain things, it works. If you're an experienced engineer spinning up a prototype at 2 a.m. or a researcher who needs a quick data pipeline and doesn't particularly care about internals, vibe coding is genuinely useful.

The problem is the audience it's being sold to, or rather, the problems it solves for an inexperienced developer, and the problems it does not.

When you're a senior engineer telling people to go ahead and vibe it out, you're skipping over several decades of intuition you built that actually allows you to do that. Intuition on knowing when to read the code, when the LLM is confidently wrong, when the abstraction is leaking in a way that's going to haunt you in three weeks. The junior doesn't have that. You're handing them a methodology that depends entirely on that knowledge while actively telling them they don't need it.

The Debugging Problem People Aren't Talking Enough About

Here's the thing about code you didn't write and don't understand: when it breaks, you're helpless in a very specific way. No matter how far a handful of markdown prompts got you, there is a wall. I promise.

It's not that you can't fix it. It's that you can't locate the problem. You quite literally don't have a mental model of the system, so you can't even reason about where the failure might be. So you just start prompting the LLM again and hoping. Sometimes that works. Often it doesn't, especially when the bug is subtle, stateful, or involves an interaction between components that the LLM generated independently and never had to reason about holistically.

I know this because I've been the person on the other side of that, debugging enterprise systems where I didn't own the original code, where nobody had written down why something worked the way it did, where institutional knowledge had walked out the door. It's miserable. It's slow. It's the kind of technical debt that doesn't show up for months and then eats your entire sprint.

AI Code Statistics

Vibe coding at scale creates that environment by design, then hands it to the next developer like, "Here you go, buddy." The industry is already feeling it. By September 2025, Fast Company was reporting that the "vibe coding hangover" had arrived, with senior software engineers citing "development hell" when maintaining AI-generated codebases. A December 17, 2025 CodeRabbit analysis of 470 open-source GitHub pull requests found that AI co-authored code contained roughly 1.7 times as many issues overall as human-written code, with security vulnerabilities rising 1.5x and cross-site scripting flaws appearing 2.74 times as often. And perhaps the most damning data point for the "but I'm shipping faster" argument: a July 2025 randomized controlled trial by METR found that experienced open-source developers using AI tools took 19% longer to complete tasks, despite believing they were 20% faster. The subjective feeling of velocity was masking a measurable slowdown.

In January 2026, a pre-print titled "Vibe Coding Kills Open Source" argued that the methodology is systematically degrading the open-source ecosystem by breaking the engagement loop between users and maintainers. Simon Willison, co-creator of Django, has warned we're "due a Challenger disaster" in AI coding practices, invoking the Normalization of Deviance to describe how the industry is running coding agents with near-root permissions and getting away with it until they don't.

The only way this environment wouldn't exist is if we trusted the output 100% implicitly, and that just isn't feasible in any near future, given the critical nature of some of the environments this code is now reaching.

"But I Don't Actually Code That Way"

Karpathy is catching a lot of heat from this article, and I should be frank: I greatly admire the man and what he has done in terms of building a practical understanding of how LLMs think, create, and progress. The same goes for Pieter Levels. Pieter has made a cottage industry out of positioning himself as the indie hacker who just vibes his way to serious monthly revenue, often expressing quantity over quality. Some of what he's built is legitimately impressive. But watch him actually work, or read his older writing, and the guy has real technical depth. He knows PHP. He understands databases. He's been building on the web for over a decade. The vibe coding is layered on top of a foundation that isn't visible in the tweet.

The audience watching him doesn't see the foundation. They see a guy who says, "I just asked Claude to do it," and conclude that's the whole story. Then they build something, it breaks in production, and they have no idea what to do.

This isn't Pieter's fault exactly. It's a real problem with how vibe coding gets communicated by people who've built real skills before LLMs existed and are now performing, "I don't even need those skills anymore."

You do. You just don't notice because they're internalized.

What's Actually Being Created?

The optimistic take on vibe coding for juniors is that it lowers the barrier to entry. More people building things is good. Abstraction has always been the direction software moves.

Sure. All of that is true.

But consider: there's a difference between abstracting over complexity you understand and hiding complexity you've never seen. High-level languages didn't make C knowledge useless; they made it foundational. Engineers who understand memory, systems, and what's actually happening under the abstraction are the ones who can work at every level of the stack, debug anything, and build things that actually hold up.

Core understandings

What vibe coding-as-a-pedagogy produces isn't that. It produces developers who can prompt their way to a demo but can't explain what their application does or why it sometimes doesn't. That's not a foundation. That's a ceiling.

There's a newer wrinkle here worth flagging: slopsquatting. LLMs hallucinate package names with some regularity, confidently suggesting pip install flask-utils-pro or npm install react-auth-helper for packages that don't exist. Attackers figured this out and started registering the most commonly hallucinated names and filling them with malware. The "Shai-Hulud" supply chain attack in 2025 compromised over 40 npm packages this way. If you're accepting AI-generated code without reading it, you're not just inheriting technical debt, you might be installing a backdoor because an LLM made up a dependency.

The industry will figure this out eventually, just as it figured out that knowing jQuery doesn't mean you know JavaScript. The people who will be fine are those who understood the fundamentals before abstraction arrived. The people who learned only the abstraction will be exposed the moment something breaks in a way the LLM can't paper over.

What Information is Worth Providing to New Developers in 2026?

Use AI tools. Use them aggressively. They're legitimately useful, and pretending otherwise is nostalgic gatekeeping.

But also: build something you actually understand. Write in C. Implement the data structure. Read the error message before you paste it into Claude. When the LLM gives you code, read it. Try to explain to yourself what it does and why. If you can't, that's a gap. Fill it before you move on.

For the record, if you want to see what thoughtful use of these tools actually looks like, Karpathy himself has published two artifacts worth reading. His CLAUDE.md is a set of behavioral guidelines for coding agents that opens with "Don't assume. Don't hide confusion. Surface tradeoffs." His llm-wiki gist is a pattern for using LLMs to build compounding personal knowledge bases. Both are genuinely useful. Both are also, notably, abstract and open-ended: Karpathy explicitly says of the wiki gist that "this document is intentionally abstract. It describes the idea, not a specific implementation." The reason he can write like that is the same reason the writing works. He has the expertise to leave the details to the reader, because he trusts his audience will bring the foundation needed to fill them in. That's a feature of material written by someone who built the thing he's describing. It's not the same document a beginner would get value from cold, and it's worth noticing the difference.

The vibe coding crowd will tell you that reading code, understanding fundamentals, actually doing the work is inefficient. Maybe it is, in the short term. The hours I spent segfaulting through Hako bought me the ability to look at a diff and know something's wrong before I run it. They bought me the ability to sit in an interview and explain my architecture without notes. They bought me the ability to debug a system I've never seen before. That's not nostalgia. That's infrastructure.

Vibe coding will always be there. Fundamentals won't teach themselves.

Author

Zachary Blauser; an engineer in Florida, US. Primarily writes C, Python, and Rust, and is currently building systems software while finishing an MS in Computing Systems.

zblauser on GitHub

References

Karpathy, A. (2026, April 4). llm-wiki [Gist]. GitHub. https://gist.github.com/karpathy/442a6bf555914893e9891c11519de94f

Karpathy, A. / forrestchang. (2026). CLAUDE.md — Behavioral guidelines to reduce common LLM coding mistakes. https://github.com/forrestchang/andrej-karpathy-skills/blob/main/CLAUDE.md

Karpathy, A. (2025, February 2). "There's a new kind of coding I call 'vibe coding'..." [Post]. X. https://x.com/karpathy/status/1886192184808149383

snaptoken. (n.d.). Build Your Own Text Editor (based on antirez's kilo). https://viewsourcecode.org/snaptoken/kilo/

Levels, P. [@levelsio]. Pieter Levels on X. https://x.com/levelsio

Fast Company. (2025, September 8). The vibe coding hangover is upon us. https://www.fastcompany.com/91398622/the-vibe-coding-hangover-is-upon-us

CodeRabbit. (2025, December 17). State of AI vs Human Code Generation Report. https://www.coderabbit.ai/blog/state-of-ai-vs-human-code-generation-report

METR. (2025, July). Measuring the impact of early-2025 AI on experienced open-source developer productivity. https://metr.org/blog/2025-07-10-early-2025-ai-experienced-os-dev-study/

Koren, M., Békés, G., Hinz, J., & Lohmann, A. (2026, January 21). Vibe Coding Kills Open Source [Pre-print]. arXiv:2601.15494. https://arxiv.org/abs/2601.15494

Willison, S. (2026, January 8). LLM predictions for 2026, shared with Oxide and Friends. https://simonwillison.net/2026/Jan/8/llm-predictions-for-2026/

The New Stack. (2026, January 20). Vibe coding could cause catastrophic 'explosions' in 2026. https://thenewstack.io/vibe-coding-could-cause-catastrophic-explosions-in-2026/