博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
[elixir! #0037] Agent 小传
阅读量:5982 次
发布时间:2019-06-20

本文共 934 字,大约阅读时间需要 3 分钟。

图片描述

elixir! #0041

前言

Agent 是 elixir 中引入的一个新的抽象。 它建立在 GenServer 之上,它的

实现非常简单。基本的机制就是 agent 进程接收一个函数, 然后对它的 state
执行这个函数。

所以, agent 进程可以在存取数据的同时,用来对数据做一些轻量的处理。

它使得我们实现并发操作所需要的代码变得更加简单了。

注意

agent 的优点

  • 提供了一个可以从其他进程访问的数据存储点

  • agent 的数量不限,而ets 表的数量默认是 1400 个

  • 使用起来很简单

agent 的缺点

  • 进行 expensive 的操作可能会导致响应超时

  • 存取速度比 ets 慢

例子

在 elixir 自带的构建工具 Mix 的源码中, 我们看到了对 Agent 这样的使用方式:

defmodule Mix.Config.Agent do  @moduledoc false  @typep config :: Keyword.t  @spec start_link() :: {:ok, pid}  def start_link do    Agent.start_link fn -> [] end  end  @spec stop(pid) :: :ok  def stop(agent) do    Agent.stop(agent)  end  @spec get(pid) :: config  def get(agent) do    Agent.get(agent, &(&1))  end  @spec merge(pid, config) :: config  def merge(agent, new_config) do    Agent.update(agent, &Mix.Config.merge(&1, new_config))  endend

它的作用是在编译时临时存储应用的配置信息, 具体可看。

总结

简而言之, 如果你有这样的需求:

  • 一个可以从任何进程访问的数据存储点

  • 让一个独立的进程来对数据进行轻量处理

  • 对速度要求不高(例如在编译时使用)

  • 不想占用 ets 表的份额

就可以考虑使用 Agent。

转载地址:http://dhrox.baihongyu.com/

你可能感兴趣的文章
层次分析法
查看>>
ASP.NET一些常用的东西
查看>>
音乐播放类应用后台播放耗电评测报告
查看>>
2015百度之星 单调区间
查看>>
Ubuntu安装Chrome的方法
查看>>
用批处理来操纵你的光驱
查看>>
SQL 问题记录
查看>>
vim修改时自动备份配置文件小脚本
查看>>
我的友情链接
查看>>
官宣:深度剖析免费OA系统是如何盈利
查看>>
vue2.0学习笔记(一)搭建学习环境
查看>>
数据库热备产品都有哪些?各有什么优缺点?
查看>>
生成树协议(STP)
查看>>
hadoop大数据基础框架技术详解
查看>>
Apache日志分割&日志分析
查看>>
MySQL完全备份与恢复
查看>>
JVM内存结构 VS Java内存模型 VS Java对象模型
查看>>
__main__:1: Warning: Unknown table 'employ' 0L
查看>>
Linux练习题-文件查找
查看>>
python bottle 简介
查看>>