我通过执行字节的累积和来模拟缓存系统,当总和为缓存大小的0.95时,强制该值为完整大小的0.9。
最终结果应该像锯齿一样进化。
这是我用来强制实现这个条件的代码。
cache_size=1e11 #B
high_mark=0.95
low_mark=0.50
ordered_datestamp['Cache']=0
for i in range(1,rows_number):
ordered_datestamp['file_size_Cum'][i]=ordered_datestamp['file_size_Cum'][i-1]+ordered_datestamp['file_size'][i]
ordered_datestamp['Cache'][i]=ordered_datestamp['file_size_Cum'][i]
if(ordered_datestamp['Cache'][i]>high_mark*cache_size):
ordered_datestamp['Cache'][i]=low_mark*ordered_datestamp['Cache'][i]这是输出。

if语句如何在循环中只完成一次?
发布于 2020-12-15 03:06:58
给出代码,我不明白为什么观察到的行为是错误的。下面是如何设置累计和上限的方法:
ordered_datestamp['Cache'][i]=low_mark*ordered_datestamp['Cache'][i]
您是通过low_mark因子来缩放值,而不是实际设置上限。因此,它有可能超出高速缓存的大小。您可能打算这样做:
ordered_datestamp['Cache'][i]=low_mark*cache_size
而且,我不知道ordered_datestamp['file_size_Cum'][0]是在哪里初始化的。您正在初始化ordered_datestamp['Cache']=0,这很奇怪,因为ordered_datestamp['Cache']看起来像是一个列表。
https://stackoverflow.com/questions/65294525
复制相似问题