git 源码学习

Preface 最近趁上一个工作任务刚结束,新的任务还在规划中,难得清闲几天,可以抽点时间来看下 Linus 大神在2005年写的 git,为了简单,理解git 的原理,我们可以 checkout 刚开始的版本 比如hash为 79517a067。 这个版本总代码量只有1491 行。 Compile 依赖包:libssl-dev、zlib 修改编译选项:Makefile中LIBS 增加 -lcrypto 编译完之后会生成可执行文件: update-cache show-diff init-db write-tree read-tree commit-tree cat-file fsck-cache checkout-cache Analysis 1 init-db 初始化工作目录: 在当前路径下创建目录, .dircache └── objects ├── 00 ├── 01 ├── ...(255 dirs) ├── fe └── ff 2 update-cache……

阅读全文

what do you want?

1 你真正想要的是什么?这个问题一直在我身边,挥之不去,甚至在你做一些决策时,还挡在你面前,寸步难行。 摩西奶奶 说:人生只有一次,去做自己喜欢的事。……

阅读全文

Reflection in protobuf (C++/Java)

最近工作中,需要做一些消息动态解析,因为使用的 protobuf,考虑使用protobuf的反射特性。 1 reflection in C++ 在c++中使用protobuf 反射 1 2 3 4 5 6 7 8 9 10 11 package com.sunquan; message Login { optional int64 userid = 1; optional string username = 2; // name optional string password = 3; // passwd optional string email = 4; optional string nickname = 5; // etc ... } C++和Java 不同的是: c++有一个全局的pool,管理了所有定义在 proto 文件里的消息原型, 我们可以通过消息全称,查找到对应的单例的消息原型,然后通过原型构造可变的消息。 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 /** * 通过消息名称, 获取构造该类型的默认(原型)。 然后你可以……

阅读全文

异步编程之 CPS

1 Preface 后继传递风格(continuation-passing style CPS wiki) 具体解释请阅读wiki。 CPS 最初在1970年代作为一种编程风格出现,主要用于函数式编程; 在1980年代到1990年代期间,其作为高级编程语言的编译器的一种中间表达形式开始崭露头角。 现在,CPS作为非阻塞系统(通常是分布式)的一种编程风格被再次发掘出来。 1.1 CPS in Haskell 我们使用Haskell 实现勾股定理(Pythagorean theorem) 计算斜边的长度。 传统的实现如下: 1 2 3 4 5 6 7 8 square :: Double -> Double square x = x * x add :: Double -> Double -> Double add x y = x + y pythagorean :: Double -> Double -> Double pythagorean x y……

阅读全文

C++ RAII

什么是RAII ? RAII即“Resource Acquisition Is Initialization”,也称为“资源获取即初始化”。是C++语言的一种管理资源、避免泄漏的惯用法。利用的就是C++构造的对象最终会被销毁的原则。 RAII的做法是使用一个对象,在其构造时获取对应的资源,在对象生命期内控制对资源的访问,使之始终保持有效,最后在对象析构的时候,释放构造时获取的资源。……

阅读全文

2018 年会-Plan

plan 1 如果你是CEO或 CTO, 2018你想做什么? 说出你有创意的idea, 可以异想天开。 平行世界,未来已来。 区块链,比特币 1 我们现在在做的 ems2.0 Al 日常运维。 正准备做的 ems3.0 seastar dpdk coroutine… 我想做 : 理财平台 智能投顾 大数据 语言的技巧很重要,很多时候用言语表达出来的都是浅薄的,很多时候说的多反而起不到好的效果。 通过这一次年会,我也发现了一些我不喜欢的……

阅读全文

2018年会

2018-03-09 记于十三陵 1 如果你是CEO或 CTO, 2018你想做什么? 说出你有创意的idea, 可以异想天开。 平行世界,未来已来。 区块链,比特币 1 我们现在在做的 ems2.0 Al 日常运维。 正准备做的 ems3.0 seastar dpdk coroutine… 我想做 : 理财平台 智能投顾 大数据 语言的技巧很重要,很多时候用言语表达出来的都是浅薄的,很多时候说的多反而起不到好的效果。 通过这一次年会,我也发现了一些我不喜欢的。……

阅读全文

公司的成长史

preface 最近Boss 开了例会,谈了下公司的发展史。听着挺有意思,于是决定记录下来。……

阅读全文

Seastar 入门

1 what is Seastar 这篇文章将介绍一下 Seastar : 一个在现在多核机器上编写高效复杂的服务器应用程序的 C++ 库。 有些框架非常高效,但只允许构建简单的应用程序(eg: DPDK 允许单独处理数据包的应用程序), 而其他框架则允许构建极其复杂的应用程序,代价是运行时效率。Seastar 是我们尝试获得两全其美的方法:创建一个允许构建高度复杂的服务器应用程序并实现最佳性能的库。 2 起源 Seastar 的灵感和首例使用案例是ScyllaDB,重写了Apache Cassandra,Cassandra 是一个分厂复杂的应用,同时通过 Seastar,我们能够重新实现……

阅读全文

2018 Vision Hubble

1990年4月24日 Hubble Space Telescope Preface 和往常一样,今天又领到一笔资本主义安慰,一切都很安逸。CTO 会上开玩笑说:“软件不出Bug,每个月领着固定的薪水,生活就这样保持现状,多好! 最好什么都不要变,生活就保持现状!如果说,把每个人的薪资都提高一倍,我想就没人干活了,生活太安逸了。 反过来,如果把每个人的薪资都降到5k,我想大家一定拼命写!写简历…(哈哈)” 很有同感,之前在HS的时候,感觉自己用的东西太low,偶尔夜里做恶梦跟不上技术的革新,用着大家都淘汰的东西,失落就像坠……

阅读全文

最近文章

分类

友情链接

标签

-Wall(1) 2017(1) 2023(1) about(1) AC自动机(1) algorithm(2) atomic(1) BigData(1) busy(1) C++11(3) cache(3) chrome(1) cluster(1) CMake(1) cmd(1) Code Review(1) communication(1) core(1) CPA(1) CPC(1) CPM(2) CPP(15) CPS(1) CPT(1) CPU(1) CR(1) CS(4) Diary(3) Docker(1) DP(1) duck-type(1) echarts(1) epoll(1) etcd(1) Eureka(1) event(1) eventfd(1) Feeling(1) future(2) Gerrit(1) git(6) go(3) go-cmp(1) Golang(8) hardware(1) Hundsun(2) intersection(1) iPhone(1) Java(2) kafka(2) lambda(1) Languages(2) LeetCode(3) libuv(1) Life(12) LinkList(1) Linux(2) LogReplay(1) lua(3) MacOS(1) MySQL(1) mysqldump(1) narrow cast(1) nullptr(1) OKR(1) oneof(1) OpenTelemetry(1) owners(1) pkg(2) plan(1) plugin(2) plugins(1) poll(1) promise(1) proto3(1) Protobuf(1) rb-tree(1) Reactive(1) ready_future(1) rebase(1) recommend(2) recursive(1) Redis(1) reflection(3) Registry Center(1) Release(1) resume(1) rpm(1) seastar(4) select(2) set(1) shared_ptr(1) SIGABRT(1) Simulate Location(1) sql(2) std::thread(1) syscall(1) tcp(1) timeout(1) TodoList(1) Tools(3) tracing(1) Travel(1) unique_ptr(1) unwound stack(1) weak_ptr(1) Web(2) Wireshark(4) Work(9) zeromq(2) zookeeper(2) zsh(1) 个人旅游(1) 企微机器人(1) 优点(1) 全麻(1) 动态规划(1) 在线广告(1) 多模匹配(1) 工作总结(1) 广告(1) 开源工具(1) 开源库(4) 总结(2) 扔鸡蛋问题(1) 文本消息指令(1) 智齿(1) 流量录制回放(1) 用户标签(1) 缺点(1) 群收款(1) 背包问题(1) 读书笔记(8) 香港签注(1) 高可用(2) 鼻炎(1)

其它