- r - 以节省内存的方式增长 data.frame
- ruby-on-rails - ruby/ruby on rails 内存泄漏检测
- android - 无法解析导入android.support.v7.app
- UNIX 域套接字与共享内存(映射文件)
所以我正在构建一个小型实用程序,它在套接字上监听并将传入的消息作为结构存储在 slice 中:
var points []Point
type Point struct {
time time.Time
x float64
y float64
}
func main() {
received = make([]Point, 0)
l, err := net.Listen("tcp4", ":8900")
// (...)
}
func processIncomingData(data string) {
// Parse icoming data that comes as: xValue,yValue
inData = strings.Split(data, ",")
x, err := strconv.ParseFloat(inData[0], 64);
if err != nil {
fmt.Println(err)
}
y, err := strconv.ParseFloat(inData[1], 64);
if err != nil {
fmt.Println(err)
}
// Store the new Point
points = append(points, Point{
time: time.Now(),
x: x,
y: y,
})
// Remove points older than 1h ?
}
现在,正如您想象的那样,这将很快填满我的 RAM。 在添加每个新点后删除早于 1 小时的点的最佳方法(执行速度更快)是什么?我将获得同龄人每秒 10-15 倍的新积分。
谢谢。
最佳答案
我多次使用的一种方法是在项目早期启动一个 goroutine,看起来像这样:
go cleanup()
...
func cleanup() {
for {
time.Sleep(...)
// do cleanup
}
}
然后你可以做的是遍历 points
使用 time.Since(point.time)
计算出每条数据的年龄。如果它太旧,则有一个 slice trick从给定位置的 slice 中删除项目:
points = append(points[:i], points[i+1:]...)
(其中 i
是要删除的索引)
因为这些点是按照它们被添加的时间顺序排列在 slice 中的,所以您可以通过简单地找到第一个不到一小时的索引并执行 points = points[i:]
来加快速度。从 slice 的开头切掉旧点。
如果您在清理数组时收到访问数组的请求,您可能会遇到问题。添加 sync.Mutex
可以帮忙。只需在清理之前锁定互斥锁,并尝试在写入数组的其他任何地方锁定互斥锁。但这可能是过早的优化。在添加互斥量之前,我会在没有互斥量的情况下进行试验,因为这会有效地与 points
进行交互。串行操作并减慢服务速度。
time.Sleep(...)
在循环中是为了防止过于频繁地清洁。您可能想将它设置为一个小时,因为您想要删除早于该时间的点,但最终可能会遇到在清理后立即添加一个点的情况。在下一次清理时,它将有 59 分钟的历史,而您不删除它,在下一次清理中,它有将近 2 小时的历史。我的经验法则是,我尝试每 1/10 的时间清理一次我希望允许对象保留在内存中的时间,但这是相当随意的。这种方法意味着一个对象在删除时最多可以存在 1 小时 5 米 59 秒。
关于戈朗 : remove structs older than 1h from slice,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/55911261/
我正在使用 .remove() 方法删除一个 html 元素,同时对于这个元素,我有一个事件处理程序,但它没有被触发。为什么会这样呢?这是jsFiddle和代码:HTML Delete I'm goi
所以我尝试从另一篇文章中编写此代码: while(fscanf(orderFile," %49[^;];%d; %49[^\n]",fileName,&seconds,timeValue) == 3)
我正在阅读 Nicolai M.Josuttis 撰写的“The C++ STL. A Tutorial and References”一书,在专门介绍 STL 算法的一章中,作者陈述如下:如果你调用
是否有一种简单的机制来确定 DownloadManager remove() 何时完成,因为它看起来是部分异步的。该函数几乎立即返回下载表中已删除的条目计数,但实际的文件系统管理似乎被插入了某个后台线
我愿意: getActionBarToolbar().removeView(logoImage); getActionBarToolbar().addView(logoImage, lp); 我得到:
我有类(class)评论一对多关系。在类(class)表中有 id 和 title 列。在 Review 表中,有 id、comment 和 course_id,其中“course_id”作为指向类(
我在 stackoverflow 上阅读了不同的答案,了解如何销毁 wigdet/jQueryObject 并取消绑定(bind)其上的所有事件。 这就是我的想法。 $('选择器').remove()
我有一个由一个线程填充的 byte[] 列表,然后我有另一个线程正在从该列表中读取并通过网络发送项目。 每次我读取线程 2 中的项目时,我都想将其从内存中清除。但是因为我正在使用线程,如果我使用 .r
就算法而言,从连续数组中删除一组元素可以分两部分有效地完成。 将所有不删除的元素移到数组的前面。 将数组标记得更小。 这可以在 C++ 中使用 erase-remove 习惯用法来完成。 vector
我尝试删除包含在 map 中渲染的制造商的 View 。当我单击按钮时,事件 click .ver 被激活,但没有任何反应,并且我收到以下错误:Uncaught TypeError: undefine
场景: 使用 jQuery 2.0.1 构建的应用程序。 您的团队更喜欢原生 JavaScript。 选项有jQuery .remove()和 ChildNode.remove() . 您需要删除节点
最初我有一个像这样的删除功能: function ViewWorkflowDetail(btn, workflowId) { $("#workflowDetailPanel").remov
我正在编写 C++ 代码来解决 Leetcode 中的这个问题:https://leetcode.com/problems/remove-element/ Given an array nums an
根据太阳, "Iterator.remove is the only safe way to modify a collection during iteration; the behavior is
众所周知,从 std::vector 中完全删除所需项的一种好方法是 erase-remove idiom . 如以上链接中所述(截至本文发布日期),在代码中,erase-remove 习惯用法如下所
我在 HashSet 上调用 Iterator.remove() 时遇到问题。 我有一组带有时间戳的对象。在将新项目添加到集合之前,我会遍历集合,识别该数据对象的旧版本并将其删除(在添加新对象之前)。
这段代码: Collection col = new ArrayList(); col.add("a"); col.add("b"); col.add("c");
我试图通过在下面输入来卸载 conda 环境基础, conda env remove -n base 正如我所建议的那样,我尝试通过使用来停用基地 conda deactivate base 我再次尝
我已经对我的 IOS 应用程序进行了质量扫描分析。我收到以下警告: The binary has Runpath Search Path (@rpath) set. In certain cases
这个问题已经有答案了: Properly removing an Integer from a List (8 个回答) 已关闭 4 年前。 我是java新手。看起来很简单,但我不明白为什么会发生这种
我是一名优秀的程序员,十分优秀!