This "for loop" doesn't work as expected (with version 7.0.350). Nothing is printed. 
int main()
{
   char s[]="ABC";
   for(int i=strlen(s);i>=-strlen(s); i--)
      printf("%c",s[abs(i)]);
}
			
			
			
				Hello gho. Welcome on PellesC.
First of all please use current compiler version, 8.00.60, that you can download from here (http://forum.pellesc.de/index.php?topic=6663.0).
There is no bug in the compiler for the snippet you have posted.
It is your code indeed to be bugged.
The problem is that you are comparing a signed int, the loop variable i, with the unsigned size_t value returned from strlen.
The compiler try to apply integer promotion privileging the type that can contain bigger value, the usigned, but sign change (equivalent to arithmetiic computation 0-val) generates an underflow. And this lead to wrong value. See here (http://stackoverflow.com/questions/7221409/is-unsigned-integer-subtraction-defined-behavior) (the concept is valid for overflow and underflow).
Casting the result from strlen solve the problem:
int main(void)
{
   char s[]="ABC";
   for(int i=strlen(s);i>=-((int)strlen(s)); i--)
      printf("%c",s[abs(i)]);
}
Of course on compilers not fully C99-C11 compliant it could eventually work...  :(
			
			
			
				As PellesC is a C99 compiler, you have to addint strlen(char *s);to get that example compiled without headers.
msvc don't need that (C89) as function without declaration defaults as return int.