반응형

분류 전체보기 163

Microsoft SQL Server (MSSQL)에 대한 장단점 및 설명

장점 1. 다양한 기능 제공: MSSQL은 고급 기능과 기능이 풍부한 플랫폼으로, 트랜잭션 관리, 저장 프로시저, 트리거 등 다양한 기능을 제공합니다. 2. 다중 사용자 지원: 강력한 다중 사용자 지원으로 여러 사용자가 동시에 데이터베이스에 접근할 수 있습니다. 3. 관리 및 개발 도구: Microsoft의 SQL Server Management Studio (SSMS) 및 Visual Studio 등의 툴을 통해 데이터베이스를 효과적으로 관리하고 개발할 수 있습니다. 4. 높은 확장성: 대규모 응용프로그램 및 데이터베이스에 대한 확장성이 높습니다. 5. 보안 기능 강화: 고급 보안 기능을 갖추고 있어 데이터의 안전성이 높습니다. 단점 1. 비용: MSSQL은 상용 데이터베이스로 라이선스 비용이 발생할 ..

DataBase/MSSQL 2024.01.17

SQLite 장단점

장점: 1. 경량성 및 내장형: SQLite는 경량이면서도 내장형 데이터베이스로, 별도의 서버 설치 없이 파일 기반으로 데이터를 저장합니다. 이로써 쉽게 배포 및 관리할 수 있습니다. 2. 무료 및 오픈 소스: SQLite는 오픈 소스이며 무료로 사용할 수 있습니다. 이는 비용을 절감하고 자유롭게 사용할 수 있는 장점으로 작용합니다. 3. 간단한 사용법: 설치 및 설정이 간단하며, 초보자도 쉽게 사용할 수 있는 SQL 문법을 지원합니다. 4. 효율적인 읽기 작업: 읽기 작업에 강점을 가지고 있어, 읽기 중심의 애플리케이션에서 높은 성능을 보여줍니다. 5. 데이터 이식성: 파일 기반이기 때문에 동일한 데이터 파일을 여러 플랫폼에서 사용할 수 있습니다. 단점: 1. 다중 사용자 지원 한계: SQLite는 동..

DataBase/SQLite 2024.01.17

Github 화살표 폴더,폴더 클릭 안 됨 해결

Problem 위와 같이 Git에서 화살표 폴더가 생성되어 프로젝트 내부로 들어갈 수 없는 상황이 발생했다. Cause 이미 Git 설정이 되어 있는 상위 폴더 내부 하위 폴더에 Git 연결이 설정되어 있기 때문이었다. 간단하게 상위 폴더에도 .git 파일이 있고 하위 폴더에도 .git 파일이 있어서 하위 폴더를 Git 에 Push 했을 때 화살표 폴더로 생성되어 클릭이 안 됐던 것 Solution 하위 폴더의 .git 파일을 제거한다. (.git은 숨김 파일로 되어있다) 스테이지의 파일을 제거한다. git rm --cached . -rf 하위 폴더에서 위 명령어를 사용하여 스테이지 파일을 제거하면 된다.

Git 2024.01.17

.NET에서 IntPtr 및 네이티브 코드와의 상호 작용

IntPtr이란? IntPtr은. NET 언어에서 관리되지 않는 코드와 상호 작용하기 위한 특별한 데이터 형식으로, 포인터나 핸들과 같은 메모리 주소를 나타냅니다. 주로 P/Invoke와 같은 상황에서 사용되며, 네이티브 코드와의 상호 작용을 가능케 합니다. Array.Clear, Array.Copy, Marshal.Copy Array.Clear: 배열의 특정 범위의 요소를 초기화하는 메서드. 사용 이유: 초기화하지 않은 배열은 예기치 못한 동작을 일으킬 수 있으며, Array.Clear를 사용하여 초기화된 상태로 사용하기 위함. Array.Copy: 배열에서 다른 배열로 요소를 복사하는 메서드. 사용 이유: 데이터 이전이나 복사 과정에서 배열을 정확하게 관리하기 위해 사용. Marshal.Copy: 관..

C# 2024.01.11

C# 동적으로 메서드 호출하기: Reflection과 Type 활용

Reflection 기본 설명 및 구조 종종 메서드의 이름이나 구조가 변경될 수 있는 환경에서 동적으로 메서드를 호출해야 때가 있습니다. Reflection 은 프로그램이 실행 중에 자신의 구조를 검사하고 조작할 수 있는 기능을 제공하는데 예를 들어 특정 유형의 멤버를 찾거나 인스턴스를 동적으로 생성하는 데 사용될 수 있습니다. Reflection 기능을 사용할 필요가 없는 경우는 다음과 같이 일반 객체를 생성해서 사용합니다. BS2Event instance = new BS2Event(); object value = instance.FieldName; 리플렉션을 사용하는 경우는 다음과 같이 사용합니다. Type structureType = typeof(BS2Event); FieldInfo field = ..

