软件代码设计零碎杂想-2

想到一个极端的例子,主要是想说如何提取变化的东西和设计的取舍。

先看一个题目:考试分数为百分制,请将给定的分数进行分类,分类规则是

[0,60)    不及格

[60,70)    合格

[70,80)    良好

[80,90)    优秀

[90,100]   杰出

嗯,题目简单,做法也很简单,如下,简便起见,假设分数为整形:

char* get_result(int x)

{

    if ( x < 60 ) return "..";

    else if ( x < 70 ) return "...";

    else if ( x < 80 ) return "....";

    else if ( x < 90 ) return ".....";

    else return "....."

}

以这个简单的例子,说明一下抽象的思想。一个规律,凡是用到了if else 的地方,就有抽象可以派上用场。我来过度设计一下,变成这样的:

struct score

{

    virtual char* result()=0;

};

 

struct score_bad : public score

{

     char* result(){ return "bad";}

};

struct score_yes : public score

{

     char* result(){ return "yes";}

};

....

 

score* get_score(int x)

{

    if( x< 60 ) return new score_bad;

    else ( x< 70 ) return new score_yes;

    ...

}

 

char* get_result(int x)

{

    score* s = get_score( x );

    return s->result();   

}

有的人说,有的时候,用if只是简单判断下参数是否正确而已,可以像上面进行抽象么?如:

int abc::get_xyz(int x)

{

 if ( x < 0 ) return -1;

 set(x);

draw(x);

y=x+1;

return 0;

}

 

当然可以过度设计一把。

struct doer

     virtual int  do()=0;

};

struct error : public doer

{

int x;

error(int _x) : x(_x){}

int do(){return -1;}

};

 

struct yes:public doer

{

int x;

abc* a;

yes(int _x,abc* _a):x(_x),a(_a){}

int do()

{

a->set(x);

a->draw(x);

a->y=x+1;

return 0;

}

};

 

int abc::get_xyz(int x)

{

    doer* d = x < 0 ? new error(x) : new yes(x,this);

    return d->do();

}

嗯,这里好像用上了一个简单工厂模式,根据输入的参数不同,返回不同的产品。这里都把产品抽象了一下。虽然过度设计的厉害,但是实际上思想都差不多的。

 

阅读终点,创作起航,您可以撰写心得或摘录文章要点写篇博文。去创作
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 1
    评论
使用display: flex可以实现垂直水平居中。首先,将容器的display属性设置为flex,然后通过align-items和justify-content属性来控制子元素的对齐方式。设置align-items为center可以实现垂直居中,设置justify-content为center可以实现水平居中。以下是代码示例: ```css .container { display: flex; align-items: center; justify-content: center; /* 其他样式属性 */ } .child { /* 子元素的样式属性 */ } ``` 其中,container是父容器的类名,child是子元素的类名。通过这种方式,父容器中的子元素就可以实现垂直水平居中了。<span class="em">1</span><span class="em">2</span><span class="em">3</span> #### 引用[.reference_title] - *1* [css垂直水平居中的详细实现方式(6种)](https://blog.csdn.net/weixin_46591819/article/details/129161551)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v92^chatsearchT3_1"}}] [.reference_item style="max-width: 50%"] - *2* *3* [CSS垂直水平居中,display:flex,布局,文字属性的一些零碎](https://blog.csdn.net/github_36487770/article/details/70234349)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v92^chatsearchT3_1"}}] [.reference_item style="max-width: 50%"] [ .reference_list ]

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

辉歌

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值