쪽지발송 성공
Click here
재능넷 이용방법
재능넷 이용방법 동영상편
가입인사 이벤트
판매 수수료 안내
안전거래 TIP
재능인 인증서 발급안내

🌲 지식인의 숲 🌲

🌳 디자인
🌳 음악/영상
🌳 문서작성
🌳 번역/외국어
🌳 프로그램개발
🌳 마케팅/비즈니스
🌳 생활서비스
🌳 철학
🌳 과학
🌳 수학
🌳 역사
해당 지식과 관련있는 인기재능

안녕하세요:       저는 현재   소프트웨어 개발회사에서 근무하고잇습니다.   기존소프트웨...

30년간 직장 생활을 하고 정년 퇴직을 하였습니다.퇴직 후 재능넷 수행 내용은 쇼핑몰/학원/판매점 등 관리 프로그램 및 데이터 ...

AS규정기본적으로 A/S 는 평생 가능합니다. *. 구매자의 요청으로 수정 및 보완이 필요한 경우 일정 금액의 수고비를 상호 협의하에 요청 할수 있...

타입 특성(type traits)과 SFINAE

2024-10-18 09:48:58

재능넷
조회수 402 댓글수 0

🚀 타입 특성(Type Traits)과 SFINAE: C++ 마법사의 비밀 도구 상자 🧙‍♂️

 

 

안녕하세요, C++ 개발자 여러분! 오늘은 정말 흥미진진한 주제로 여러분과 함께 이야기를 나눠볼까 해요. 바로 "타입 특성(Type Traits)"과 "SFINAE"라는 C++의 마법 같은 기능들이에요. ㅋㅋㅋ 이름부터 뭔가 어려워 보이죠? 걱정 마세요! 제가 쉽고 재미있게 설명해드릴게요. 마치 카톡으로 수다 떠는 것처럼요! 😉

