- 在线时间
- 0 小时
- 最后登录
- 2005-9-21
- 注册时间
- 2004-4-27
- 听众数
- 1
- 收听数
- 0
- 能力
- 0 分
- 体力
- 1027 点
- 威望
- 0 点
- 阅读权限
- 40
- 积分
- 385
- 相册
- 0
- 日志
- 0
- 记录
- 0
- 帖子
- 153
- 主题
- 43
- 精华
- 0
- 分享
- 0
- 好友
- 0
升级   28.33% 该用户从未签到
国际赛参赛者
 |
< >不知道大家有没有我这种体验.大家先看看下面这段代码:</P>$ ]( w3 i& O" ~3 p6 A
< >int fp=_wopen(L"Hello.dat",O_BINARY | O_CREAT | O_TRUNC | O_RDWR);" R' l; u4 ` g. D) G1 u
if(fp==-1) return;
6 e5 k) }' C8 Mwrite(fp,L"123中国人",wcslen(L"123中国人"));0 F' O: Y% Z. Z( y; S! e
close(fp);
' f: g3 B5 [4 B+ {( r0 \ n' j6 I1 Y8 d# [8 y% x% @
上面这段代码不知道大家看出什么BUG来了.如果大家看不出毛病也不足为怪,因为这是我们的习惯导致了我们的错误产生.
5 L" ~2 f* L* n' G2 s, P0 Y( ^) z2 Q6 H) s* z6 L/ Q, h( s
先让我来分析一下write吧.下面是write的原型:8 E8 M7 F3 j4 h
int write( int <I>handle</I>, const void *<I>buffer</I>, unsigned int <I>count</I> ); o4 T1 u( e6 e3 W5 l& F
! g- |/ a" t- I; q参数:
# K( `+ W$ r' T) Fhandle 已打开或已创建的文件句柄 J; @$ @* I) o* [
buffer 待写入的数据
, R9 K/ ~7 n t% z# ^count 待写入的数据大小# [4 p$ F; w; u3 j4 |
* g2 e8 N+ K" |
现在分析为什么上面的那代码有bug,其实主要问题就在一个buffer,和count.
. y6 a7 g! P+ k8 U如果我们写入一个Ansi字符串,上面的代码改成相应的形式确实没有错.
' u! ]9 ~" N1 z$ `但如果是写入一个宽字符串,那么上面的代码就不严格.原因就在于count.
5 [* L: S0 m. B
3 t/ y8 g1 B1 z我们首先看一下strlen和wcslen,如果使用strlen,一般情况下,我们直接作为字符串的长度,$ n4 b: ] W# W
而使用wcslen,你会发现,得出的不是字符串的长度而是字符的个数.6 e! ]$ P# Q% U1 s3 p
; b8 F8 ?) c; ]/ s3 T/ q- X8 D) j
这就是问题的所在.一般情况下.char的长度是1,这是用sizeof(char)运算出来的结果.
7 t9 M: `9 ^* n$ r- i% ~len=strlen(str)*sizeof(char);而我们一般情况下,都只用strlen(str)来等价,这就是平时的习惯.; \' A- h. v9 \3 h0 Y9 c8 D
正是由于这个习惯所引来的问题,这个习惯并不适用于宽字符串.因为wcslen(str)*sizeof(wchar_t)并不等于wcslen(strl).这就是习惯所引起的错误., W% Y/ D/ g; |' K, _
0 D, ^3 s- u4 u# Q& ]: d2 w0 Z. q说到这里我想大家都明白了.我在这里把这种习惯称之为不良习惯.所以大家以后在计算字符串长度的时候,千万不能简而简之,一定要len=strlen(str)*sizeof(char),len=wcslen(str)*sizeof(wchar_t).
* r/ t( _7 [6 Q# y8 u* `& t不要再犯这种习惯性的低级错误.(在下就犯了这种错误.大家都可怜我吧!).</P>" _2 f) }; Q, H
[此贴子已经被作者于2004-11-26 9:50:40编辑过] |
zan
|