36. ์ต๋ช…๋ฉ”์†Œ๋“œ

2022. 4. 8. 09:13ยท๐Ÿ’ป Programming Language/C#
  • ์ต๋ช…๋ฉ”์†Œ๋“œ(Anonymous Method) : ์ด๋ฆ„์ด ์—†๋Š” ๋ฉ”์†Œ๋“œ

์„ ์–ธํ˜•์‹

๋ธ๋ฆฌ๊ฒŒ์ดํŠธ ์ธ์Šคํ„ด์Šค๋ช… = delegate(๋งค๊ฐœ๋ณ€์ˆ˜)
                    {
                        ์‹คํ–‰์ฝ”๋“œ ... 
                    }

์‚ฌ์šฉ ์˜ˆ์ œ ์ฝ”๋“œ

using System.Collections;

namespace AnonymousMethodEx
{
    delegate int CalDelegate(int x, int y);
    class Program
    {
        static void Main(string[] args)
        {
            CalDelegate cd;
            cd = delegate (int x, int y)
                {
                    return x * y;
                }; // => ์ต๋ช…๋ฉ”์†Œ๋“œ ํ˜•ํƒœ (์ด๋ฆ„์ด ์—†์Œ)
                    // ๋‹จ ๋Œ€๋ฆฌ์ž์˜ ํ˜•์‹๊ณผ ๊ฐ™์€ ํ˜•์‹์„ ์จ์•ผํ•œ๋‹ค.
                     // ๊ณ ๋ คํ•ด์•ผ ํ•  ํ˜•์‹์€ ๋ฐ˜ํ™˜ํƒ€์ž…, ์ธ์žํƒ€์ž…, ์ธ์ž์ˆ˜๊ฐ€ ์žˆ๋‹ค.

            Console.WriteLine($"{cd(10, 20)}");
        }
    }
}
Output

200
  • delegate๋Š” ์ธ์Šคํ„ด์Šค๋ฅผ ๋งŒ๋“ค ์ˆ˜ ์žˆ๋Š” ํด๋ž˜์Šค์ฒ˜๋Ÿผ ๋™์ž‘์„ ํ•˜๊ธฐ ๋•Œ๋ฌธ์— ํด๋ž˜์Šค ๋ฐ–์œผ๋กœ ๋นผ์„œ ์ž‘์„ฑํ•˜๋Š”๊ฒŒ ์ผ๋ฐ˜์ ์ด์ง€๋งŒ ์ƒํ™ฉ์— ๋”ฐ๋ผ์„œ ํด๋ž˜์Šค ๋‚ด๋ถ€์— ์ž‘์„ฑํ•˜๋Š” ๊ฒฝ์šฐ๋„ ์กด์žฌํ•œ๋‹ค.

์ต๋ช…๋ฉ”์†Œ๋“œ์˜ ํ™œ์šฉ(feat. Bubble Sort)

using System.Collections;

