还记得搞怪的hold住姐Miss Lin么,对于人们常规的行为,Miss Lin会挑起夸张的眉毛说:"Oh my God, it's not fashion!"。如果程序员圈子里有位Miss Lin,对于一些功能的实现,她会认为哪些编码实现方法是not fashion的,哪些是fashion的呢?

下面示例中,循规蹈矩先生编码但求功能实现,喜好使用常规方法,hold住姐实现功能的同时,不忘fashion一把。

问题一:事件触发库函数支持三种事件类型:IO事件(包括读/写)、信号和超时事件,请编码定义以上事件类型并说明使用方法。

循规蹈矩先生

1.事件类型定义

#define EV_TIMEOUT 1                  #define EV_READ    2#define EV_WRITE   3#define EV_SIGNAL  4

2.使用方法

有效性判断:

if(ev_events >= EV_TIMEOUT && ev_events <= EV_SIGNAL){……}

根据事件类型进行事件处理:

if(ev_events == EV_READ){……}

No! No! No! it's not fashion!

**Miss Lin**

1.定义事件类型:

#define EV_TIMEOUT 0x01#define EV_READ    0x02  #define EV_WRITE   0x04  #define EV_SIGNAL  0x08 

有效性判断:

if (ev->ev_events & (EV_READ|EV_WRITE|EV_SIGNAL)){……}

根据事件类型进行事件处理:

if (ev->ev_events & EV_READ){……}

Miss Lin语:

Well,well,well.循规蹈矩先生的方法 is very sample,让人一看就明白,but it's not fashion!

假如一个事件既包含“读”,又包含“写”,是否还要添加一个EV_READ_WRITE宏?Think about that!

But 使用我的方法就不一样了,EV_READ|EV_WRITE 即可表示一个读写事件。该方法同样适用于其他事件组合,比如一个限时的读事件可以这样定义:EV_READ|EV_TIMEOUT,so easy!

另外,通过位运算,可以很方便地对事件类型进行操作:

//添加超时类型ev_events |= EV_TIMEOUT;//删除超时类型ev_events &= ~EV_TIMEOUT;

使用bit指示状态,通过位运算操作状态值——要知道,fashion也讲求节约!

问题二:定义链表数据结构并编写相关操作函数。

循规蹈矩先生

//结点结构定义typedef struct _LIST_NODE{     void* pdata;     struct _LIST_NODE* next;}LIST_NODE; //链表结构定义typedef struct _LIST_HEAD{     LIST_NODE* first;}LIST_HEAD;//头部插入结点函数void list_insert_head(LIST_HEAD* head, LIST_NODE* node){    node->next = head->first;    head->first = node;}

No! No! No! it's not fashion!

**Miss Lin**

//链表头定义宏#define SLIST_HEAD(name, type)                      \struct name {                               \    struct type *slh_first; /* first element */         \}//链表元素定义宏#define SLIST_ENTRY(type)                       \struct {                                \    struct type *sle_next;  /* next element */          \}//链表初始化#define SLIST_INIT(head) do {                       \    (head)->slh_first = NULL;                   \} while (/*CONSTCOND*/0)//头部插入结点宏#define SLIST_INSERT_HEAD(head, elm, field) do {            \    (elm)->field.sle_next = (head)->slh_first;          \    (head)->slh_first = (elm);                  \} while (/*CONSTCOND*/0)

Miss Lin语:

Fashion是什么?to be different! 提到宏的使用,很多程序员能列出一堆缺点,比如展开容易出错、不方便调试,但是恰当地使用宏可以带来很多好处,以上方法相比函数的实现,运行效率更高(哪怕只是一点点地提升)。最最关键的一点,it's cool!
以上关于链表的宏定义使用方法如下:

;SLIST_INSERT_HEAD(&slist_head, item, entries);  //在头部插入元素

问题三:编写接口函数,分别实现动态数组和队列插入和删除。

循规蹈矩先生

//list.hstruct _List;typedef struct _List List;//链表接口函数void list_insert(void* thiz, size_t index, void* data);void list_delete(void* thiz, size_t index);

//darray.hstruct _DArray;typedef struct _DArray DArray;//动态数组接口函数void darray_insert(void* thiz, size_t index, void* data);void darray_delete(void* thiz, size_t index);

No! No! No! it's not fashion!

**Miss Lin**

//container.hstruct container{   void (*insert) (void*, size_t index, void* data);  void (*delete) (void*, size_t index);};

//list.hstatic void list_insert(void* thiz, size_t index, void* data);static void list_delete(void* thiz, size_t index);struct container list_container = {list_insert, list_delete};

//darray.hstatic void darray_insert(void* thiz, size_t index, void* data);static void darray_delete(void* thiz, size_t index);struct container darray_container = {darray_insert, darray_delete};

Miss Lin语:

Fashion! Can you see that ?! 增加container结构、利用回调函数,实现了统一的接口,static关键字实现了隐藏,使用方法如下:

struct container* containerp = &list_container;containerp->insert(……);containerp->delete(……);

