2014年8月25日,收藏家和杀手——面向对象的C++和C(一)
更通俗来说。就像打架,C++给我们了非常多武器。太多的选择和矛盾组合让我们无所适从,可以使用好这么多武器须要成年累月的经验,而商业项目就是最快最准的打倒对方,才无论你用啥。
想想看,当我拥有匕首、手枪、机关枪、火箭炮……时,我非常可能会忘了我的目的是打到对方,而当起了武器收藏家;但当我仅仅有匕首在手的时候呢?或许对方真正要倒霉了——我非常可能是个抱着誓死决心的杀手。
C++中有class(或者struct)这么一个keyword能够把数据和关联的方法封装成一个类。那么C语言呢?C语言的struct事实上也能够把数据和关联的方法封装在一起。
或许非常多人说。你骗人。C语言的struct中仅仅能放成员变量,不能放成员方法。或许你忘了还有函数指针这么一个东西,这个东西的存在,能够把方法像变量一样的放在C语言的struct中。例如以下(下面三个代码文件在Mac
OS X的XCode上完毕):
//
// person.h
// cthinking
//
// Created by Rafael Gu on 14-8-25.
// Copyright (c) 2014年 Rafael Gu. All rights reserved.
//
#ifndef _PERSON_H_
#define _PERSON_H_
struct person;
typedef unsigned char (*GET_AGE)(struct person *this);
typedef void (*SET_AGE)(struct person *this, unsigned char age);
// all public members
struct person {
];
GET_AGE get_age;
SET_AGE set_age;
};
struct person *person_create();
void person_destroy(struct person *p);
#endif // _PERSON_H_
//
// person.c
// cthinking
//
// Created by Rafael Gu on 14-8-25.
// Copyright (c) 2014年 Rafael Gu. All rights reserved.
//
#include "person.h"
#include <stdlib.h>
// all private members
struct _person {
unsigned char age;
};
static unsigned char _get_age(struct person *this)
{
struct _person *p = (struct _person *)(this
+ );
return p->age;
}
static void _set_age(struct person *this, unsigned char age)
{
struct _person *p = (struct _person *)(this
+ );
p->age = age;
}
struct person *person_create() {
struct person *p = (struct person *)malloc(sizeof(struct person)
+ sizeof(struct _person));
p->get_age = _get_age;
p->set_age = _set_age;
return p;
}
void person_destroy(struct person *p) {
free(p);
}
//
// main.c
// cthinking
//
// Created by Rafael Gu on 14-8-25.
// Copyright (c) 2014年 Rafael Gu. All rights reserved.
//
#include <stdio.h>
#include <string.h>
#include "person.h"
int main(int argc, const char *
argv[]) {
struct person *this = person_create();
, );
);
this->);
printf("%s's age is: %u\n", this->name, this->get_age(this));
person_destroy(this);
;
}
当然这里仅仅实现了private和public,没有protected。
- 继承——你看上面的person和_person的struct变体偏移就知道怎样组合不同结构体实现继承了。
- 重载、虚函数——你看上面的函数指针在“构造”函数才被指定。那么你应该明确怎样实现重载和虚函数了。
我的项目是基于上面代码的对象方式写得。假设全然实现C++或者Java的全部面向对象特性。也不太有用。
2014年8月25日,收藏家和杀手——面向对象的C++和C(一)的更多相关文章
- 09.25日记(2014年9月25日23:22:06)用java这么多年面向对象我真的懂了吗,测试先行理念会玩吗
二胡 (1)应该找些书来看看,工作N年并不代表就有N年的工作经验. (2)DiaTransit02,DiaDept02,DiaAirport02,DiaHighway02.都具有x,y属性为何不设计一 ...
- SE 2014年5月25日
如图配置 两实验 R1模拟总部,R2 与R3模拟分部 实验一 要求使用 IPSec VPN 主模式,使得总部与两分部内网可相互通讯 步骤: 1. 配置默认路由 [RT1]ip route-stat ...
- SE 2014年4月25日
1. 描述 STP 的计算过程 (1.根桥的选举 2.端口角色的确定) 根桥的选举 启用STP后,网络中桥ID最小的交换机会被选为根桥,桥ID由桥优先级和桥MAC两部分组成,优先级默认为32768,首 ...
- 马后炮之12306抢票工具(四)--抢票Demo,2014年1月9日终结版
时隔一年多,终于朋友的忽悠下吧抢票Demo的最后一步完善了,与2014年1月9日成功生成车票. Demo仅经过自己测试,并未在高峰期进行测试,代码质量很差,因为赶工,套用去年模板并未使用设计模式. 代 ...
- 无插件的大模型浏览器Autodesk Viewer开发培训-武汉-2014年8月28日 9:00 – 12:00
武汉附近的同学们有福了,这是全球第一次关于Autodesk viewer的教室培训. :) 你可能已经在各种场合听过或看过Autodesk最新推出的大模型浏览器,这是无需插件的浏览器模型,支持几十种数 ...
- 系列文章:老项目的#iPhone6与iPhone6Plus适配#(持续更新中,更新日期2014年10月12日 星期日 )
本文永久地址为http://www.cnblogs.com/ChenYilong/p/4020399.html ,转载请注明出处. ********************************** ...
- 2016年12月25日 星期日 --出埃及记 Exodus 21:20
2016年12月25日 星期日 --出埃及记 Exodus 21:20 "If a man beats his male or female slave with a rod and the ...
- 转:[置顶] 从头到尾彻底理解KMP(2014年8月22日版)
[置顶] 从头到尾彻底理解KMP(2014年8月22日版)
- SQLSERVER2014 2014年4月1日发布
SQLSERVER2014 2014年4月1日发布 原文地址: http://blogs.technet.com/b/microsoft_blog/archive/2014/03/18/sql-ser ...
随机推荐
- Codeforces Round #412 Div. 2 第一场翻水水
大半夜呆在机房做题,我只感觉智商严重下降,今天我脑子可能不太正常 A. Is it rated? time limit per test 2 seconds memory limit per test ...
- 关于windows系统DPI增大导致字体变大的原因分析
最近再学习WPF开发,其中提到一个特性“分辨率无关性”,主要功能就是实现开发的桌面程序在不同分辨率的电脑上显示时,会根据系统的DPI自动进行UI的缩放,从而不会导致应用程序的失真. 这个里面就提到了个 ...
- 九度oj 题目1374:所有员工年龄排序
题目描述: 公司现在要对所有员工的年龄进行排序,因为公司员工的人数非常多,所以要求排序算法的效率要非常高,你能写出这样的程序吗? 输入: 输入可能包含多个测试样例,对于每个测试案例, 输入的第一行为一 ...
- CSS3box-shadow属性的使用
每次使用box-shadow,都要查阅资料才能实现对应的效果,现在总结一下,方便以后查看. 一.语法: E {box-shadow: inset x-offset y-offset blur-radi ...
- 居然有这种操作?各路公司面试题(作者:马克-to-win)
我喜欢考试,不考试,谁知道哪些掌握了哪些没有?? 面试什么的最有爱了(变态笑)~~~ http://www.mark-to-win.com/JavaBeginner/JavaBeginner4_web ...
- hdu 3501 容斥原理或欧拉函数
Calculation 2 Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 32768/32768 K (Java/Others)Tot ...
- 【HDOJ5971】Wrestling Match(二分图,并查集)
题意:有n个人,m场比赛,x个人为good player,y个人为bad player, 每场比赛两个人分分别为good和bad,问good和bad是否会冲突 1 ≤ N≤ 1000,1 ≤M ≤ 1 ...
- XMPP协议实现原理介绍(转)
XMPP协议简介 XMPP(Extensible Messageing and Presence Protocol:可扩展消息与存在协议)是目前主流的四种IM(IM:instant messagi ...
- 标准C程序设计七---57
Linux应用 编程深入 语言编程 标准C程序设计七---经典C11程序设计 以下内容为阅读: <标准C程序设计>(第7版) 作者 ...
- HDU 5726 GCD(ST&RMQ)
题目链接 GCD 先ST倍增预处理,f[i][j]表示从i开始(包含第i个数)的连续2^j个数的最大公约数. 这样就可以在O(1)内询问得到a[l]到a[r]之间的所有数的最大公约数的值. 然后对于每 ...