-
Notifications
You must be signed in to change notification settings - Fork 0
/
alloc.c
117 lines (105 loc) · 2.91 KB
/
alloc.c
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
// Copyright (c) 2021. Lorem ipsum dolor sit amet, consectetur adipiscing elit.
// Morbi non lorem porttitor neque feugiat blandit. Ut vitae ipsum eget quam lacinia accumsan.
// Etiam sed turpis ac ipsum condimentum fringilla. Maecenas magna.
// Proin dapibus sapien vel ante. Aliquam erat volutpat. Pellentesque sagittis ligula eget metus.
// Vestibulum commodo. Ut rhoncus gravida arcu.
//
// Created by 75685 on 2021/8/12.
//
#include "stdio.h"
#include "malloc.h"
#define NULL 0
// 虽然数组没有a[n]这个元素,但是却可以引用这个元素的地址&a[n],
// 而且ANSI C标准也明确允许这种用法:数组中实际不存在的“溢界”元素的地址位于数组所占内存之后。
// 这个地址可以用来进行赋值和比较,但因为不存在a[n],所以引用该元素的值就是非法引用。
int main(int argc, char *argv[]) {
/*char *s;
int n;
s = (char *) malloc(50);
if (s == NULL) {
printf("OOM");
return -1;
}
scanf("%s", s);
for (n = 0; *s != '\0'; ++s) {
++n;
}
s = s - n;
free(s);
printf("%d", n);
*/
/* int i,*p;
p = (int *) malloc(8);
for (i = 0; i < 2; ++i, ++p) {
scanf("%d", p);
}
p = p - 2;
for (i = 0; i < 2; ++i, ++p)
printf("%d \t", *p);
p -= 2;
// 释放内存的语句free(p) `中的参数p,必须是申请到的动态内存的首地址。
free(p);*/
// char *p,*q;
// p = q = (char *) malloc(100);
// scanf("%s", q);
// while (*p != '\0')
// p++;
// printf("%lld\n", p - q);
// // 使用free时要注意,指向同一个目标的指针只能释放一次,因为释放后另一个已经是空指针,再free就要出错
// free(q);
/*float *p, *q;
p = q = (float *) malloc(10 * sizeof(float));
if (q == NULL) {
printf("error");
return -1;
}
for (int i = 0; i < 10; i++,q++)
scanf("%f", q);
float min = 0xffffff, sum = 0;
for (int i = 0; i < 10; ++i, ++p) {
sum += *p;
if (min > *p) {
min = *p;
}
}
printf("min: %f,sum: %f", min, sum);*/
// char *p, *q;
// printf("%s\t%s\n", p, q);
// printf(p, q);
// char s[] = "abcd";
// int i = 4;
// printf("%s\n", s);
// for (i = 0; i < 4; i++) {
// printf("%u ", s[i]);
// }
// printf("\n");
// 一维数据越界错误
// int i = 0, a[5];
// // index of out bound
// for (i = 1; i <= 5; i++) {
// a[i] = i;
// }
// // c[4] = '\n' error
// char c[] = "abcde";
// char b[6];
// // error
// for (i = 0; i < 6; i++)
// b[i] = c[i];
//
// printf(b);
// printf("\n");
int i = 0;
char a[] = "How are you?", b[13];
while (a[i] != '\0') {
b[i] = a[i];
++i;
}
printf("%d", i);
b[i] = '\0';
i = -1;
while (i++, b[i] != '\0') {
printf("%c ", b[i]);
}
printf("\n");
return 0;
}