上文模仿Miss Lin的语气介绍了以下内容:

  1. 使用二进制和位运算定义类型;
  2. 使用宏定义结构和函数;
  3. 使用回调函数提供统一接口。

”循规蹈矩先生”们应向"Miss Lin"学习,学习她追求与众不同的精神。对于编程,除了常规的编码实现方法,我们还应多思考能同样达到目的的方法。通过不断思考与总结,逐渐提高编程技能。

No!No!No! It's not fashion!的更多相关文章

  1. Reporting Service 服务启动时报错The service did not respond to the start or control request in a timely fashion

    案例环境: 启动一台数据库服务器(Windows Server 2003)的Reporting Service(SQL Server 2008 R2)服务时,出现如下错误信息: System.Inva ...

  2. 如何在ExtJS 6中使用Fashion美化应用程序

    在Ext JS 6,一个最大的改变就是框架合并,使用一个单一的代码库,就可以为每一种设备开发各具有良好体验的最好应用程序.它还带来了一种美化应用程序的新方式. 在本文,重点是Sencha Fashio ...

  3. IIS Default Web Site : The service did not response to the start or control request in a timely fashion

    IIS Default Web Site无法启动,提示错误:The service did not response to the start or control request in a time ...

  4. 【翻译】如何在Ext JS 6中使用Fashion美化应用程序

    原文:How to Style Apps with Fashion in Ext JS 6 在Ext JS 6,一个最大的改变就是框架合并,使用一个单一的代码库,就可以为每一种设备开发各具有良好体验的 ...

  5. fashion datasets图像检索实践project

    Using Siamese Networks and Pre-Trained Convolutional Neural Networks (CNNs) for Fashion Similarity M ...

  6. Educational Codeforces Round 14 A. Fashion in Berland 水题

    A. Fashion in Berland 题目连接: http://www.codeforces.com/contest/691/problem/A Description According to ...

  7. 深度学习常用数据集 API(包括 Fashion MNIST)

    基准数据集 深度学习中经常会使用一些基准数据集进行一些测试.其中 MNIST, Cifar 10, cifar100, Fashion-MNIST 数据集常常被人们拿来当作练手的数据集.为了方便,诸如 ...

  8. 时尚与深度学习系列:Fashion forward: Forecasting visual style in fashion

           https://arxiv.org/pdf/1705.06394.pdf         将深度学习与时尚预测联系在一起,是一个很有趣但是估计结果会没什么成效的话题.因为,时尚预测这一领 ...

  9. codeforces 691A A. Fashion in Berland(水题)

    题目链接: A. Fashion in Berland 题意: 思路: AC代码: //#include <bits/stdc++.h> #include <iostream> ...

随机推荐

  1. BZOJ 1001:[BeiJing2006]狼抓兔子(最小割)

    http://www.lydsy.com/JudgeOnline/problem.php?id=1001 题意:中文. 思路:很明显是最小割,转化为最大流做.一开始看那么多点,但还是试了一下,居然过了 ...

  2. Codeforces 758D:Ability To Convert(思维+模拟)

    http://codeforces.com/problemset/problem/758/D 题意:给出一个进制数n,还有一个数k表示在n进制下的值,求将这个数转为十进制最小可以是多少. 思路:模拟着 ...

  3. C++11/14笔记

    目录 语言层面 模板表达式中的空格 nullptr和std::nullptr_t 自动推导类型----auto 一致性初始化----Uniform Initialization 初始化列表(initi ...

  4. 作者联系方式D1

    欢迎大伙投稿,审核通过免费发布. 奥特曼超人 KARL-Dujinyang QQ:  309933706   QQ:  1875125470 工作时间都会在线. 偶尔博客,不过有问题可以加Q来找我讨论 ...

  5. mybatis学习(五)(动态mybatis(多条件查询))

    有时候要查询条件是多条件的,尤其是使用mybatis的时候如何创建sql语句呢? 这里mybatis有自己的办法,如下: 案例:通过传入map,根据map里面的数据来查询 mapper配置如下: &l ...

  6. 字符串翻转demo

    1.利用char数组 public class stringfanzhaun { public static void main(String[] args) { String str="1 ...

  7. Guid几种格式及之间的互换,以及利用Base64缩短guid的长度到22个字符和还原

    1.Guid.NewGuid().ToString("N") 结果为: 38bddf48f43c48588e0d78761eaa1ce6 2.Guid.NewGuid().ToSt ...

  8. koa2服务端使用jwt进行鉴权及路由权限分发

    大体思路 后端书写REST api时,有一些api是非常敏感的,比如获取用户个人信息,查看所有用户列表,修改密码等.如果不对这些api进行保护,那么别人就可以很容易地获取并调用这些 api 进行操作. ...

  9. NameNode故障处理方法

    NameNode故障处理方法 简述 NameNode故障后,可以通过下列两种方式进行恢复数据: 方法一(手动):将SecondaryNameNode文件下的数据复制到NameNode中 方法二(程序) ...

  10. Linux/Ubuntu正确卸载LXDE

    第一步: sudo apt-get remove lxde 第二步 sudo apt autoremove lxde