go遇到的问题

一、类型转换             a = 100.0  //c/c++使用100.0f                fmt.Printf("%f\n",a/4) //可以得到浮点数             fmt.Printf("%f\n",a/4.0...

2017-09-04 09:43:13

阅读数 114

评论数 0

toml使用中容易遇到的问题

1、成员变量、类型、toml中的名字的一致性        go语言中的结构定义              server struct {                                   Debug                    bool    `toml:deb...

2017-09-02 15:48:51

阅读数 747

评论数 0

go的protobuf环境搭建

go的protobuf环境搭建

2017-08-30 08:21:08

阅读数 334

评论数 0

go开发中遇到的问题

go入门

2017-08-22 07:58:14

阅读数 292

评论数 0

redis日常学习

redis

2017-08-18 19:57:18

阅读数 134

评论数 0

go开发中容易犯的错

go入门

2017-08-18 16:25:17

阅读数 114

评论数 0

go语言入门必备

go语言入门

2017-08-13 19:14:50

阅读数 172

评论数 0

go的html模板替换

go入门

2017-08-09 21:57:54

阅读数 904

评论数 0

go的反射机制和interface

go反射机制的摸索

2017-08-09 21:31:23

阅读数 125

评论数 0

go语言开发必备

go入门必备

2017-08-09 21:13:41

阅读数 5083

评论数 0

文件系统中的io请求的传递

块设备的io请求类型在不同层次有不同的表示      page cache=>buffer head=>bio=>request IO请求在内核的传递过程中,并未发生实际的拷贝,而是引用部分数据 在request对象中还是有bio对象的,在转化的时候,bio...

2016-08-15 17:18:48

阅读数 249

评论数 0

文件系统中数据读取的详细过程

一直在困惑文件系统sys_read、bio、io调度、硬中断、软中断、io完成通知之间的过程是怎么样的,通过代码的跟踪大致明白过程了 内核态的系统调用与bio的交界处的函数mpage_bio_submit(fs/mpage.c) bio与io调度的交界处的函数__make_request(bloc...

2016-08-14 22:32:41

阅读数 919

评论数 0

缓存的理解

CPU体系结构中有L1,L2,L3缓存 L1是CPU相关的,L2,L3则是所有CPU共享的 L1分指令和数据的Cache,Cache line是缓存的最小单位 想象CPU在执行指令的时候,引用的大部分的数据都是L1,L2,L3中,只有部分是使用内存中的数据 可以想象这里存在一个L1,L2,L3...

2016-08-14 00:04:36

阅读数 403

评论数 0

文件系统中的疑惑

1、inode之间有逻辑关系,在持久化的时候保存这种关系吗?       逻辑关系就是一个文件使用的块的链表编号       逻辑关系还包括就是目录的树结构,需要在内存中构建出来 2、dentry需要持久化吗?       树形结构不需要持久化       通过file_system_type...

2016-08-12 15:00:21

阅读数 321

评论数 0

Qdisc数据发送

Qdisc中的实现方式大致如下 struct Qdisc { int (*enqueue)(struct sk_buff *skb, struct Qdisc *dev); struct sk_buff * (*dequeue)(struct Qdisc *dev); unsigned...

2016-08-11 10:07:34

阅读数 1659

评论数 0

数据收发的软中断以及数据从网卡发送

注册软中断 static int __init net_dev_init(void) { ...... open_softirq(NET_TX_SOFTIRQ, net_tx_action); open_softirq(NET_RX_SOFTIRQ, net_...

2016-08-11 01:00:26

阅读数 484

评论数 0

协议栈数据发送

数据发送 tcp_write_xmit() {   while ((skb = tcp_send_head(sk)))    {      tcp_event_new_data_sent(sk, skb);//重新获取首部   } } 数据发送经过ip层路由和邻居协议后 发送队列关联了Qdisc ...

2016-08-11 00:36:39

阅读数 634

评论数 0

网络包处理的中断下半部

中断下半部处理    中断下半部将网卡中的DMA-ring中的skb取出来,经过ip层处理,主要是netfilter    最后决定是否传递到本地传输层    如果交给本地传输层ip的最后处理ip_local_deliver_finish 中断的下半部的结束位置是哪里? 何时出中断上下文?    ...

2016-08-10 15:21:12

阅读数 302

评论数 0

tcp拥塞控制

查看当前正在使用的拥塞算法    sysctl net.ipv4.tcp_available_congestion_control    /proc/sys/net/ipv4/tcp_congestion_control  常见的拥塞算法   cubic(RTT隔离,但有流量突发)   reno ...

2016-08-10 15:17:07

阅读数 333

评论数 0

客户端状态机如何进入ESTABLISHED

结论      tcp客户端connect发起之后,协议栈就会发送SYN给服务器,协议栈收到来自服务器的响应后,发出Ack后,就进入了established    tcp服务器在收到SYN后,发送SYN+ACK后就进入SYN_RECVD,再次收到客户端的Ack时,也进入established   ...

2016-08-09 23:55:03

阅读数 408

评论数 0

提示
确定要删除当前文章?
取消 删除
关闭
关闭