namespace AnonymousMethodEx
{
    delegate int SelectSort(int x, int y);
    class Program
    {    
        static void BSort(int[] arr, SelectSort ss)
        {
            int temp = 0;
            for (int i = 0; i < arr.Length - 1; i++)
            {
                for (int j = 0; j < arr.Length - (i+1); j++)
                {
                    if (ss(arr[j],arr[j+1]) > 0)
                    {
                        temp = arr[j];
                        arr[j] = arr[j+1];
                        arr[j+1] = temp;
                    }

                }
            }
        }
        static void Main(string[] args)
        {
            int[] array = { 2, 4, 1, 10, 7 };

            // ์ต๋ช…ํ•จ์ˆ˜๋ฅผ ์ด์šฉํ•ด ๋ธ๋ฆฌ๊ฒŒ์ดํŠธ๋ฅผ ์„ ์–ธํ•˜๊ธฐ.(์˜ค๋ฆ„์ฐจ์ˆœ)
            SelectSort ascend;
            ascend = delegate(int x, int y){
                if (x > y) return 1;
                else if (x == y) return 0;
                else return -1;
            };

            BSort(array, ascend);

            Console.WriteLine("์˜ค๋ฆ„์ฐจ์ˆœ : ");
            foreach (int x in array)
            {
                Console.Write($"{x} ");
            }
            Console.WriteLine();

            // ์ต๋ช…ํ•จ์ˆ˜๋ฅผ ์ด์šฉํ•ด ๋ธ๋ฆฌ๊ฒŒ์ดํŠธ๋ฅผ ์„ ์–ธํ•˜๊ธฐ.(๋‚ด๋ฆผ์ฐจ์ˆœ)
            SelectSort descend;
            descend = delegate (int x, int y) {
                if (x < y) return 1;
                else if (x == y) return 0;
                else return -1;
            };

            BSort(array, descend);

            Console.WriteLine("๋‚ด๋ฆผ์ฐจ์ˆœ : ");
            foreach (int x in array)
            {
                Console.Write($"{x} ");
            }
            Console.WriteLine();

            // ๋” ์ข‹์€ ๋ฐฉ๋ฒ•์œผ๋กœ ์ „๋‹ฌํ•˜๋Š” ๋ฉ”์†Œ๋“œ์—์„œ ๋ฐ”๋กœ ์ž‘์„ฑํ•  ์ˆ˜ ์žˆ์Œ
            int[] array2 = { 3, 2, 4, 1, 10, 7, 21, 42, 5, 13 };

            BSort(array2, delegate(int x, int y)
            {
                if (x > y) return 1;
                else if (x == y) return 0;
                else return -1;
            });

            Console.WriteLine("๋ฉ”์†Œ๋“œ์˜ ์ธ์ž์—์„œ ์„ ์–ธํ•œ ์ต๋ช… ๋ฉ”์†Œ๋“œ ์˜ค๋ฆ„์ฐจ์ˆœ : ");
            foreach (int x in array2)
            {
                Console.Write($"{x} ");
            }
            Console.WriteLine();

        }
    }
}
Output

