달력

5

« 2024/5 »

  • 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

구조체 포인터라고 해서 다를 것 없다.

int형 포인터 변수를 선언하듯이 선언하면 되고, int형 포인터를 통해서 접근하듯이 접근하면 된다.


-구조체 포인터

함수의 인자로 기본자료형 변수와 마찬가지로 구조체 변수도 포인터로 전달 할 수 있다.

이렇게 함수 내부에서 외부에 있는 구조체 변수에 직접 접근하기 위해 구조체 포인터를 쓴다.

구조체 변수의 포인터 선언 방식과 매개변수로 구조체 포인터를 선언하는 방식은 일반적은 변수의 포인터 선언규칙을 그대로 적용하면 된다.

또한 구조체 변수의 주소 값을 얻을 때고 & 연산자를 사용한다.


-포인터를 이용한 구조체 멤버의 접근

(*구조체_포인터).멤버 

여기에서 (*구조체_포인터)는 구조체 변수를 의미하게 된다.

멤버에 접근하는 데 ( )가 필요한 이유는 .연산자보다 *연산자의 우선순위가 낮기 때문이다.

그런데 포인터를 이용한 구조체 멤버의 접근을 간단히 처리하는 -> 연산자가 있는 데 다음과 같은 방식으로 접근이 가능하다.

구조체_포인터->멤버

즉, "(*구조체_포인터).멤버"는 "구조체_포인터->멤버"와 완전히 동일한 연산문이다.


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
#include <stdio.h>
#include <string.h>
 
#define NAME_LEN    30
#define    PID_LEN        15
 
typedef struct _person
{
    char name[NAME_LEN]; //이름
    char ID[PID_LEN]; //주민등록 번호
    unsigned int age; //나이
}person;
 
void ShowPersonData(person * ptr)
{
    printf("이름: %s \n", (*ptr).name);
    printf("주민등록번호: %s \n", (*ptr).ID);
    printf("나이: %u \n", ptr->age);
}
 
int main(void)
{
    person A_youjin = { "안유진""920720-2587412"24 };
    person * personPtr = &A_youjin;
 
    
    ShowPersonData(personPtr);
 
    while (1);
}
cs



:
Posted by youjin.A

1.구조체를 선언할 때 typedef 사용

구조체 변수를 선언 할 때에는 다음과 같이 한다.

struct      자료형_이름      변수_이름;

일반적인 자료형인 int나 double과 마찬가지로 [자료형_이름     변수_이름;] 이렇게 선언하고 싶을 것이다.

앞에있는 struct를 떼버리고...

그런데 typedef 선언을 이용하면 이것이 실제로 가능하다.

typedef    struct    자료형_이름    새롭게_축약된_자료형_이름;        

이 선언에 의해서 새롭게_축약된_자료형_이름 이 struct    자료형_이름 을 대신 할 수 있는 것이다.

이 후 변수를 선언할 때, 컴파일러에 의하여 struct    자료형_이름 새롭게_축약된_자료형_이름이 둘 다 사용될 수 있다. 


1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
#include <stdio.h>
 
struct point
{
    double    xpos;
    double    ypos;
};
 
typedef    struct point point;
 
int main(void)
{
    point p1;
    struct point p2;
 
    p1.xpos = 0.1, p1.ypos = 0.2;
    p2.xpos = 2.4, p2.ypos = 2.5;
 
    printf("X축 거리: %g \n", p2.xpos - p1.xpos);
    printf("Y축 거리: %g \n", p2.ypos - p1.ypos);
 
    while (1);
}
cs



2.구조체의 정의에 포험되는 typedef

위의 코드에서는 구조체의 정의와 typedef선언을 별도로 하고 있다.

하지만 이 둘을 다음과 같이 묶어서 선언할 수 있다.

 struct   point

{

   double xpos;

   double ypos;

};

typedef   struct point point;

 typedef  struct  point

{

    double  xpos;

    double  ypos;

}  point;


아래의 코드는 위의 코드를 오른편에 선언방식으로 대체한 것이다.

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
#include <stdio.h>
 
typedef struct point
{
    double    xpos;
    double    ypos;
}point;
 
int main(void)
{
    point p1;
    struct point p2;
 
    p1.xpos = 0.1, p1.ypos = 0.2;
    p2.xpos = 2.4, p2.ypos = 2.5;
 
    printf("X축 거리: %g \n", p2.xpos - p1.xpos);
    printf("Y축 거리: %g \n", p2.ypos - p1.ypos);
 
    while (1);
}
cs


:
Posted by youjin.A
2015. 9. 7. 00:14

트랜지스터의 특성 전자공학이론/전자회로2015. 9. 7. 00:14

컬렉터 특성 곡선


위의 회로에서 V(BB)를 고정시킨다.

그리고 V(CC)를 증가시키면서 V(CE)의 변화에따른 I(C)의 변화를 살펴보면 다음과 같다.


그리고 위의 실험을 V(BB)를 증가시키면서 반복하면 다음과 같은 그래프가 나온다.

위 그래프는 세 영역으로 나눌 수 있는 데 왼쪽부터 Saturation영역, 중간은 Active영역, 오른쪽은 Breakdown영역이다.

여기서 우리는 Active영역을 다루는 데, 이영역은 거의 일정한 직선으로 본다.

그러면 I(C) = B(베타)I(B)

실제로는 Active영역에서 I(C)는 증가하지만 증가하지 않고 일정하다고 가정하면 문제를 풀 수 있기때문이다.



직류 등가 회로


베이스-이미터 접합의 전기적 특성은 다이오드 특성 곡선과 같다.

V(CE)가 활성영역일때 I(C)는 I(B)에 종속적이다.

컬렉터 전류와 베이스 전류의 비는 전류 이득이고 이를 베타로 표시한다.값은 20~200정도 이다.

   

컬렉터 전류와 이미터 전류의 비는 알파로 표시한다. 값은 0.95~0.99 사이이다. 그 이유는 I(C)가 I(E)보다 약간 작기 때문이다.



직류 부하선

맨 위의 회로에서 이번에는 V(CC)가 고정되어 있는 경우를 고려해본다.

핑크색깔 직선은 V(CC)가 고정 되어 있을 때, V(BB)를 변화 시켰을 때의 V(CE)와 I(C)이다.

V(BB)를 증가 시킴에 따라 I(B)가 증가하면 핑크색 그래프위의 점은 차단점->Q1->Q2->Q3->포화점으로 이동한다.

차단점은 I(B)가 0일 때, I(C) = 0이고 V(CE) = V(CC)인 점이고

포화점은 V(CE)가 0인 이상적인 상황에서 흐를 수 있는 최대 전류 IC(sat) 이다.



동작점


베이스에 교류신호를 입력했을 때 신호가 차단점 이하이거나 포화점 이상이면 출력파형이 짤리게 된다.


출력 파형이 짤리지 않게 하기위해서 교류신호 말고 DC로 바이어스를 시켜준다.


회로에 교류 입력 전압을 인가하지 않았을 때 I(C)와 V(CE)를 동작점이라고 하는데 이 동작점을 부하선의 가운데로 맞춰준다.



:
Posted by youjin.A