C# 2023.12.28

Binary(이진 파일)의 장점 및 사용

Binary 컴퓨터 프로그래밍에서 데이터를 저장하고 전송하는 방식 중 하나인 이진 파일은 많은 이점을 제공합니다. 이 글에서는 이진 파일의 개념, 사용 이유, 장점, 그리고 어떻게 사용되는지에 대해 알아보겠습니다. 1. 이진 파일이란? 이진 파일은 0과 1로 이루어진 이진 데이터를 담고 있는 파일 형식입니다. 이는 텍스트 파일과는 대조적으로 텍스트 형식이 아닌 이진 데이터로 구성되어 있습니다. 2. 사용 이유와 장점 2.1 효율성 이진 파일은 텍스트 파일에 비해 더 적은 공간을 차지하며, 이는 데이터를 더 작은 크기로 저장하고 빠른 입출력을 가능하게 합니다. 특히 대용량 데이터를 다룰 때 효과적입니다. 2.2 속도 이진 파일을 사용하면 데이터 직렬화와 역직렬화 과정에서 생기는 오버헤드가 적습니다. 이는 ..

C# 2023.12.19

ASP.NET Core 서비스 라이프타임 종류 및 특징

ASP.NET Core에서 서비스 라이프타임은 서비스가 생성되고 사용되는 시간 동안의 범위를 나타냅니다. 서비스 라이프타임은 서비스의 인스턴스가 어떻게 관리되고 언제 생성되고 소멸되는지를 결정합니다. ASP.NET Core는 주로 세 가지 라이프타임을 제공합니다: Singleton, Scoped, 그리고 Transient. 1. Singleton 라이프타임 특징: 애플리케이션 전체에서 하나의 인스턴스를 공유합니다. 애플리케이션이 시작될 때 생성되고 종료될 때까지 유지됩니다. 활용 예시: 애플리케이션 설정, 캐싱, 로깅 등과 같이 공유 자원을 관리할 때 사용됩니다. 예시 코드: builder.Services.AddSingleton(); builder.Services.AddSingleton(); 2. Sco..

C# 2023.12.14

Interop 라이브러리

Interop Interop.xxx.dll 파일들은 COM(Components Object Model) 형식의 라이브러리를 .NET 환경에서 사용하기 위한 인터오퍼 라이브러리이다. COM은 플랫폼 간 상호 운용성을 지원하기 위한 마이크로소프트의 기술로, 여러 언어와 환경에서 사용할 수 있는 컴포넌트 기반의 소프트웨어 개발 모델이다. COM 컴포넌트와 .NET 언어 간의 통신 지원 : COM은 C++ 등의 언어로 작성된 컴포넌트를 .NET 언어에서 사용할 수 있게 해주는 인터페이스를 제공한다. Interop 라이브러리는 이러한 인터페이스를 .NET 에서 호출할 수 있도록 *래핑 하고 변환한다. *타입 라이브러리(Typelib)에서 정보 추출 : COM 컴포넌트들은 타입 라이브러리에 정보를 저장하고, Int..

C# 2023.12.12

C# 라이브러리 만들기

흔히 DLL 파일이라고 불리기도 하는 라이브러리는 재사용 가능한 범용 모듈을 말합니다. 특별한 기능을 하는 프로그램을 만들고 이를 공용으로 쓸 수 있게, 재사용 가능하게 만드는 이 라이브러리를 만드는 방법과 그 라이브러리를 어떻게 사용할 수 있는지에 대해 알아보겠습니다. 1. 프로젝트 만들기 [클래스 라이브러리. NET]을 선택하여 새로운 프로젝트를 생성합니다. 2. 라이브러리로 만들 코드 작성 namespace MyDLL { public class MyCal { public double Add(double a, double b) { return a + b; } public double Subtract(double a, double b) { return a - b; } public double Multi..

C# 2023.11.28

C# Delegate , 제네릭(Generic)

C# Delegate에 대한 소개 C#에서 Delegate(델리게이트)는 메서드에 대한 참조를 나타내는 형식입니다. 이는 다른 언어에서의 함수 포인터와 유사한 역할을 합니다. Delegate를 사용하면 메서드를 변수에 할당하고 다른 메서드로 전달하거나, 이벤트 처리, 콜백 등의 기능을 쉽게 구현할 수 있습니다. Delegate의 선언과 사용 // 델리게이트 선언 delegate void MyDelegate(string message); class Program { static void Main() { // 델리게이트 인스턴스 생성 MyDelegate myDelegate = new MyDelegate(DisplayMessage); // 델리게이트를 통한 메서드 호출 myDelegate("Hello, Del..

C# 2023.11.27
반응형