news 2026/4/16 12:00:43

C语言对话-29.可怜的bool

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
C语言对话-29.可怜的bool

oversense 翻译

嘿嘿...今天的活比较爽!前几天写了点破程序,今天改改就搞定了。哎,真困!喝点咖啡,靠在我的小椅子上,看看我的代码...

神奇,这是啥?

void f()

{

TextHandler t;

t.sendText("Hello, world", true);

// ...

}

后面那个true是什么东东?翻翻定义:

class TextHandler

{

public:

void sendText( const std::string & msg,

bool sendNewLine );

//...

};

喝点coffee,我想起来了,true表示sendText函数自动加上一个回车换行,我怎么忘了?难道是我笨?我陷入迷茫的沉思...

砰!!!的一声巨响,我一慌张,嘴里的咖啡差点喷出来,还好我嘴紧。一定是Guru合上了她的什么大头书。我转向她,挤出一点微笑。她手里拿着一本不到一百页的小册子。

神奇,这么小的书弄得这么响,她是怎么弄得?显然,她什么都知道了。

"我的宝贝!如果你这么快就忘了参数的含义,那么当其他程序员第一次看你的代码的时候,他怎么明白你要表达的意思呢?"

"嗯,是啊" 我咕噜道 "但是在IDE里面,他只要把鼠标移到函数上,他就可以看到参数说明了啊!"

"有些IDE如此,并非全部,甚至不是大多数!我说过很多次,源代码最主要的用途是用来交流,对意图的交流。我手中这本古老的,令人尊敬的卷册阐述了交流的艺术。在这儿,它写道,'使用明确,详细,具体的语言'[1],你代码中的bool与此无缘,他不能传递任何有用的信息给读者。 "

"不哈,一旦他知道这个bool是什么意思,就很容易记住了哈!"我中气不足的说。Guru用她美丽而坚定的蓝眼睛盯着我,我心里扑通扑通跳起来。

"你多久以前写的这段代码?"Guru很温柔的说道--那种我喜欢的温柔。

"嗯,好,嗯,那如何改正呢?"我巧妙的回避她的问题。

"你不能另外想一种方式去表达你的意图吗?"她也不直接回答我,我们就好像在煎鸡蛋。

"我可以不要第二个参数,让用户自己加 '\n' 好了。"我边说边写:

{

t.sendText("Hello, world\n");

}

"如果传递给sendText是一个变量呢?" Guru问。

"那就这样好了"

{

t.sendText( variable );

t.sendText( "\n" );

}

我抬头看到Guru脸色不善,赶紧说道:"那就这样,我提供两个函数"

void sendText( const std::string & );

void sendTextWithNewLine( const std::string & );

"没有其他的办法了吗?"Guru思考的时候,微微皱眉。

哎,看来我今天不要想轻松溜走了,我一阵猛想......什么也没想出来,我投降了,"就这样吧!"

"关于你的问题,你还要认识一点" Guru写道:

void displayText( const std::string &,

bool applyItalics,

bool applyBold );

void f(){

displayText( "This is bold but not italic",true, false );

}

"如果一个程序员要用斜体显示文字,但是弄错了参数顺序,那么这些文字就要用粗体显示了,而且显然编译器无法发现这个错误。"

"如果Bob拿到了这段代码,改变了参数的顺序,一种叫做'Permute And Baffle'的技术[2]。会怎样?"

"显然,问题多多的displayText不能得到 '明确,详细,具体' 的参数。"

"现在来看你的问题,你的第一个方案,因为displayText需要其他参数而没法用。你的第二个方案,可以工作,但是如果displayText需要很多信息,比如颜色,字体等,你是不是要提供如此多的函数呢?"

"所以,我们可以用enumerated,枚举."

"Enumerations?"我奇怪的说。

"是的,Enumerations在这儿能得到很好的应用,看,"

class TextHandler

{

public:

enum NewLineDisposition { sendNewLine, noNewLine };

void sendText( const std::string &, NewLineDisposition );

};

void f()

{

TextHandler t;

t.sendText( "Hello, ", TextHandler::noNewLine );

t.sendText( "world", TextHandler::sendNewLine );

}

"这种写法很好,这段代码现在self-documenting了,不需要注释,意图和结果都很清楚。看的人不需要去查找函数的定义了。"

"而且,这种写法有很好的扩展性,如果你需要只加一个回车,你只需要在enumeration中加上prependNewLine就可以了,现有的代码无需任何改变。"

"不要抛弃你第一个方案,宝贝。在有的情况下,他是最优的。"Guru转过身,重新打开那本书,优雅而轻快的走开,消失在拐角处。

注解:

[1] William Strunk Jr. and E.B. White. The Elements of Style (MacMillan Publishing Co. Ltd, 1979).

[2] From Roedy Green's "How To Write Unmaintainable Code," <http://mindprod.com/unmaindesign.html>. (Primarily aimed at Java programmers, it still has lots of relevance for C++ programmers.)

版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/4/6 4:43:30

LeafView v4.0.2 绿色版 | 电脑轻量图片查看器

LeafView v4.0.2 绿色版是一款高实用性的电脑轻量图片浏览工具&#xff0c;凭借界面简洁、加载高效、低耗兼容的核心优势&#xff0c;成为日常图片浏览与简单编辑的优质选择。该工具无需复杂安装&#xff0c;跨平台适配且支持多种主流图片格式&#xff0c;能全方位满足用户各类…

作者头像 李华
网站建设 2026/4/16 11:58:34

首次,蔚来真盈利了......

点击下方卡片&#xff0c;关注“自动驾驶之心”公众号 戳我-> 领取自动驾驶近30个方向学习路线 编辑 | 自动驾驶之心 本文只做学术分享&#xff0c;如有侵权&#xff0c;联系删文 >>自动驾驶前沿信息获取→自动驾驶之心知识星球 首次&#xff01;蔚来实现单季度盈利了…

作者头像 李华
网站建设 2026/4/15 22:51:38

多模态驱动下,Java企业的AI应用开发新路径

在数字化转型的深水区&#xff0c;AI技术正从单一的文本交互&#xff0c;走向文本、语音、图像、视频融合的多模态时代。对于以Java技术栈为核心的企业而言&#xff0c;传统系统往往局限于结构化数据处理&#xff0c;面对日益增长的多模态业务需求——如客服场景的图片投诉识别…

作者头像 李华
网站建设 2026/4/11 21:29:06

深入了解500kW储能变流器(PCS):从结构到资料的全解析

500kW储能变流器&#xff08;PCS&#xff09; 采用T型三电平模块&#xff0c;结构三维、控制电路、驱动电路&#xff0c;全部的BOM&#xff0c;型式试验报告等全部资料。 没有程序源码&#xff0c;本商品交付的资料与本描述一致&#xff0c;未提及的可能没有。在储能领域&#…

作者头像 李华
网站建设 2026/4/13 20:23:27

阿里减持三江购物:套现2.5亿

雷递网 乐天 2月5日三江购物俱乐部股份有限公司&#xff08;证券代码&#xff1a;601116 证券简称&#xff1a;三江购物&#xff09;日前发布公告称&#xff0c;阿里在2025年11月27日到2026年2月5日通过集中竞价减持5,476,784股&#xff0c;通过大宗交易减持10,953,568股。阿里…

作者头像 李华