我需要对备忘录中的文本进行数学计算。 [档案大小:~2mb]
一个合适的例子是我需要解码的编码文本。
我将备忘录文本传递给字符串以便对其进行解码。 我想使用线程运行我的解码函数会更快。 但经过一些谷歌搜索后,我没有找到符合我目的的好例子。
示例功能:
function entr_base_N(my_text:String):String;
var
ts_hamil64:Integer;
begin
For ts_hamil64 := 1 to Length(my_text) do
begin
Result:= Result + Chr(Ord(my_text[ts_hamil64])+10)
end;
end;
.....
.....
Memo1.Text:=entr_base_N(Memo1.Text)
我想将工作分成小块,平均分工,让我们说3..8个线程并将解码函数分配给那些线程。你能指导我吗?
处理文本文件的当前时间:~35秒。 谢谢你的帮助。
答案 0 :(得分:5)
线程不是问题。您的函数entr_base_N
会立即运行。在调试器中尝试。你会发现它根本不需要时间。在现代计算机上处理2MB字符串是微不足道的。也就是说,我总是建议在可能的情况下预先分配一个返回缓冲区。
所有时间都花在将结果字符串发送回备忘录控件上。发生的事情是你将#13和#10字符转换为#23和#20。无论出于何种原因,备忘录控件都不喜欢这样。在我看来,你发回的字符串根本没有换行符,备忘录的自动换行代码表现不佳。
快速而又肮脏的方法是将WordWrap
设置为False
备忘录。
这里的重要教训是,您必须在尝试优化之前正确识别瓶颈。然而,这是一个容易陷入的陷阱,因为我最初的努力回答了这个问题。
答案 1 :(得分:1)
要更快地分配Memo1.Text,您可以使用以下内容:
memo1.Perform(wm_setredraw, 0, 0);
try
memo1.Text:= entr_base_N(memo1.Text);
finally
memo1.Perform(wm_setredraw, 1, 0);
memo1.invalidate;
end;