์˜ค๋ฆ„์ฐจ์ˆœ :
1 2 4 7 10
๋‚ด๋ฆผ์ฐจ์ˆœ :
10 7 4 2 1
๋ฉ”์†Œ๋“œ์˜ ์ธ์ž์—์„œ ์„ ์–ธํ•œ ์ต๋ช… ๋ฉ”์†Œ๋“œ ์˜ค๋ฆ„์ฐจ์ˆœ :
1 2 3 4 5 7 10 13 21 42
  • ์ต๋ช…ํ•จ์ˆ˜๋Š” ๋‹ค์–‘ํ•˜๊ฒŒ ํ™œ์šฉ๋  ์ˆ˜ ์žˆ๋‹ค. ์œ„์˜ ์ฝ”๋“œ์—์„œ๋Š” ์ธ์Šคํ„ด์Šค๋ฅผ ์ƒ์„ฑํ•  ๋•Œ ์ต๋ช…ํ•จ์ˆ˜๋ฅผ ์ž‘์„ฑํ•˜๋Š” ๋ฐฉ์‹๊ณผ ๋ฉ”์†Œ๋“œ์˜ ์ธ์ž๋กœ ๋„˜๊ธธ๋•Œ ์ต๋ช…ํ•จ์ˆ˜๋ฅผ ํ†ตํ•ด ๋ฐ”๋กœ ์ž‘์„ฑํ•˜๋Š” ๋ฐฉ์‹ ๋‘ ๊ฐ€์ง€๋ฅผ ์‹ค์Šตํ•˜์˜€๋‹ค.

            // ์ต๋ช…ํ•จ์ˆ˜๋ฅผ ์ด์šฉํ•ด ๋ธ๋ฆฌ๊ฒŒ์ดํŠธ๋ฅผ ์„ ์–ธํ•˜๊ธฐ.(์˜ค๋ฆ„์ฐจ์ˆœ)
            SelectSort ascend;
            ascend = delegate(int x, int y){
                if (x > y) return 1;
                else if (x == y) return 0;
                else return -1;
            };

            BSort(array, ascend);

            Console.WriteLine("์˜ค๋ฆ„์ฐจ์ˆœ : ");
            foreach (int x in array)
            {
                Console.Write($"{x} ");
            }
            Console.WriteLine();
  • ์ฒซ๋ฒˆ์งธ ๋ฐฐ์—ด์— ๋Œ€ํ•˜์—ฌ ์˜ค๋ฆ„์ฐจ์ˆœ๊ณผ ๋‚ด๋ฆผ์ฐจ์ˆœ ๋ฐฉ์‹์ด ๋˜‘๊ฐ™์•„ ํ•˜๋‚˜๋งŒ ํ™•์ธํ•ด๋ณด์ž
  • ๋จผ์ € SelectSort์— ๋Œ€ํ•œ ์ธ์Šคํ„ด์Šค๋กœ ascend ์ธ์Šคํ„ด์Šค๋ฅผ ์ƒ์„ฑํ•œ ๋’ค ์ต๋ช…ํ•จ์ˆ˜๋ฅผ ํ†ตํ•ด delegate๋กœ ๋ฉ”์†Œ๋“œ๋ฅผ ํ• ๋‹นํ•œ ๊ฒƒ์„ ํ™•์ธํ•  ์ˆ˜ ์žˆ๋‹ค.

            // ๋” ์ข‹์€ ๋ฐฉ๋ฒ•์œผ๋กœ ์ „๋‹ฌํ•˜๋Š” ๋ฉ”์†Œ๋“œ์—์„œ ๋ฐ”๋กœ ์ž‘์„ฑํ•  ์ˆ˜ ์žˆ์Œ
            int[] array2 = { 3, 2, 4, 1, 10, 7, 21, 42, 5, 13 };

            BSort(array2, delegate(int x, int y)
            {
                if (x > y) return 1;
                else if (x == y) return 0;
                else return -1;
            });

            Console.WriteLine("๋ฉ”์†Œ๋“œ์˜ ์ธ์ž์—์„œ ์„ ์–ธํ•œ ์ต๋ช… ๋ฉ”์†Œ๋“œ ์˜ค๋ฆ„์ฐจ์ˆœ : ");
            foreach (int x in array2)
            {
                Console.Write($"{x} ");
            }
            Console.WriteLine();
  • ๋‘๋ฒˆ์งธ ๋ฐฐ์—ด์˜ ์ •๋ ฌ์— ๋Œ€ํ•ด์„œ๋Š” BSort()๋ฉ”์†Œ๋“œ๋ฅผ ํ˜ธ์ถœํ•จ๊ณผ ๋™์‹œ์— ์ธ์ž๋กœ ์ต๋ช…ํ•จ์ˆ˜๋ฅผ ์„ ์–ธํ•ด ์คŒ์œผ๋กœ์จ ๋„˜๊ฒจ์ฃผ์—ˆ๋‹ค.
  • ์œ„์˜ ์ฝ”๋“œ๋ฅผ ํ†ตํ•ด ํ™•์ธํ•  ์ˆ˜ ์žˆ๋‹ค.

'๐Ÿ’ป Programming Language > C#' ์นดํ…Œ๊ณ ๋ฆฌ์˜ ๋‹ค๋ฅธ ๊ธ€

38. ๋žŒ๋‹ค์‹(Lambda Expression)  (0) 2022.04.08
37. ๋ธ๋ฆฌ๊ฒŒ์ดํŠธ๋ฅผ ํ†ตํ•œ ์ด๋ฒคํŠธ ์ฒ˜๋ฆฌ  (0) 2022.04.08
35. ๋ธ๋ฆฌ๊ฒŒ์ดํŠธ ์ฒด์ธ(delegate chain)  (0) 2022.04.08
34. ์ œ๋„ค๋ฆญ ๋ธ๋ฆฌ๊ฒŒ์ดํŠธ(Generic Delegate) & ์ฝœ๋ฐฑํ•จ์ˆ˜  (0) 2022.04.08
33. ๋ธ๋ฆฌ๊ฒŒ์ดํŠธ(delegate) ์‚ฌ์šฉ  (0) 2022.04.08
'๐Ÿ’ป Programming Language/C#' ์นดํ…Œ๊ณ ๋ฆฌ์˜ ๋‹ค๋ฅธ ๊ธ€
  • 38. ๋žŒ๋‹ค์‹(Lambda Expression)
  • 37. ๋ธ๋ฆฌ๊ฒŒ์ดํŠธ๋ฅผ ํ†ตํ•œ ์ด๋ฒคํŠธ ์ฒ˜๋ฆฌ
  • 35. ๋ธ๋ฆฌ๊ฒŒ์ดํŠธ ์ฒด์ธ(delegate chain)
  • 34. ์ œ๋„ค๋ฆญ ๋ธ๋ฆฌ๊ฒŒ์ดํŠธ(Generic Delegate) & ์ฝœ๋ฐฑํ•จ์ˆ˜
