所以,我正在通过串口读取ModBos,并获得如下内容:’0020.8 0022.8-00.046-00.002-00.005-001.99 00.000 00.003′; 基本上,总会有8个浮点读数,前面带有加号或减号,尽管它们的字符长度可能不同. 获取值
基本上,总会有8个浮点读数,前面带有加号或减号,尽管它们的字符长度可能不同.
获取值为浮点数组(或字符串数组或TSringList)的最有效方法是什么?
我不确定,但这可能是时间关键,所以效率可能优于优雅.
我会做这样的事情:type TFloatArray = array[0..7] of Double; procedure ParseFloats(const aFloatStr: string; var aFloatArray: TFloatArray); var lPos: Integer; lNextPos: Integer; lPosPositive: Integer; lPosNegative: Integer; i: Integer; lFormatSettings: TFormatSettings; begin //do not forget formatsettings, or you will get problems with regional settings lFormatSettings.DecimalSeparator := '.'; lFormatSettings.ThousandSeparator := ','; lPos := 1; for i := 0 to High(aFloatArray) do begin lPosPositive := PosEx('+', aFloatStr, lPos + 1); lPosNegative := PosEx('-', aFloatStr, lPos + 1); if lPosPositive = 0 then lNextPos := lPosNegative else if lPosNegative = 0 then lNextPos := lPosPositive else lNextPos := Min(lPosPositive, lPosNegative); if lNextPos = 0 then lNextPos := Length(aFloatStr) + 1; aFloatArray[i] := StrToFloat(Copy(aFloatStr, lPos, lNextPos - lPos), lFormatSettings); lPos := lNextPos; end; end; //call like this var lFloats: TFloatArray; begin ParseFloats('+0020.8+0022.8-00.046-00.002-00.005-001.99+00.000+00.003', lFloats); end;
因为总有8个浮点值,所以8个双精度数的固定数组就足够了.我将字符串操作保持在最小值,每个浮点值只复制一次字符串.重要的是TFormatSettings,否则你会在小数分隔符不是点(如我的)的系统上得到错误.
这里没有异常处理,我期望一个包含8个浮点值的字符串,仅此而已.