250x250
Rainbow๐ŸŒˆCoder
My dev Note๐Ÿ“’
Rainbow๐ŸŒˆCoder
์ „์ฒด ๋ฐฉ๋ฌธ์ž
์˜ค๋Š˜
์–ด์ œ
  • ๋ถ„๋ฅ˜ ์ „์ฒด๋ณด๊ธฐ (411)
    • ๊ณต์ง€์‚ฌํ•ญ (0)
    • Debugger (10)
      • Visual Studio Debugger (1)
      • Chrome DevTools (3)
      • Visual Studio Code Debugger (4)
      • eclipse (1)
      • intelliJ (1)
    • OOP (2)
      • OOP (2)
    • TypeScript (54)
      • ํƒ€์ž…์Šคํฌ๋ฆฝํŠธ TypeScript (54)
    • Javascript (87)
      • Javascript (45)
      • Node.js (19)
      • React (5)
      • FE ๊ฐœ๋ฐœํ™˜๊ฒฝ์„ค์ • (3)
      • React์™€ Node ๊ฐ™์ด ๋•Œ๋ ค์žก๊ธฐ (6)
      • next.js (2)
      • pixi.js (7)
    • ๋งˆํฌ์—… (23)
      • Html & Css (23)
    • C# (80)
      • C# (12)
      • ์ด๊ฒƒ์ด C#์ด๋‹ค (68)
    • C++ (30)
      • c++ (27)
      • win api (3)
    • Unity (18)
      • Unity(๊ธฐ์ดˆ) (8)
      • Unity(C#์ค‘๊ธ‰) (5)
      • ์œ ๋‹ˆํ‹ฐ ํฌํ†ค(๋„คํŠธ์›Œํฌ) (4)
      • unity c# MyCode (1)
    • Java & Spring (29)
      • Java (11)
      • ์Šคํ”„๋ง (8)
      • Java Algorithm (9)
      • Javs Data Structures (1)
    • ์ž๋ฃŒ๊ตฌ์กฐ์™€ ์•Œ๊ณ ๋ฆฌ์ฆ˜ (15)
      • ์ž๋ฃŒ๊ตฌ์กฐ (5)
      • ์•Œ๊ณ ๋ฆฌ์ฆ˜ (10)
    • ํ˜•์ƒ๊ด€๋ฆฌ (15)
      • Git (11)
      • ์†Œ์ŠคํŠธ๋ฆฌ (3)
    • ๊ทธ๋ž˜ํ”ฝ์Šค (7)
      • WebGl (7)
    • AWS (3)
      • aws (3)
    • ๋ฆฌ๋ˆ…์Šค (5)
      • ๋ฆฌ๋ˆ…์Šค (5)
    • ์ฑ… ๋ฆฌ๋ทฐ (13)
      • ํด๋ฆฐ์ฝ”๋“œ(์ฑ…๋ฆฌ๋ทฐ) (3)
      • ์œ ์ง€๋ณด์ˆ˜๊ฐ€๋Šฅํ•œ์ฝ”๋”ฉ์˜๊ธฐ์ˆ C#ํŽธ(์ฑ…๋ฆฌ๋ทฐ) (1)
      • ๋ฆฌํŒฉํ† ๋ง(์ž๋ฐ”์Šคํฌ๋ฆฝํŠธํŒ) (9)
    • Server (2)
      • ๊ฒŒ์ž„ ์„œ๋ฒ„(๋„คํŠธ์›Œํฌ, ๋ฉ€ํ‹ฐ์“ฐ๋ ˆ๋“œ,OS) (2)
    • ์„ค๊ณ„, ์•„ํ‚คํ…์ณ (4)
    • ํŒŒ์ด์ฌ (5)
    • ๋””์ž์ธํŒจํ„ด (2)
    • mocha (2)
    • Jest (1)
    • Spine (1)
    • ์ธ๊ณต์ง€๋Šฅ (1)
      • ํ˜ผ์ž๊ณต๋ถ€ํ•˜๋Š”๋จธ์‹ ๋Ÿฌ๋‹+๋”ฅ๋Ÿฌ๋‹ (1)

๋ธ”๋กœ๊ทธ ๋ฉ”๋‰ด

  • ํ™ˆ
  • ํƒœ๊ทธ
  • ๋ฐฉ๋ช…๋ก

๊ณต์ง€์‚ฌํ•ญ

์ธ๊ธฐ ๊ธ€

ํƒœ๊ทธ

  • ์œ„์ž„
  • ์ปดํฌ์ง€์…˜
  • MySQL
  • ใ…ฃใ„ท

์ตœ๊ทผ ๋Œ“๊ธ€

์ตœ๊ทผ ๊ธ€

ํ‹ฐ์Šคํ† ๋ฆฌ

hELLO ยท Designed By ์ •์ƒ์šฐ.
Rainbow๐ŸŒˆCoder

My dev Note๐Ÿ“’

[ํƒ€์ž…์Šคํฌ๋ฆฝํŠธ] ์ œ๋„ˆ๋ ˆ์ดํ„ฐ, ๋ฐ˜๋ณต์ž(iterator) ์ถ”๋ก ๊ณผ ๋ช…์‹œ
TypeScript/ํƒ€์ž…์Šคํฌ๋ฆฝํŠธ TypeScript

[ํƒ€์ž…์Šคํฌ๋ฆฝํŠธ] ์ œ๋„ˆ๋ ˆ์ดํ„ฐ, ๋ฐ˜๋ณต์ž(iterator) ์ถ”๋ก ๊ณผ ๋ช…์‹œ

2022. 4. 20. 12:11
728x90

Generator

ํƒ€์ž…์Šคํฌ๋ฆฝํŠธ๋Š” Generator๊ฐ€ yield๋ฅผ ํ†ตํ•ด ๋ฐฉ์ถœํ•œ ๊ฐ’์„ ํ† ๋Œ€๋กœ ๋ฐ˜๋ณต์ž์˜ ํƒ€์ž…์„ ์ถ”๋ก ํ•œ๋‹ค.

์ œ๋„ˆ๋ ˆ์ดํ„ฐ ํ•จ์ˆ˜

๋ฐ˜๋ณต์ž(iterator)์™€ ์ œ๋„ˆ๋ ˆ์ดํ„ฐ๋Š” ์ƒ์ƒ๊ด€๊ณ„๋‹ค.

์ œ๋„ˆ๋ ˆ์ดํ„ฐ๋กœ ๊ฐ’์˜ ์ŠคํŠธ๋ฆผ์„ ์ƒ์„ฑํ•  ์ˆ˜ ์žˆ๊ณ  ๋ฐ˜๋ณต์ž๋กœ ์ƒ์„ฑ๋œ ๊ฐ’์„ ์†Œ๋น„ํ•  ์ˆ˜ ์žˆ๊ธฐ ๋•Œ๋ฌธ์ด๋‹ค.

์ดํ„ฐ๋Ÿฌ๋ธ”(iterable;๋ฐ˜๋ณตํ•  ์ˆ˜ ์žˆ๋Š”)Symbol.iterator ๋ผ๋Š” ํ”„๋กœํผํ‹ฐ(๋ฐ˜๋ณต์ž๋ฅผ ๋ฐ˜ํ™˜ํ•˜๋Š” ํ•จ์ˆ˜)๋ฅผ ๊ฐ€์ง„ ๋ชจ๋“  ๊ฐ์ฒด

๋ฐ˜๋ณต์ž(iterator)next๋ผ๋Š” ๋ฉ”์„œ๋“œ(value, done ๋‘ ํ”„๋กœํผํ‹ฐ๋ฅผ ๊ฐ€์ง„ ๊ฐ์ฒด๋ฅผ ๋ฐ˜ํ™˜)๋ฅผ ์ •์˜ํ•œ ๊ฐ์ฒด

 

์ž๋ฐ”์Šคํฌ๋ฆฝํŠธ์—์„œ ์ œ๋„ˆ๋ ˆ์ดํ„ฐ ํ•จ์ˆ˜๋ฅผ ํ˜ธ์ถœํ•˜๋ฉด ์ดํ„ฐ๋Ÿฌ๋ธ” ๋ฐ˜๋ณต์ž(IterableIterator)๊ฐ€ ๋ฐ˜ํ™˜๋œ๋‹ค.

ํƒ€์ž…์Šคํฌ๋ฆฝํŠธ์—์„œ๋„ ์ง€์›ํ•œ๋‹ค.

//๋‹ค์Œ ํ”ผ๋ณด๋‚˜์น˜ ์ˆซ์ž๋ฅผ ๊ณ„์‚ฐํ•˜๊ธฐ ์œ„ํ•ด a์— b๋ฅผ, b์— a+b๋ฅผ ํ•œ๋ฒˆ์— ๋‹ค์‹œ ํ• ๋‹นํ•œ๋‹ค.

function* createFibonacciGenerator() {
  let a = 0;
  let b = 1;
  while (true) {
    yield a;
    [a, b] = [b, a + b];
  }
}

let fiboancciGenerator = createFibonacciGenerator();
                                        //IterableIterator<number>
console.log(fiboancciGenerator.next()); //{ value: 0, done: false }
console.log(fiboancciGenerator.next()); //{ value: 1, done: false }
console.log(fiboancciGenerator.next()); //{ value: 1, done: false }
console.log(fiboancciGenerator.next()); //{ value: 2, done: false }
console.log(fiboancciGenerator.next()); //{ value: 3, done: false }
console.log(fiboancciGenerator.next()); //{ value: 5, done: false }
console.log(fiboancciGenerator.next()); //{ value: 8, done: false }
console.log(fiboancciGenerator.next()); //{ value: 13, done: false }

createFibonacciGenerator ๋ฅผ ํ˜ธ์ถœํ•˜๋ฉด Symbol.iterator ํ”„๋กœํผํ‹ฐ์™€ next ๋ฉ”์„œ๋“œ๋ฅผ ๋ชจ๋‘ ์ •์˜ํ•œ ๊ฐ’์„ ์–ป๊ฒŒ ๋œ๋‹ค. ์ฆ‰, ์ดํ„ฐ๋Ÿฌ๋ธ”๊ณผ ๋ฐ˜๋ณต์ž ๋‘ ๊ฐ€์ง€๊ฐ€ ๊ฒฐํ•ฉ๋œ ์ œ๋„ˆ๋ ˆ์ดํ„ฐ๊ฐ€ ๋ฐ˜ํ™˜๋œ๋‹ค.

์œ„ ์ฝ”๋“œ์˜ createFibonacciGenerator ํ•จ์ˆ˜๋Š” IterableIterator์„ ๋ฐ˜ํ™˜ํ•˜๊ณ , ์ด ์ œ๋„ˆ๋ ˆ์ดํ„ฐ์— next๋ฅผ ํ˜ธ์ถœํ•  ๋•Œ๋งˆ๋‹ค ๋‹ค์Œ ํ”ผ๋ณด๋‚˜์น˜ ๊ฐ’์„ ๊ณ„์‚ฐํ•ด์„œ ๊ฒฐ๊ณผ๋ฅผ ๋ฐฉ์ถœํ•œ๋‹ค. ํƒ€์ž…์Šคํฌ๋ฆฝํŠธ๋Š” Generator๊ฐ€ yield๋ฅผ ํ†ตํ•ด ๋ฐฉ์ถœํ•œ ๊ฐ’์„ ํ† ๋Œ€๋กœ ๋ฐ˜๋ณต์ž์˜ ํƒ€์ž…์„ ์ถ”๋ก ํ•œ๋‹ค.

fiboancciGenerator๋ฅผ ํ˜ธ์ถœํ•˜๋ฉด Symbol.iterator ํ”„๋กœํผํ‹ฐ์™€ next ๋ฉ”์„œ๋“œ๋ฅผ ๋ชจ๋‘ ์ •์˜ํ•œ ๊ฐ’์„ ์–ป๊ฒŒ ๋œ๋‹ค. ์ฆ‰, ์ดํ„ฐ๋Ÿฌ๋ธ”๊ณผ ๋ฐ˜๋ณต์ž ๋‘๊ฐ€์ง€๊ฐ€ ๊ฒฐํ•ฉ๋œ ์ œ๋„ˆ๋ ˆ์ดํ„ฐ๊ฐ€ ๋ฐ˜ํ™˜๋œ๋‹ค.

๋‹ค์Œ ์˜ˆ์ฒ˜๋Ÿผ IterableIterator ์—์„œ ๋ฐฉ์ถœํ•˜๋Š” ํƒ€์ž…์„ ๊ฐ์‹ธ์„œ ์ œ๋„ˆ๋ ˆ์ดํ„ฐ ๋ฐ˜ํ™˜ ํƒ€์ž…์„ ๋ช…์‹œํ•˜๋Š” ๋ฐฉ๋ฒ•๋„ ์žˆ๋‹ค.

์ง์ ‘ ๋ช…์‹œํ•  ์ˆ˜๋„ ์žˆ๋‹ค.

 
function* createNumbers(): IterableIterator<number> {
    let n = 0;
    while( 1 ){
        yield n++;
    }
}
let numbers = creatNumbers();
numbers.next() // {value: 0, done: false}
numbers.next() // {value: 1, done: false}
numbers.next() // {value: 2, done: false}

 

๋ฐ˜๋ณต์ž(iterator)์™€ ์ œ๋„ˆ๋ ˆ์ดํ„ฐ(Generator๋Š” ํ˜ธ์ถœ๋  ๋•Œ Iterator๋ฅผ ์ž๋™์œผ๋กœ ์ƒ์„ฑํ•˜๋Š” ํŠน์ˆ˜ ํ•จ์ˆ˜)๋Š” ์ƒ์ƒ๊ด€๊ณ„๋‹ค.

์ œ๋„ˆ๋ ˆ์ดํ„ฐ๋กœ ๊ฐ’์˜ ์ŠคํŠธ๋ฆผ์„ ์ƒ์„ฑํ•  ์ˆ˜ ์žˆ๊ณ  ๋ฐ˜๋ณต์ž๋กœ ์ƒ์„ฑ๋œ ๊ฐ’์„ ์†Œ๋น„ํ•  ์ˆ˜ ์žˆ๊ธฐ ๋•Œ๋ฌธ์ด๋‹ค.

 

 

์ดํ„ฐ๋Ÿฌ๋ธ”(iterable;๋ฐ˜๋ณตํ•  ์ˆ˜ ์žˆ๋Š”)

Symbol.iterator ๋ผ๋Š” ํ”„๋กœํผํ‹ฐ(๋ฐ˜๋ณต์ž๋ฅผ ๋ฐ˜ํ™˜ํ•˜๋Š” ํ•จ์ˆ˜)๋ฅผ ๊ฐ€์ง„ ๋ชจ๋“  ๊ฐ์ฒด

- Symbol.Iterator ๋ฉ”์„œ๋“œ๊ฐ€ ๊ตฌํ˜„๋˜์–ด ์žˆ์–ด์•ผ ํ•œ๋‹ค. ์ฆ‰, ๊ฐ์ฒด๊ฐ€ Symbol.iterator ํ‚ค๋ฅผ ๊ฐ–๋Š” ์†์„ฑ์ด ์žˆ์–ด์•ผ ํ•จ
- Symbol.Iterator ๋Š” Iterator์„ ๋ฐ˜ํ™˜ํ•ด์•ผ ํ•œ๋‹ค

 

๋ฐ˜๋ณต์ž(iterator)

next๋ผ๋Š” ๋ฉ”์„œ๋“œ(value, done ๋‘ ํ”„๋กœํผํ‹ฐ๋ฅผ ๊ฐ€์ง„ ๊ฐ์ฒด๋ฅผ ๋ฐ˜ํ™˜)๋ฅผ ์ •์˜ํ•œ ๊ฐ์ฒด

- next ๋ฉ”์„œ๋“œ๋ฅผ ๊ฐ€์ง„๋‹ค
- next ๋ฉ”์„œ๋“œ๋Š” value์™€ done ์†์„ฑ์„ ๊ฐ€์ง„ ๊ฐ์ฒด๋ฅผ ๋ฐ˜ํ™˜ํ•œ๋‹ค.
- ์ž‘์—…์ด ๋๋‚˜๋ฉด done์€ true๊ฐ€ ๋œ๋‹ค.

 

 

๊ฐ€๋ น createFibonacciGenerator ํ•จ์ˆ˜๋ฅผ ํ˜ธ์ถœํ•˜๋ฉด Symbol.iterator ํ”„๋กœํผํ‹ฐ์™€ next ๋ฉ”์„œ๋“œ๋ฅผ ๋ชจ๋‘ ์ •์˜ํ•œ ๊ฐ’์„ ์–ป๊ฒŒ ๋œ๋‹ค. ์ฆ‰, ์ดํ„ฐ๋Ÿฌ๋ธ”๊ณผ ๋ฐ˜๋ณต์ž ๋‘ ๊ฐ€์ง€๊ฐ€ ๊ฒฐํ•ฉ๋œ ์ œ๋„ˆ๋ ˆ์ดํ„ฐ๊ฐ€ ๋ฐ˜ํ™˜๋œ๋‹ค.

Symbol.iterator์™€ next๋ฅผ ๊ตฌํ˜„ํ•˜๋Š” ๊ฐ์ฒด(๋˜๋Š” ํด๋ž˜์Šค)๋ฅผ ๋งŒ๋“ค์–ด ๋ฐ˜๋ณต์ž๋‚˜ ์ดํ„ฐ๋Ÿฌ๋ธ”์„ ์ง์ ‘ ์ •์˜ํ•  ์ˆ˜ ์žˆ๋‹ค. ๋‹ค์Œ์€ 1์—์„œ 10๊นŒ์ง€์˜ ์ˆซ์ž๋ฅผ ๋ฐ˜๋ณตํ•˜๋Š” ๋ฐ˜๋ณต์ž๋ฅผ ์ •์˜ํ•˜๋Š” ์˜ˆ๋‹ค.

  let numbers = {
    *[Symbol.iterator]() {
      for (let n = 1; n <= 10; n++) {
        yield n;
      }
    },
  };

์‚ฌ์šฉ์ž ์ •์˜ iterable

Symbol.iterator์™€ next๋ฅผ ๊ตฌํ˜„ํ•˜๋Š” ๊ฐ์ฒด(๋˜๋Š” ํด๋ž˜์Šค)๋ฅผ ๋งŒ๋“ค์–ด ๋ฐ˜๋ณต์ž๋‚˜ ์ดํ„ฐ๋Ÿฌ๋ธ”์„ ์ง์ ‘ ์ •์˜ํ•  ์ˆ˜ ์žˆ๋‹ค.

๋‹ค์Œ์€ 1์—์„œ 10๊นŒ์ง€์˜ ์ˆซ์ž๋ฅผ ๋ฐ˜๋ณตํ•˜๋Š” ๋ฐ˜๋ณต์ž๋ฅผ ์ •์˜ํ•˜๋Š” ์˜ˆ

์ด์™€ ๊ฐ™์ด ์ž์‹ ์˜ ๋ฐ˜๋ณต๊ฐ€๋Šฅ ๊ฐ์ฒด๋ฅผ ๋งŒ๋“ค ์ˆ˜ ์žˆ๋‹ค

let numbers = {
  *[Symbol.iterator]() {
    for (let n = 1; n <= 10; n++) {
      yield n;
    }
  },
};

console.log([...numbers]);
<์ถœ๋ ฅ>
[
  1, 2, 3, 4,  5,
  6, 7, 8, 9, 10
]

 

//์ปค์Šคํ…€ ๋ฐ˜๋ณต์ž
let numbers = {
  *[Symbol.iterator](){
    for(let n =1;n <= 10; n++){
      yield n;
    }
  }
}
์ด๋Ÿฌํ•œ ์‚ฌ์šฉ์ž ์ •์˜ ๋ฐ˜๋ณต๊ฐ€๋Šฅ ๊ฐ์ฒด์— ๋Œ€ํ•ด์„œ๋„ ํƒ€์ž…์Šคํฌ๋ฆฝํŠธ๊ฐ€ ์ œ๋„ˆ๋ ˆ์ดํ„ฐ ๋ฐ˜ํ™˜ ํƒ€์ž…์„ ์ถ”๋ก 

 

 

์ง์ ‘ ๋ช…์‹œ๋„ ๊ฐ€๋Šฅ

let numbers = {
  *[Symbol.iterator](): IterableIterator<number> {
    for (let n = 1; n <= 10; n++) {
      yield n;
    }
  },
};

for (let value of numbers) {
  console.log(value);
}

<์ถœ๋ ฅ>
1
2
3
4
5
6
7
8
9
10
 

 

<์ตœ์ข… ์ ๊ฒ€>

let numbers = {
  *[Symbol.iterator](): IterableIterator<number> {
    for (let n = 1; n <= 10; n++) {
      yield n;
    }
  },
};

//for-of๋กœ ๋ฐ˜๋ณต์ž ๋ฐ˜๋ณตํ•˜๊ธฐ
for (let a of numbers) {
  console.log(a);
}
<์ถœ๋ ฅ>
1
2
3
4
5
6
7
8
9
10

//๋ฐ˜๋ณต์ž ์Šคํ”„๋ ˆ๋“œ
let allNumbers = [...numbers];
console.log(allNumbers);

<์ถœ๋ ฅ>
[
  1, 2, 3, 4,  5,
  6, 7, 8, 9, 10
]

//๋ฐ˜๋ณต์ž ๊ตฌ์กฐ ๋ถ„ํ•ด ํ• ๋‹น(destructure)
let [one, two, ...rest] = numbers;
console.log(one);
console.log(two);
console.log(rest);

<์ถœ๋ ฅ>
1
2
[
  3, 4, 5,  6,
  7, 8, 9, 10
]

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

728x90

'TypeScript > ํƒ€์ž…์Šคํฌ๋ฆฝํŠธ TypeScript' ์นดํ…Œ๊ณ ๋ฆฌ์˜ ๋‹ค๋ฅธ ๊ธ€

[ํƒ€์ž…์Šคํฌ๋ฆฝํŠธ] ๋ฌธ๋งฅ์  ํƒ€์ž…ํ™”  (0) 2022.04.20
[ํƒ€์ž…์Šคํฌ๋ฆฝํŠธ] ํ˜ธ์ถœ ์‹œ๊ทธ๋‹ˆ์ฒ˜  (0) 2022.04.20
[ํƒ€์ž…์Šคํฌ๋ฆฝํŠธ] ์ปคํ”ผ๋จธ์‹  ํด๋ž˜์Šค๋งŒ๋“ค๊ธฐ ์‹ค์Šต  (0) 2022.04.19
[ํƒ€์ž…์Šคํฌ๋ฆฝํŠธ] ์ œ๋„ˆ๋ ˆ์ดํ„ฐ ์ง€์›, ๋ช…์‹œ  (0) 2022.04.19
[ํƒ€์ž…์Šคํฌ๋ฆฝํŠธ] this ๊ด€๋ จ ์˜ค๋ฅ˜  (0) 2022.04.19
    'TypeScript/ํƒ€์ž…์Šคํฌ๋ฆฝํŠธ TypeScript' ์นดํ…Œ๊ณ ๋ฆฌ์˜ ๋‹ค๋ฅธ ๊ธ€
    • [ํƒ€์ž…์Šคํฌ๋ฆฝํŠธ] ๋ฌธ๋งฅ์  ํƒ€์ž…ํ™”
    • [ํƒ€์ž…์Šคํฌ๋ฆฝํŠธ] ํ˜ธ์ถœ ์‹œ๊ทธ๋‹ˆ์ฒ˜
    • [ํƒ€์ž…์Šคํฌ๋ฆฝํŠธ] ์ปคํ”ผ๋จธ์‹  ํด๋ž˜์Šค๋งŒ๋“ค๊ธฐ ์‹ค์Šต
    • [ํƒ€์ž…์Šคํฌ๋ฆฝํŠธ] ์ œ๋„ˆ๋ ˆ์ดํ„ฐ ์ง€์›, ๋ช…์‹œ
    Rainbow๐ŸŒˆCoder
    Rainbow๐ŸŒˆCoder
    ๋ชฐ๋ผ๋„ ๊ฒฐ๊ตญ์€ ์•„๋Š” ๊ฐœ๋ฐœ์ž, ๊ทธ๋Ÿฐ ์‚ฌ๋žŒ์ด ๋˜๊ธฐ ์œ„ํ•œ ๋งค์ผ์˜ ํ•œ๊ฑธ์Œ

    ํ‹ฐ์Šคํ† ๋ฆฌํˆด๋ฐ”