我写了一个小程序,它反转一个字符串并将其打印到屏幕:
void ReverseString(char *String) { char *Begin = String; char *End = String + strlen(String) - 1; char TempChar = '\0'; while (Begin < End) { TempChar = *Begin; *Begin = *End; *End = TempChar; Begin++; End--; } printf("%s",String); }
它在Windows上的Dev C++(小端)中完美运行.但我突然怀疑它的效率.如果你看这一行:
while (Begin < End)
我正在比较开头和结尾的地址.这是正确的方法吗?此代码是否适用于Mac OS X等大端操作系统?或者我在想错路?
我有几个疑问,我在上面提到过.有人可以澄清一下吗?
您的代码没有与字节顺序相关的问题.你比较两个指针的方式也没什么不对.简而言之,您的代码很好.