发一下牢骚和主题无关:
昨晚听完百度校园公开课,还得了个保温杯,好开心.
当初把抄到的笔记整理下,货色不会很具体,但充足引出很多知识点
感谢运维部的颜工来湖大授课!
1 周游linux
一些经常使用的linux命令: ssh cd pwd ls tab mkdir rm cp mv cat more less
文本处理:head tail cat sort diff grep sed awk
重定向: | > >>
其它: alias find scp wget ps top vmstat netstat watch
vim
gcc 版本我特地问了 ,本来他们部门在用3.4.5版本
gcc常见错误:
underfind reference 找不到库 -l库名 -L库目录
no such file or directory 找不到头文件 -I 头文件路径 (i的大写)
项目管理工具: Makefile 还有开源的Autoconf 百度的Commake
经常使用开发工具:valgrind strace Ltrace ccov Gtest
2 多线程
多线程:共享内存空间
长处:数据访问方便 缺点:线程问题会影响团体,线程安全问题
多进程:独立内存空间
线程切换有开销
开几个线程的要点:线程数不要超过CPU个数
线程安全问题:线程调度的前后是由操作系统决定的,和代码复杂度无关
互斥与同步: (1)访问同一个资源,应用互斥锁程序的串行 (2)应用条件变量坚持同步
开销: 锁比运算要慢,但比磁盘IO要快
锁的应用原则:
IO密集型程序:不要让高速设备等待低速设备
CPU密集型程序:放大锁的粒度,减少锁的应用
线程池模型:
(1)单队列:无序,池中的线程能够运行任何任务,能够最大化利用CPU
(2)多队列:某些任务只能由特定的线程来运行,这个须要负载均衡
3 高性能网络编程
网络编程中有很多慢的地方
accept() 在等待
recv() 在等待
send() 在发送到网卡时 在空转
(1)多线程同步IO设计模式
效率低 用于原理验证
(2)单线程异步IO设计模式 (单核时期最快)
(3)多线程异步IO模式 多进程异步IO模式 :充分发挥多核优势
4多机系统和分布式系统
有点累, 没抄笔记
文章结束给大家分享下程序员的一些笑话语录:
有一天,一个男人穿越森林的时候,听到一个细微的声音叫住他。他低头一看,是一只青蛙。
“如果你亲我一下,我会变成一个美丽的公主哦。”男人一言不发,把青蛙捡起来,放入口袋。
“如果你亲我一下,我会变成一个美丽的公主哦。而且,我会告诉我遇到的每一个人,你是多么聪明和勇敢,你是我的英雄。”男人把青蛙拿出来,对着它微微一笑,又把它放回口袋。
“如果你亲我一下,我会变成一个美丽的公主,然后我愿意成为你的爱人一星期。”男人又把青蛙拿出来,对着它微微一笑,把它放回口袋。
“如果你亲我一下,我会变成一个美丽的公主,然后我愿意成为你的爱人一年,而且你可以对我做任何事。”再一次,男人把青蛙拿出来,对着它微微一笑,又把它放回口袋。
最后,青蛙无力地问:“我开出了这么好的条件,为什么你还不肯吻我?”男人说:“我是一个程序员,我可没时间和什么公主鬼混。不过,拥有一个会说话的青蛙,倒是蛮酷的。”