大端和小端:
小端:高位放在高地址,低位放在低地址。
大端:高位放在低地址,低位放在高地址。
windows系统中都采取的是小端存放,linux采取的是大端存放。
通过下面一个小的程序就可以判断当前的操作系统是采用大端还是小端存放的。
eg:
//判断是否为大小端
union
{
int a;
char b[2];
}c;
int main()
{
c.b[0]=10;
c.b[1]=1;
printf("%d\n",c.a);
}
运行结果为:
266
如果运行结果不为266,则说明采取的是大端存储。
程序分析:首先,b[0]对应的是低位,b[1]对应的是高位。而a和b采取的是共用体,即他们是共用的一段内存。所以a 当中存放的是 10 1 0 0;对应的二进制补码为:
00000000 00000000 00000001 00001010 转换为十进制就是:266
字符串分离函数:
//char*strtok(char*,const char*);
int main()
{
char a[50]="i,am.a student";
char b[20] = ",. ";
char *tok = NULL;
for(tok=strtok(a,b);tok!=NULL;
tok=strtok(NULL,b))
{
puts(tok);
}
//"i\0am\0a\0student";
return 0;
}
strtok函数先定义一个tok函数,将其指向0,防止野指针的出现,先将tok指向i,如果找到b字符串中的关键字,就用'\0'来替代其中的关键字,再用puts函数将tok输出,此时tok指向的是i,一直遇到\0就结束输出。再执行tok=strtok(NULL,b)),将指针指向下一个单词的开始,然后这样一直重复输出。知道tok指向\0。
小端:高位放在高地址,低位放在低地址。
大端:高位放在低地址,低位放在高地址。
windows系统中都采取的是小端存放,linux采取的是大端存放。
通过下面一个小的程序就可以判断当前的操作系统是采用大端还是小端存放的。
eg:
//判断是否为大小端
union
{
int a;
char b[2];
}c;
int main()
{
c.b[0]=10;
c.b[1]=1;
printf("%d\n",c.a);
}
运行结果为:
266
如果运行结果不为266,则说明采取的是大端存储。
程序分析:首先,b[0]对应的是低位,b[1]对应的是高位。而a和b采取的是共用体,即他们是共用的一段内存。所以a 当中存放的是 10 1 0 0;对应的二进制补码为:
00000000 00000000 00000001 00001010 转换为十进制就是:266
字符串分离函数:
//char*strtok(char*,const char*);
int main()
{
char a[50]="i,am.a student";
char b[20] = ",. ";
char *tok = NULL;
for(tok=strtok(a,b);tok!=NULL;
tok=strtok(NULL,b))
{
puts(tok);
}
//"i\0am\0a\0student";
return 0;
}
strtok函数先定义一个tok函数,将其指向0,防止野指针的出现,先将tok指向i,如果找到b字符串中的关键字,就用'\0'来替代其中的关键字,再用puts函数将tok输出,此时tok指向的是i,一直遇到\0就结束输出。再执行tok=strtok(NULL,b)),将指针指向下一个单词的开始,然后这样一直重复输出。知道tok指向\0。