This is C++

이것이 C++이다.

제 2장 namespace 두번째와 세번째 강의

template

C++에서 overloading이 가능한 것은 name magling기능 덕분이다.

이름은 같지만 다른 type의 function들은 각각 다른 이름도 부여되어 있다

r value reference

format 방법 3가지.

Assignment initialization, copy initialization, Uniform initialization,

return pointer

함수 안에서 malloc으로 입력 받거나

C로 자료구조를 만들면서 불편했던 점.
structure에는 상속 기능 + constructor 기능이 없다.
즉 어떤 instance를 만들 때, declare하고 format(define)을 따로 해야한다.
가령

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
typedef struct Node
{
    int data;
    struct Node* p_next;
} Node;

void NodeInit(Node* node)
{
    node->data = 0;
    node->p_next = NULL;
}

int main()
{
    Node s
    return 0;
}
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
// 만약 data의 type이 int가 아닌 다른 2차원 평면에서의 좌표 struct 라고 하자. 
// constructor(생성자)가 없기 때문에 malloc을 통해서 좌표와 Node를 따로 따로 할당해줘야한다.
// C++에서는 initializer list에서 base class(abstract class)의 private 변수도 같이 return

#include <stdio.h>
#include <Windows.h>
#include <assert.h>

// 2D point type
typedef struct Coordinate2D {
    int x_;
    int y_;
}Coordinate2D;

// 
typedef struct node {
    Coordinate2D* p_coordinate;
    struct node* p_next_node;
}Node;

// 
typedef struct LinkedList {
    Node *p_current_node;
    Node *p_header_node;
}LinkedList;

// pointer를 return 하려면, const를 써야지 return 할 수 있지 않나?
// 이곳의 const의 유무가 어떤 역할인지..
// malloc에서 주는 변수는 heep memory에 있으므로, return해도 해제되지 않는군.
// literal도 함수 stack에 저장되지 않으므로, char* name = "blabla" return 해도 되는 군!
// literal과 dynamic allocated pointer는 return해도 됨.
Node* NodeConstructor(const int x, const int y)
{
    Node*         const p_new_node   = (Node*)malloc(sizeof(Node));
    Coordinate2D* const p_2d         = (Coordinate2D*)malloc(sizeof(Coordinate2D));
    
    assert(p_new_node != NULL);
    assert(p_2d       != NULL);

    p_new_node->p_coordinate = p_2d;
    p_new_node->p_coordinate->x_ = x;
    p_new_node->p_coordinate->y_ = y;
    p_new_node->p_next_node = NULL;

    return p_new_node;
}

// 
void ListInit(LinkedList* list)
{
    Node* p_dummy_node = NodeConstructor(/*x = */0, /*y = */ 0);
    list->p_current_node = NULL;
    list->p_header_node = p_dummy_node;
}

// TODO
// x축 오름차순 
// y축 내림차순


void PrintList(LinkedList* list)
{
    list->p_current_node = list->p_header_node;
    while (list->p_current_node != NULL)
    {
        printf("x coordinate : %d \n", list->p_current_node->p_coordinate->x_);
        printf("y coordinate : %d \n", list->p_current_node->p_coordinate->y_);
        printf("               | \n");
        printf("               V \n");
        list->p_current_node = list->p_current_node->p_next_node;
    };
    printf("             NULL\n\n");
}

// dumy가 깨지는 거 아님? dumpy 다음에 붙히면 되네.
void AppendFront(LinkedList* list, Node* node)
{
    node->p_next_node = list->p_header_node->p_next_node;
    list->p_header_node->p_next_node = node;
}

void Insert();


void DeleteList(LinkedList* list)
{
    list->p_current_node = list->p_header_node;
    while (list->p_current_node != NULL)
    {
        Node* p_delete_node  = list->p_current_node;
        list->p_current_node = list->p_current_node->p_next_node;
        free(p_delete_node->p_coordinate);
        free(p_delete_node);
    };
}


int main()
{
    LinkedList coordinate_list; // 궂이 이렇게 format을 해야 하는지는 의문,
    ListInit(&coordinate_list); // constructor로 생성할 때, format해서 return 해주면 안 됨? Time_T 처럼.
    PrintList(&coordinate_list);
    Node* new_nodes[5];
    Node* p_new_node = NodeConstructor(1, 6);
    AppendFront(&coordinate_list, p_new_node);
    PrintList(&coordinate_list);
    DeleteList(&coordinate_list);
    return 0;
}

initializer list로 abstract class(virtual method)

return const value
return reference

SBCS, MBCS, WBCS

Comments