下面两个函数均是对于一个字符串将其以某个分割符分开:
function SplitStrToArray(const tString, tSplit: String): TStringList;
//以后成为方法1,这也是《delphi超级猛料》中提到的算法
var
t_Str, t_Item: WideString;
t_Index, t_Len: Integer;
t_StrList: TStringList;
begin
t_StrList := TStringList.Create();
t_Str := tString;
t_Len := Length(tString);
t_Index := pos(tSplit, t_Str); //语句1
if t_Index > 0 then
begin
while t_Index > 0 do
begin
t_Item := LeftStr(t_Str, t_Index – 1);
t_Str := MidStr(t_Str, t_Index + 1, t_Len);
t_Index := Pos(tSplit, t_Str);
if Length(t_Item) > 0 then
t_StrList.Add(t_Item);
end;
end;
if Length(t_Str) > 0 then
t_StrList.Add(t_Str);
Result := t_StrList;
end;
function SplitString(const source,ch:string):TStringList;
//以后成为方法2;
var
temp:string;
i:integer;
begin
result:=tstringlist.Create;
temp:=source;
i:=pos(ch,source);
while i<>0 do
begin
result.Add(copy(temp,0,i-1));
delete(temp,1,i);
i:=pos(ch,temp);
end;
result.Add(temp);
end;
看上去两段代码都没有问题,然而,实际用这两段进行测试时:比如:
s:=美国a,aab,中国,ddf;
t:=SplitStrToArray(s,,);
//t:=SplitString(s,,);
for i:=0 to t.Count-1 do
showmessage(t.Strings[i]);
会发现方法1不能识别中文,也就是说在有中文的字符串里面,方法一不能正确分割。而方法2可以。问题出现在哪里呢?
我又跟踪程序发现,两个函数在进入循环之前都执行了一个pos( )函数,而方法1此时返回的值是4,方法2返回的就是6,所以方法1自然不能正确识别了。那么问题又来了,在他们的pos之前,两个函数都没有做什么奇怪的操作啊。
再尝试,将方法1的 语句1,即t_Index := pos(tSplit, t_Str);的pos的第二个参数修改为函数的形参tString,那么,此句t_Index的值就是正确的6,而以后的分割又错了。
我实在是想不通了,不知道哪位达人遇到过类似的问题,还是说我分析的不对,还是delphi的bug?