我正在整理过去使用FastStrings的旧代码,并且我已经实现了我的’PosAnyCase’的旧例程,它应该像’Pos’一样操作. (我希望SearchBuf比在两个字符串上调用UpperCase更好).
function PosAnyCase( const AFindStr,AStr : string ) : integer; // Returns the position of this substring within a string ignoring case
我正在使用SearchBuf如下:
function PosAnyCase( const AFindStr,AStr : string ) : integer; // Returns the position of this substring within a string ignoring case var Start,ResultPos : PChar; begin Start := PChar( AStr ); ResultPos := SearchBuf( Start,ByteLength( AStr ),AFindStr,[sodown] ); if ResultPos = nil then Result := 0 else Result := ResultPos-Start+1; end;
当我从单元测试中调用此例程时,以下测试通过:
Check( PosAnyCase( '','123' ) = 0 ); Check( PosAnyCase( '2','123' ) = 2 ); Check( PosAnyCase( 'A','ABC' ) = 1 ); Check( PosAnyCase( 'a','ABC' ) = 1 ); Check( PosAnyCase( 'the','hellot there' ) = 8 ); Check( PosAnyCase( 'THE','hellot there' ) = 8 );
但是这个测试失败了:
Check( PosAnyCase( 'nice','does not have n i c e' ) = 0 );
我做错了什么? SearchBuf上的文档非常有限….
谢谢
解决方法
对ByteLength的调用不正确.虽然
documentation明确声明参数是以字节为单位的长度,但事实并非如此.你应该使用Length代替,因为函数实际上需要char的单位而不是byte的单位.
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。