S.Honey
S.Honey
  • S.Honey
    Algo ์“ฐ์ž
    S.Honey
  • ์ „์ฒด
    ์˜ค๋Š˜
    ์–ด์ œ
    • ๋ถ„๋ฅ˜ ์ „์ฒด๋ณด๊ธฐ (123)
      • ํšŒ๊ณ  (0)
        • ์ทจ์—… ํ›„ ํšŒ๊ณ  (0)
      • ๐Ÿƒ Frontend Road-Map (2)
        • ๐Ÿšฉ Summary (1)
        • ๐Ÿ“š Road-Map Contents (1)
        • ๐ŸŸง HTML (0)
        • ๐ŸŸฆ CSS (0)
        • ๐ŸŸจ Javascript (0)
        • โฌœ React (0)
        • ๐ŸŸช Redux (0)
      • Backend (0)
        • QueryDSL (0)
      • ๐Ÿ’ป Programming Language (54)
        • C# (51)
        • Flutter-Dart (3)
        • Java (0)
      • ๐Ÿ“š Computer Science (4)
        • Algorithms (4)
        • Database (0)
        • Network (0)
        • Operating System(OS) (0)
      • ๐Ÿ’ฏ CodingTest (60)
        • BaekJoon (22)
        • Programmers (34)
        • CodeTree (4)
      • โœ’๏ธ Design Pattern (1)
      • ๐Ÿฑ Etc (2)
        • Jenkins Plugin ์ œ์ž‘๊ธฐ (1)
  • ๋ธ”๋กœ๊ทธ ๋ฉ”๋‰ด

    • ๋งํฌ

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

      • ๐Ÿ“– ๊ณต๋ถ€ ์ฐธ๊ณ  ๊ต์žฌ ๋ฐ ์ž๋ฃŒ
    • ์ธ๊ธฐ ๊ธ€

    • ํƒœ๊ทธ

      sort
      BFS
      ์ฝ”๋“œํŠธ๋ฆฌ
      DART
      ์ฝ”๋”ฉํ…Œ์ŠคํŠธ
      ๋ฌธ์ž์—ด ํŒŒ์‹ฑ
      ์•Œ๊ณ ๋ฆฌ์ฆ˜
      ๋ฐฑ์ค€
      ์ด์ง„ํƒ์ƒ‰
      ๋™์  ํ”„๋กœ๊ทธ๋ž˜๋ฐ
      c#
      ์นด์นด์˜ค
      JavaScript
      Algorithm
      ํ”„๋กœ๊ทธ๋ž˜๋จธ์Šค
      ์ž๋ฃŒ๊ตฌ์กฐ
      Flutter
      programmers
      ์‚ผ์„ฑsw์—ญํ…Œ
      ๊ตฌํ˜„
      BAEKJOON
      ๊ทธ๋ž˜ํ”„ ํƒ์ƒ‰
      ์Šคํ„ฐ๋””
      JS
      Java
      ์“ฐ์…จ์ž–์•„
      ์‹œ๋ฎฌ๋ ˆ์ด์…˜
      ์ž๋ฐ”์Šคํฌ๋ฆฝํŠธ
      ํŒŒ์ด์ฌ
      DP
    • ์ตœ๊ทผ ๋Œ“๊ธ€

    • ์ตœ๊ทผ ๊ธ€

    • hELLOยท Designed By์ •์ƒ์šฐ.v4.10.1
    S.Honey
    36. ์ต๋ช…๋ฉ”์†Œ๋“œ
    ์ƒ๋‹จ์œผ๋กœ

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