第六章:指针
- 1字节=8位,1字=16/32/64位
- 对指针解引用之前,需要检查确认其并未NULL指针
*(int * ) 100 = 25;
把内存为100的地方赋值为25- 前缀++a:先自增后返回值; 后缀a++:先返回值后自增
- *,++这两个操作符都是从右向左结合,且后者优先级更高
char ch = 'a';
char *cp = &ch;
*(cp + 1) = 'f';
*++cp: 'f' 且cp指向‘f'
*cp++: 'a' 且cp指向’f'
++*cp: 'b' 且cp指向‘b'
(*cp)++:'b'且cp指向’b'
++*++cp:'e'且cp指向’e'
++*cp++:'b'且cp指向‘f'
#include <stdio.h>
#include <assert.h>
#define True 1
#define False 0;
size_t mystrlen(char * string)
{
int length = 0;
while(*string++ != '\0') { length ++; }
return length;
}
int find_char(char **strings, char value)
{
char *string = NULL;
while( (string = *strings++) != NULL)
{
while(*string != '\0')
{
if(*string++ == value) { return True; }
}
}
return False;
}
int find_char_onetimes(char **strings, char value)
{
assert(strings != NULL);
while(*strings != NULL)
{
while (**strings != '\0')
{
if(*(*strings)++ == value) { return True; }
}
strings ++;
}
return False;
}
int main(void)
{
char *s = "hello";
size_t ans1 = mystrlen(s);
printf("%d\n",ans1);
char *a[] = {"ye","no",NULL};
int ans2 = find_char(a,'y');
printf("%d\n",ans2);
int ans3 = find_char(a,'k');
printf("%d\n",ans3);
int ans4 = find_char_onetimes(a,'k');
printf("%d\n",ans4);
int ans5 = find_char_onetimes(a,'y');
printf("%d\n",ans5);
return 0;
}