首页
学习
活动
专区
工具
TVP
发布

蘑菇先生的技术笔记

专栏作者
75
文章
93101
阅读量
28
订阅数
多线程中的锁系统(四)-谈谈自旋锁
基础 内核锁:基于内核对象构造的锁机制,就是通常说的内核构造模式。用户模式构造和内核模式构造            优点:cpu利用最大化。它发现资源被锁住,请求就排队等候。线程切换到别处干活,直到接受到可用信号,线程再切回来继续处理请求。            缺点:托管代码->用户模式代码->内核代码损耗、线程上下文切换损耗。                    在锁的时间比较短时,系统频繁忙于休眠、切换,是个很大的性能损耗。 自旋锁:原子操作+自循环。通常说的用户构造模式。  线程不休眠,一直循环尝
蘑菇先生
2018-05-21
1.1K0
探索c#之一致性Hash详解
阅读目录: 使用场景 算法原理 虚拟节点 代码示例 使用场景 以Redis为例,当系统需要缓存的内容超过单机内存大小时,例如要缓存100G数据,单机内存仅有16G时。这时候就需要考虑进行缓存数据分片,也即是把100G的数据拆分成多块小于单机内存的数据。例如以10G为单位,拆分10份,存储到多台机器节点上。 但是数据怎么个分法更合理呢? 、 f(key)%n 这里配置n=10,不同的key根据数值余数映射到对应的机器。 很简单的办法就解决了多台节点key分法的问题。然而数据大小的增长和缩减是很难预知的, 如果
蘑菇先生
2018-05-21
7620
多线程中的锁系统(一)-基础用法
     平常在多线程开发中,总避免不了线程同步。本篇对net多线程中的锁系统做个简单描述。 阅读目录: lock、Monitor 作用域范围 字符串锁 Monitor的用法 Mutex Semaphore 总结 lock、Monitor Lock是Monitor语法糖简化写法,Lock在IL会生成Monitor。 //======Example 1===== string obj = "helloworld"; lock (obj)
蘑菇先生
2018-05-21
5770
算法数据结构(一)-B树
介绍 B树的目的为了硬盘快速读取数据(降低IO操作次树)而设计的一种平衡的多路查找树。目前大多数据库及文件索引,都是使用B树或变形来存储实现。 目录 为什么B树效率高 B树存储 B树缺点 为什么B树效
蘑菇先生
2018-05-21
7550
没有更多了
社区活动
腾讯技术创作狂欢月
“码”上创作 21 天,分 10000 元奖品池!
Python精品学习库
代码在线跑,知识轻松学
博客搬家 | 分享价值百万资源包
自行/邀约他人一键搬运博客,速成社区影响力并领取好礼
技术创作特训营·精选知识专栏
往期视频·千货材料·成员作品 最新动态
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档