이 글은 재능넷(https://www.jaenung.net)의 '지식인의 숲' 메뉴에 등록될 예정이에요. 재능넷은 다양한 재능을 공유하고 거래하는 플랫폼인데, C++ 프로그래밍 실력도 멋진 재능 중 하나죠! 이 글을 통해 여러분의 C++ 재능이 한층 더 업그레이드될 거예요. 자, 그럼 시작해볼까요? 🎉

🔍 오늘의 학습 목표:

  • 타입 특성(Type Traits)의 개념과 사용법 이해하기
  • SFINAE의 원리와 활용 방법 익히기
  • 실제 코드에서 이 개념들을 어떻게 적용할 수 있는지 알아보기

자, 이제 본격적으로 C++의 마법 세계로 들어가볼까요? 🧙‍♂️✨

🧐 타입 특성(Type Traits)이 뭐야? 왜 필요해?

여러분, 타입 특성이라고 들어보셨나요? 뭔가 어려워 보이는 이름이죠? ㅋㅋㅋ 걱정 마세요. 생각보다 재밌고 유용한 개념이에요!

타입 특성은 C++에서 컴파일 타임에 타입에 대한 정보를 얻거나 타입을 변형할 수 있게 해주는 템플릿 클래스들의 모음이에요. 음... 뭔 소리냐고요? 쉽게 말해서, 타입에 대해 이것저것 물어보고 필요하면 살짝 바꿀 수 있게 해주는 도구라고 생각하면 돼요. 👀

💡 타입 특성의 주요 기능:

  • 타입이 어떤 특성을 가지고 있는지 확인하기 (예: 정수인지, 포인터인지 등)
  • 타입을 변형하기 (예: const 제거, 참조 제거 등)
  • 조건부 타입 선택하기

이게 왜 필요하냐고요? 음... 상상해보세요. 여러분이 마법사인데, 주문을 외우기 전에 상대방이 어떤 종족인지 알아야 한다면? 🧙‍♂️ 타입 특성은 바로 그런 거예요. 코드를 작성할 때 우리가 다루는 데이터의 타입을 정확히 알고, 그에 맞는 최적의 코드를 작성할 수 있게 해주는 거죠.

재능넷에서 프로그래밍 과외를 받는다고 생각해보세요. 선생님이 여러분의 코딩 실력을 정확히 파악하고 그에 맞는 맞춤형 수업을 해주는 것처럼, 타입 특성은 우리가 다루는 데이터 타입을 정확히 파악하고 그에 맞는 최적의 코드를 작성할 수 있게 해주는 거예요. 😊

🎭 타입 특성의 종류

타입 특성에는 정말 다양한 종류가 있어요. 마치 재능넷에 다양한 재능이 있는 것처럼요! 몇 가지 대표적인 것들을 살펴볼까요?

  • is_integral: 정수 타입인지 확인해요.
  • is_floating_point: 부동소수점 타입인지 봐요.
  • is_pointer: 포인터인지 알려줘요.
  • remove_const: const를 제거해줘요.
  • remove_reference: 참조를 제거해요.
  • conditional: 조건에 따라 타입을 선택해요.

이런 타입 특성들을 사용하면, 우리는 코드를 더 안전하고 효율적으로 만들 수 있어요. 마치 요리사가 재료의 특성을 정확히 알고 요리하는 것처럼 말이죠! 🍳

🚀 타입 특성 사용 예시

자, 이제 실제로 어떻게 사용하는지 볼까요? 간단한 예제를 통해 살펴보겠습니다.


#include <type_traits>
#include <iostream>

template <typename T>
void check_type(T value) {
    if (std::is_integral<T>::value) {
        std::cout << "이것은 정수입니다!" << std::endl;
    } else if (std::is_floating_point<T>::value) {
        std::cout << "이것은 부동소수점 숫자입니다!" << std::endl;
    } else {
        std::cout << "이것은... 음... 뭔가 다른 거예요!" << std::endl;
    }
}

int main() {
    check_type(42);        // 정수
    check_type(3.14);      // 부동소수점
    check_type("Hello");   // 문자열
    return 0;
}

이 코드에서 std::is_integralstd::is_floating_point는 타입 특성이에요. 이들은 주어진 타입 T가 각각 정수인지, 부동소수점 숫자인지를 알려줍니다.

이렇게 타입 특성을 사용하면, 컴파일 시점에 타입에 대한 정보를 얻을 수 있어요. 이는 런타임 오버헤드 없이 타입 안전성을 높이고 최적화된 코드를 작성하는 데 도움을 줍니다.

🎨 재능넷 팁: 타입 특성은 마치 재능넷에서 다양한 재능을 분류하고 찾는 것과 비슷해요. 여러분이 원하는 재능(타입)을 정확히 찾아 활용할 수 있게 해주죠. 프로그래밍에서도 이런 '재능 분류' 능력이 중요합니다!

자, 이제 타입 특성에 대해 조금은 이해가 되셨나요? ㅎㅎ 어려워 보이지만 실제로 사용해보면 정말 유용하답니다. 다음으로는 더 신기한 개념인 SFINAE에 대해 알아볼 거예요. 준비되셨나요? 🚀

🎭 SFINAE: C++의 마법 같은 기능

자, 이제 정말 재미있는 부분이 왔어요! SFINAE라는 거 들어보셨나요? 뭔가 어려워 보이는 이름이죠? ㅋㅋㅋ 걱정 마세요, 제가 쉽게 설명해드릴게요!

SFINAE는 "Substitution Failure Is Not An Error"의 약자예요. 한국어로 하면 "치환 실패는 오류가 아니다"라는 뜻이죠. 음... 뭔 소리냐고요? 쉽게 말해서, C++ 컴파일러가 템플릿을 처리할 때 "이건 안 되네? 그럼 다른 걸로 해볼게~"라고 하는 거예요. 귀여운 컴파일러죠? 😊

🎈 SFINAE의 핵심 개념:

  • 템플릿 인스턴스화 과정에서 오류가 발생해도 바로 컴파일 에러를 내지 않아요.
  • 대신, 다른 가능한 오버로드나 특수화를 찾아봐요.
  • 이를 통해 컴파일 타임에 조건부로 함수나 클래스를 선택할 수 있어요.

SFINAE는 마치 재능넷에서 여러분이 원하는 재능을 가진 사람을 찾는 과정과 비슷해요. 처음에 찾은 사람이 조건에 맞지 않으면, 다른 사람을 찾아보는 거죠. 컴파일러도 이렇게 "이 템플릿은 안 되네? 그럼 다른 걸로~"하면서 최적의 함수나 클래스를 찾아가는 거예요. 😄

🧩 SFINAE는 어떻게 작동할까?

SFINAE의 작동 원리를 이해하기 위해, 간단한 예제를 살펴볼게요.


#include <iostream>
#include <type_traits>

// 정수 타입을 위한 함수
template <typename T, typename = std::enable_if_t<std::is_integral<T>::value>>
void print_number(T value) {
    std::cout << "이것은 정수예요: " << value << std::endl;
}

// 부동소수점 타입을 위한 함수
template <typename T, typename = std::enable_if_t<std::is_floating_point<T>::value>>
void print_number(T value) {
    std::cout << "이것은 부동소수점 숫자예요: " << value << std::endl;
}

int main() {
    print_number(42);    // 정수 버전 호출
    print_number(3.14);  // 부동소수점 버전 호출
    return 0;
}

이 코드에서 std::enable_if_t와 타입 특성을 사용해 SFINAE를 구현했어요. 컴파일러는 각 print_number 함수 템플릿을 인스턴스화하려고 시도하지만, 조건에 맞지 않으면 그 템플릿을 무시하고 다음 것을 시도해요.

이렇게 SFINAE를 사용하면, 컴파일 타임에 타입에 따라 다른 함수를 선택할 수 있어요. 이는 코드의 유연성과 타입 안전성을 크게 높여줍니다.

🎨 SFINAE의 실제 활용

SFINAE는 단순히 "이런 게 있어요~" 하고 끝나는 개념이 아니에요. 실제로 많은 곳에서 유용하게 쓰이고 있죠. 몇 가지 예를 들어볼게요:

  1. 타입에 따른 최적화: 특정 타입에 대해 더 효율적인 알고리즘을 선택할 수 있어요.
  2. 인터페이스 체크: 클래스가 특정 메서드나 타입을 가지고 있는지 컴파일 타임에 확인할 수 있어요.
  3. 제약 조건 구현: 템플릿 파라미터에 제약을 걸어 의도하지 않은 타입의 사용을 방지할 수 있어요.
  4. 태그 디스패치: 런타임 오버헤드 없이 다양한 타입에 대한 특수화된 구현을 제공할 수 있어요.

재능넷에서 다양한 재능을 가진 사람들을 찾는 것처럼, SFINAE는 우리가 원하는 "재능(기능)"을 가진 코드를 컴파일 타임에 찾아내는 거예요. 이렇게 하면 런타임에 발생할 수 있는 오류를 미리 방지할 수 있죠. 👍

🚀 재능넷 팁: SFINAE를 마스터하면, 여러분의 C++ 프로그래밍 재능이 한층 더 업그레이드될 거예요! 마치 재능넷에서 새로운 스킬을 배우는 것처럼, SFINAE를 통해 더 강력하고 유연한 코드를 작성할 수 있답니다.

자, 이제 SFINAE에 대해 조금은 감이 오시나요? ㅎㅎ 처음에는 어려워 보이지만, 실제로 사용해보면 정말 강력한 도구라는 걸 느끼실 거예요. 다음으로는 타입 특성과 SFINAE를 함께 사용하는 방법에 대해 알아볼 거예요. 준비되셨나요? Let's go! 🚀

🔮 타입 특성과 SFINAE의 환상적인 콜라보

자, 이제 정말 재미있는 부분이 왔어요! 타입 특성과 SFINAE를 함께 사용하면 어떤 마법이 일어날까요? 🧙‍♂️✨ 이 두 가지를 결합하면, C++에서 정말 강력하고 유연한 코드를 작성할 수 있어요. 마치 재능넷에서 여러 재능을 가진 슈퍼 인재를 찾는 것처럼 말이죠! 😉

🎭 타입 특성 + SFINAE = 코드의 마법

타입 특성과 SFINAE를 함께 사용하면, 컴파일 타임에 타입에 따라 다른 동작을 하는 코드를 작성할 수 있어요. 이게 무슨 말이냐고요? 쉽게 말해서, 코드가 스스로 "아, 이 타입이구나! 그럼 이렇게 해야지~"라고 판단하고 행동하는 거예요. 똑똑하죠? ㅋㅋㅋ

예를 들어볼게요:


#include <iostream>
#include <type_traits>

// 컨테이너 타입을 위한 함수
template <typename T, typename = std::enable_if_t<std::is_array<T>::value || std::is_class<T>::value>>
void process(const T& container) {
    std::cout << "이건 컨테이너예요! 원소를 순회할 수 있어요." << std::endl;
}

// 산술 타입을 위한 함수
template <typename T, typename = std::enable_if_t<std::is_arithmetic<T>::value>>
void process(T value) {
    std::cout << "이건 숫자예요! 값은 " << value << "입니다." << std::endl;
}

int main() {
    int arr[] = {1, 2, 3};
    process(arr);  // 컨테이너 버전 호출
    process(42);   // 산술 타입 버전 호출
    return 0;
}

이 코드에서 std::enable_if_t와 여러 타입 특성(is_array, is_class, is_arithmetic)을 사용해 SFINAE를 구현했어요. 컴파일러는 각 process 함수 템플릿을 인스턴스화하려고 시도하지만, 조건에 맞지 않으면 그 템플릿을 무시하고 다음 것을 시도해요.

💡 여기서 잠깐! 이런 기법을 사용하면, 재능넷에서 다양한 재능을 가진 사람들을 효율적으로 분류하고 매칭하는 것처럼, 다양한 타입에 대해 최적화된 코드를 작성할 수 있어요. 코드의 재능을 극대화하는 거죠! 😎

🚀 더 복잡한 예제: 완벽 전달과 SFINAE

이번에는 조금 더 복잡한 예제를 볼게요. 완벽 전달(Perfect Forwarding)과 SFINAE를 함께 사용하는 경우예요.


#include <iostream>
#include <type_traits>

// 이동 가능한 타입을 위한 함수
template <typename T, typename = std::enable_if_t<std::is_move_constructible<T>::value>>
void process(T&& value) {
    std::cout << "이동 생성 가능한 타입이에요!" << std::endl;
    // 여기서 std::move를 사용할 수 있어요
}

// 이동 불가능한 타입을 위한 함수
template <typename T, typename = std::enable_if_t<!std::is_move_constructible<T>::value>>
void process(const T& value) {
    std::cout << "이동 생성 불가능한 타입이에요. 복사만 가능해요." << std::endl;
}

// 테스트를 위한 이동 불가능한 클래스
class NonMovable {
public:
    NonMovable() = default;
    NonMovable(const NonMovable&) = default;
    NonMovable(NonMovable&&) = delete;
};

int main() {
    std::string str = "Hello";
    process(str);  // 이동 가능

    NonMovable nm;
    process(nm);   // 이동 불가능

    return 0;
}

이 예제에서는 std::is_move_constructible를 사용해 타입이 이동 생성 가능한지 확인하고, 그에 따라 다른 함수를 선택해요. 이렇게 하면 타입의 특성에 따라 최적화된 동작을 수행할 수 있죠.

이런 방식으로 타입 특성과 SFINAE를 결합하면, 컴파일 타임에 타입에 따른 최적화를 수행하고, 잘못된 타입 사용을 방지할 수 있어요. 이는 성능 향상과 버그 예방에 큰 도움이 됩니다!

🎨 실제 사용 사례: 스마트 포인터 구현

타입 특성과 SFINAE의 조합은 실제로 많은 곳에서 사용되고 있어요. 예를 들어, C++의 스마트 포인터 구현에서도 이 기법이 사용됩니다. 간단한 예를 들어볼게요:


#include <iostream>
#include <memory>
#include <type_traits>

template <typename T>
class SmartPtr {
    T* ptr;

public:
    template <typename U, typename = std::enable_if_t<std::is_convertible<U*, T*>::value>>
    SmartPtr(U* p) : ptr(p) {
        std::cout << "변환 가능한 포인터로 생성" << std::endl;
    }

    // 삭제자를 받는 생성자
    template <typename U, typename Deleter, 
              typename = std::enable_if_t<std::is_convertible<U*, T*>::value && 
                                            std::is_invocable<Deleter, U*>::value>>
    SmartPtr(U* p, Deleter d) : ptr(p) {
        std::cout << "삭제자와 함께 생성" << std::endl;
        // 실제로는 여기서 삭제자를 저장하고 사용해야 해요
    }

    ~SmartPtr() { delete ptr; }

    T* get() const { return ptr; }
};

struct Base { virtual ~Base() = default; };
struct Derived : Base {};

int main() {
    SmartPtr<Base> ptr1(new Derived);  // OK
    SmartPtr<Base> ptr2(new Base, [](Base* p) { delete p; });  // OK
    // SmartPtr<Derived> ptr3(new Base);  // 컴파일 에러!

    return 0;
}

이 예제에서 SmartPtr 클래스는 SFINAE와 타입 특성을 사용해 다음과 같은 기능을 구현해요:

  • 포인터 타입이 변환 가능한 경우에만 생성자를 활성화합니다.
  • 삭제자를 받는 생성자는 포인터 타입이 변환 가능하고, 삭제자가 해당 포인터 타입을 인자로 받을 수 있을 때만 활성화됩니다.

이렇게 SFINAE와 타입 특성을 사용하면, 컴파일 타임에 타입 안전성을 보장하고 잘못된 사용을 방지할 수 있어요. 이는 런타임 오류를 줄이고 코드의 안정성을 높이는 데 큰 도움이 됩니다!

🌟 재능넷 팁: 타입 특성과 SFINAE를 마스터하면, 여러분의 C++ 코딩 실력은 재능넷의 최고 등급 재능자 수준으로 올라갈 거예요! 이런 고급 기술을 익히면, 더 안전하고 효율적인 코드를 작성할 수 있답니 다. 마치 재능넷에서 여러 분야의 전문성을 갖춘 멀티 플레이어처럼요! 😊

자, 이제 타입 특성과 SFINAE의 강력한 조합에 대해 어느 정도 이해가 되셨나요? 처음에는 복잡해 보이지만, 이 기술들을 마스터하면 여러분의 C++ 코딩 실력은 한 단계 더 업그레이드될 거예요. 마치 재능넷에서 새로운 스킬을 익히는 것처럼 말이죠! 🚀

🎓 마무리: C++ 마법사로 거듭나기

와우! 정말 긴 여정이었죠? 타입 특성과 SFINAE라는 C++의 고급 기능들에 대해 알아봤어요. 처음에는 어려워 보였지만, 이제 조금은 친숙해지셨나요? ㅎㅎ

이 기술들은 단순히 "있으면 좋은" 것이 아니라, 현대 C++ 프로그래밍에서 정말 중요한 도구예요. 마치 재능넷에서 여러 재능을 조합해 새로운 가치를 만들어내는 것처럼, 타입 특성과 SFINAE를 잘 활용하면 더 안전하고, 효율적이며, 유연한 코드를 작성할 수 있답니다.

🌟 배운 내용 정리

  1. 타입 특성(Type Traits): 컴파일 타임에 타입 정보를 얻고 조작하는 도구
  2. SFINAE: 템플릿 인스턴스화 실패를 이용해 오버로드 해결이나 특수화를 수행하는 기법
  3. 타입 특성 + SFINAE: 이 둘을 결합해 강력하고 유연한 템플릿 메타프로그래밍 구현

이 개념들을 마스터하면, 여러분은 진정한 C++ 마법사가 될 수 있어요! 🧙‍♂️✨

💡 재능넷 팁: C++의 이런 고급 기능들을 익히는 것은 마치 재능넷에서 새로운 재능을 개발하는 것과 같아요. 시간과 노력이 필요하지만, 그만큼 큰 가치가 있죠. 여러분의 프로그래밍 재능이 한층 더 빛나게 될 거예요!

🚀 다음 단계

여기서 배운 내용을 바탕으로, 다음과 같은 것들을 시도해보는 건 어떨까요?

  • 실제 프로젝트에 타입 특성과 SFINAE 적용해보기
  • C++20의 Concepts 기능 학습하기 (SFINAE를 더 쉽게 만들어주는 기능이에요!)
  • 템플릿 메타프로그래밍 더 깊이 공부하기
  • 오픈 소스 라이브러리의 코드를 분석하며 이런 기법들이 어떻게 사용되는지 살펴보기

기억하세요, 프로그래밍 실력을 향상시키는 것은 마치 재능넷에서 새로운 재능을 개발하는 것과 같아요. 꾸준한 학습과 연습이 필요하지만, 그 결과는 정말 멋질 거예요!

자, 이제 여러분은 C++의 강력한 마법 도구들을 알게 되었어요. 이 도구들을 활용해 더 멋진 코드를 작성하실 수 있을 거예요. 마치 재능넷에서 여러 재능을 조합해 새로운 가치를 만들어내는 것처럼 말이죠! 😊

여러분의 C++ 여정에 행운이 함께하기를 바랄게요. 언제든 질문이 있다면, 재능넷의 C++ 전문가들에게 물어보는 것도 좋은 방법이에요. 함께 성장하고 발전해 나가요! 화이팅! 🎉🚀

관련 키워드

  • 타입 특성
  • SFINAE
  • 템플릿 메타프로그래밍
  • C++
  • 컴파일 타임 최적화
  • 타입 안전성
  • 오버로드 해결
  • 템플릿 특수화
  • 조건부 컴파일
  • 고급 C++ 기법

지적 재산권 보호

지적 재산권 보호 고지

  1. 저작권 및 소유권: 본 컨텐츠는 재능넷의 독점 AI 기술로 생성되었으며, 대한민국 저작권법 및 국제 저작권 협약에 의해 보호됩니다.
  2. AI 생성 컨텐츠의 법적 지위: 본 AI 생성 컨텐츠는 재능넷의 지적 창작물로 인정되며, 관련 법규에 따라 저작권 보호를 받습니다.
  3. 사용 제한: 재능넷의 명시적 서면 동의 없이 본 컨텐츠를 복제, 수정, 배포, 또는 상업적으로 활용하는 행위는 엄격히 금지됩니다.
  4. 데이터 수집 금지: 본 컨텐츠에 대한 무단 스크래핑, 크롤링, 및 자동화된 데이터 수집은 법적 제재의 대상이 됩니다.
  5. AI 학습 제한: 재능넷의 AI 생성 컨텐츠를 타 AI 모델 학습에 무단 사용하는 행위는 금지되며, 이는 지적 재산권 침해로 간주됩니다.

재능넷은 최신 AI 기술과 법률에 기반하여 자사의 지적 재산권을 적극적으로 보호하며,
무단 사용 및 침해 행위에 대해 법적 대응을 할 권리를 보유합니다.

© 2025 재능넷 | All rights reserved.

댓글 작성
0/2000

댓글 0개

해당 지식과 관련있는 인기재능

안녕하세요!!!고객님이 상상하시는 작업물 그 이상을 작업해 드리려 노력합니다.저는 작업물을 완성하여 고객님에게 보내드리는 것으로 거래 완료...

 델파이 C# 개발 경력 10년모든 프로그램 개발해 드립니다. 반복적인 작업이 귀찮아서 프로그램이 해줬으면 좋겠다라고 생각한 것들 만...

C언어, JAVA, C++, C# 응용프로그램 개발해드립니다.간단한 프로그램부터 복잡한 응용프로그래밍 까지 가능합니다. [일정]- 요구사항 간단히 ...

프로그램 개발자입니다. ERP, WMS, MES 등과 같은 산업용 프로그램, 설비 인터페이스 프로그램 등을 주로 개발하였습니다.현재는 모 대기업의...

📚 생성된 총 지식 11,524 개

  • (주)재능넷 | 대표 : 강정수 | 경기도 수원시 영통구 봉영로 1612, 7층 710-09 호 (영통동) | 사업자등록번호 : 131-86-65451
    통신판매업신고 : 2018-수원영통-0307 | 직업정보제공사업 신고번호 : 중부청 2013-4호 | jaenung@jaenung.net

    (주)재능넷의 사전 서면 동의 없이 재능넷사이트의 일체의 정보, 콘텐츠 및 UI등을 상업적 목적으로 전재, 전송, 스크래핑 등 무단 사용할 수 없습니다.
    (주)재능넷은 통신판매중개자로서 재능넷의 거래당사자가 아니며, 판매자가 등록한 상품정보 및 거래에 대해 재능넷은 일체 책임을 지지 않습니다.

    Copyright © 2024 재능넷 Inc. All rights reserved.
ICT Innovation 대상
미래창조과학부장관 표창
서울특별시
공유기업 지정
한국데이터베이스진흥원
콘텐츠 제공서비스 품질인증
대한민국 중소 중견기업
혁신대상 중소기업청장상
인터넷에코어워드
일자리창출 분야 대상
웹어워드코리아
인터넷 서비스분야 우수상
정보통신산업진흥원장
정부유공 표창장
미래창조과학부
ICT지원사업 선정
기술혁신
벤처기업 확인
기술개발
기업부설 연구소 인정
마이크로소프트
BizsPark 스타트업
대한민국 미래경영대상
재능마켓 부문 수상
대한민국 중소기업인 대회
중소기업중앙회장 표창
국회 중소벤처기업위원회
위원장 표창