为什么eof位置不同结果不同,该如何解决

为什么eof位置不同结果不同
1.
[code=C/C++][/code]
#include <stdio.h>
int main(int argc, char *argv[])
{
char c1,array[100];
int cas=0;
while(c1=getchar())
{
if(c1==EOF) break;
  if(c1!='\n') array[cas++]=c1;
}
printf("%s",array);
return 0;
}


2.
[code=C/C++][/code]
#include <stdio.h>
int main(int argc, char *argv[])
{
char c1,array[100];
int cas=0;
while(c1=getchar()!=EOF)
{
  if(c1>=' ') array[cas++]=c1;
}
printf("%s",array);
return 0;
}
输入abc
第一个代码输出abc
第二个代码输出◆
这是为什么?

------解决方案--------------------
不要使用
while (条件)
更不要使用
while (组合条件)
要使用
while (1) {
 if (条件1) break;
 //...
 if (条件2) continue;
 //...
 if (条件3) return;
 //...
}
因为前两种写法在语言表达意思的层面上有二义性,只有第三种才忠实反映了程序流的实际情况。
典型如:
下面两段的语义都是当文件未结束时读字符
whlie (!feof(f)) {
 a=fgetc(f);
 //...
 b=fgetc(f);//可能此时已经feof了!
 //...
}
而这样写就没有问题:
whlie (1) {
 a=fgetc(f);
 if (feof(f)) break;
 //...
 b=fgetc(f);
 if (feof(f)) break;
 //...
}
类似的例子还可以举很多。

------解决方案--------------------
先讲第一个,getchar()这个函数返回的是int,你用char会产生截断,c1==EOF这句,char和int比较也是不合适的,while循环退出后没有在array这个数组的末尾加空字符,所以不是字符串,输出也会出问题。第二个的话,c1=getchar()!=EOF,这句的意思是把getchar()和EOF的比较结果赋值给c1,结果当然是true或者false,因为=是先运算右边的