웹마(Web Ma) 인터넷 브라우저

from Info/Tools 2007/04/08 00:55 view 21032
http://www.mdiwebma.com/

써볼수록 물건이다..라는 생각이 든다. 평소 추가 하고 싶은 기능이 거의 다 있다.

역시 IE보다 물건들은 넘쳐 났다.

참고로 이거 사용하면 오른쪽 마우스 방지 무력화가 아~~주 쉬워진다.

Visual Assist X 사용하기.

from Info/Dev 2007/04/08 00:00 view 48058
07.5.12(토) 1555 버젼을 쓰고 있다. 6.0 와 2005를 동시에 지원한다.

ps.처음 인스톨후 안되면 리부팅이나 또 인스톨 하면 되기도 한다....(경험담)

참고로 사용방법은 이러하다..

more..



사용자 삽입 이미지

C코드 최적화 하기.

from Info/Dev 2007/04/07 15:46 view 26773
KLDP에 있는 글.

http://kldp.org/node/79109

http://www.azillionmonkeys.com/qed/optimize.html

근데 막상 실천은 어렵 다는 거..ㅠ_ㅠ

4.2(화) 가변 인수에 맛보기..

from Study/C언어 2007/04/02 20:18 view 25806

int __cdecl printf (

        const char *format,

        ...

        )

/*

 * stdout 'PRINT', 'F'ormatted

 */

가변인수란 인수의 개수와 타입이 미리 정해져 있지 않은 것으로 이런 인수를 사용하는 함수를 가변 인수 함수라 한다.

번째 인수(고정인수) : format으로 문자열 상수를 의미하며 서식 문자열이라고도

번째 인수(가변인수) : 이후부터는 타입과 인수 이름이 명시되어 있지 않으며 대신 생략 기호인(ellipsis) 적혀 있다. – 생략기호는 컴파일러에게 이후의 인수에 대해서는 개수와 타입을 점검하지 않도록 하는데 기호에 의해 가변 인수가 가능해진다.

printf("%d", 1,2,3);   // %d 하나가 가변인수 하나 인식


int GetSum(int num, ...)

{

        int sum=0;

        int i;

        va_list ap;

        int arg;

 

        va_start(ap,num);

        for (i=0;i<num;i++) {

               arg=va_arg(ap,int);

               sum+=arg;

        }

        va_end(ap);

        return sum;

}


va_list ap : 함수로 전달되는 인수들은 스택에 저장되며 함수는 스택에서 인수를 꺼내 쓴다.

va_start(ap, Fix) :
가변 인수를 읽기 위한 준비를 하는 것으로 ap포인터 변수가 번째 가변인수를 가리키도록 초기화 한다
.

va_arg(ar,
인수타입) : 가변인수를 실제로 읽는 명령임. va_start ap 번째 가변 인수번지로 맞추어 주므로 ap위치에 있는 값을 읽으면 된다. ap번지에 있는 값의 타입을 지정해 줘야 (정수를 읽으면-va_arg(ap, int), 실수일경우
-va_arg(ap, double) )

va_end(ap) :
가변인수를 읽은 뒷정리를 하는 것.(없어도 )


4.2(월) min, max의 활용

from Study/C언어 2007/04/02 16:30 view 28440
#define max(a, b)  (((a) > (b)) ? (a) : (b))
frame = max(frame-10, 10);

frame은 10미만값을 가질 수 없다.

#define min(a, b)  (((a) < (b)) ? (a) : (b))
frame = min(frame+10, 1000)

frame은 1000을 초과 할 수 없다.

if문으로 할수도 있겠지만 이렇게 범위를 지정 해 놓으니 훨씬 좋아 보인다..
Tag |

3.28(수) strstr, strtok 함수

from Study/C언어 2007/03/28 18:38 view 39422

함수 개요

#include <string.h>

char *strtok( char *str, const char *set);

char *strstr( const char *src, const char *sub);


참고 : 2007/11/29 - [Study/C언어] - 문자열 함수의 구현

strstr 함수는 표준 C에서 처음 도입한 함수다. 이는 문자열 str 안에서 문자열 sub가 처음으로 나오는 위치를 찾아 해당 위치를 가리키는 포인터를 반환한다. 문자열 sub가 문자열 src에 한 번도 나오지 않는 경우에는 널 포인터를 반환한다.

strtok 함수는 문자열 str을 문자열 set에 나온 문자로 구분되는 토큰으로 나눌 때 사용한다. 각각의 토큰을 분리하기 위해 strtok 함수를 여러 번 호출하며, 도중에 문자열 set의 내용을 바꿀 수 있다. strtok 함수를 처음 호출할 때는 str에 문자열을 제공하며, 그 뒤에 이어지는 호출에서는 첫 번째 인자로 널 포인터를 주게 된다. 그러면 strtok함수는 이전에 찾은 토큰의 뒷부분부터 이어 검색을 진행한다.(strtok 함수를 사용해서 문자열 안의 토큰을 검색하는 과정에서 처음 제공된 문자열 str을 도중에 수정하면 안 된다.)

과정을 더 자세히 설명하면, 매개 변수 str에 널 포인터가 제공되지 않으면, strtok 함수는 문자열 str에서 set 에 존재하는 모든 문자를 건너뛰게 된다. 만약 문자열 str이 문자열 set의 문자로만 구성되어 있는 경우, strtok 함수는 토큰을 찾을 수 없기에 결과로 널 포인터를 반환한다. 이때 내부적으로 상태를 저장하기 위해 사용하는 포인터는 널 포인터로 설정된다. 문자열 str에 문자열 set에 나오지 않는 문자가 있는 경우, 내부 상태 포인터가 str에서 해당 문자를 가리키게 되고, str로 널 포인터가 제공된 것처럼 함수 실행이 계속된다.

str과 내부 상태 포인터 모두가 널 포인터인 경우, strtok 함수는 널 포인터를 반환하고 내부 상태 포인터는 널 포인터로 남는다.(이는 모든 토큰을 찾은 이후에 추가로 strtok 함수가 호출되는 경우를 위해서다.) str 이 널 포인터고 내부 상태 포인터가 널 포인터가 아닌 경우, 함수는 내부 상태 포인터가 가리키는 위치부터 시작해서 처음 제공된 str의 나머지 부분에서 set에 포함된 문자를 찾게 되고, 그와 같은 문자를 찾으면 해당 문자를 널 문자로 덮어쓴다. 함수의 결과로는 내부 상태 포인터의 값을 반환하고, 반환 이후에 내부 상태 포인터의 값은 저장된 널 문자 바로 뒤의 문자를 가리키도록 수정된다. 그러한 문자를 찾지 못하는 경우, strtok 함수는 내부 상태 포인터의 값을 반환하고 내부 상태 포인터를 널 포인터로 설정한다.

/*
다음프로그램은표준입력스트림으로부터문자열을입력받아strtok 함수를통해입력받은
라인을단어단위로나누어표준스트림으로출력한다. 이때단어는공백, 쉼표, 마침표, 인용부호,
물음표로구분된다고가정한다.
*/


예제 1.

#include <stdio.h>
#include <string.h>

int main() { char  hp[] = "080)(010)1234-4567";
    char  *p;
                  
    p = strtok( hp, "-()" );

    while( p )
    {
        printf("%s\t", p);
        p = strtok( 0, "-()");
    }

    printf("\n");

    return 0;
}

예제 2.


#include <stdio.h>
#include <string.h>

#define LINELENGTH 80
#define SEPCHARS " .,?\"\n"

int main(void)
{
   
char line[LINELENGTH];
   
char *word;

   
while(1)
    {
        printf(
"\nNext line? (empty line to quit)\n");
        fgets(line, LINELENGTH, stdin);
       
if(strlen(line) <= 1)
           
break;              //프로그램종료
        printf("That line contains these words: \n");
        word = strtok(line, SEPCHARS);              
//첫번째단어를찾음
        while(word != NULL)
        {
            printf(
"\"%s\"\n", word);
            word = strtok(
NULL, SEPCHARS);   //다음단어를찾음
        }
    }
}

Tag |

(Quiz) Cabin이 출력되게 하여라.

from Study/Quiz 2007/03/27 17:12 view 23431

#include <TurboC.h>

 

void InputName(char *pName)

{

    pName=(char *)malloc(12);

    strcpy(pName,"Cabin");

}

 

void main()

{

    char *Name;

 

    InputName(Name);

 

    printf("이름은%s입니다\n",Name);

 

    free(Name);

}


메모리 누수를 막고, Name 주소를 할당해야 한다.

맞나?

more..


Tag |

'배열 포인터' 왠지 포인터 배열을 떠오르지만 2007/03/22 - [Study] - 이차원배열과 포인터 익히기(참고) type(*변수)[]type*변수[x] 를 확연히 구분 짓는 ( ) 괄호를 생각해보면 쉽게 구분 짓을 수 있다.

1. type*변수[]

이 선언문에 사용된 *와 []는 둘 다 구두점이다. *가 앞쪽에 있으므로 변수는 먼저 정수형 포인터가 되고 다음으로 []에 의해 그런 포인터 변수 5개를 모아 배열을 선언하게 된다. 즉, 포인터배열은 포인터 타입의 모임을 정의한 것이라 할 수 있다. 이것의 쓰임새를 살펴보면  

사용자 삽입 이미지



*메모리를 아껴쓰기 위해 태어난 포인터라 생각해도 좋을 것이다. 2차원 배열을 쓴다면 행*열*타입 으로 메모리를
차지하는 byte를 계산 하겠지만 포인터배열에서는 행은 똑같지만 열에서 큰 차이를 보인다. 가령 1반의 학생수가 100명이고 2반의 1명이라면 어떠할까??

2차원 배열에서는 ar[2][100]; 이라고 선언해야 할 것이고 포인터배열에서는 *ar[2] ; 이란 선언을 통해 동적인 메모리 할당을 할 수 있는 것이다. 이러한 개념만 확실히 느끼고 있다면 앞으로 더 느끼는게 많을 듯 싶다.

여기서 또 하나 집고 가야 부분은 포인터배열을 통해 문자열을 입력 받았을 때이다.

사용자 삽입 이미지


arps[0]은 주소를 저장할 수 있는 포인터 변수라 생각하면 된다. *arps[]은 포인터 타입의 배열이라고 생각하기 바란다. 이 포인터 변수는 단지 상수영역(constant)에 있는 문자열 "고양이"등의 시작주소를 가리키는 거라 생각해야 한다. 이러한 문자열은 하나의 상수이기 때문에 변경을 하지 못한다. 이차원배열을 통해 입력 받는 문자열은 스택영역(stack)에 저장되어 얼마든지 접근하여 변경가능 하는 거랑 다른 점이라 할 수 있다.
참고 : 포인터배열

2. type(*변수)[2차 첨자 크기]

변수를 포인터형으로 변환한다. 그리고 나서 [2차첨자크기]만큼의 크기를 갖는 이차원 배열의 번지를 담는 것이다. 2차 첨자 크기는 반드시 기재해야 가리킬 배열의 전체 크기를 구할 수 있다.

*2차원배열을 포인터로 받고 싶을 때 사용한다고 보면 된다.물론 그 이상의 배열도 가능하다.

사용자 삽입 이미지

함수의 인수가 pi[][3]은 (*pi)[3]과 동일하다. 다만 인수가 포인터인지 배열을 받을 포인터인지 무엇을 강조하느냐의 차이 있을 뿐이다.

**포인터 배열은 결국은 배열이고 배열 포인터는 결국은 포인터이다.**
Tag |

소방차는 어쩌라고..

from 잡담 2007/03/27 11:32 view 20092
사용자 삽입 이미지

언제 어디서 불이 날 지 어떻게 아느냐

주차 공간이 없지 않느냐

이런 생각이 더 큰 피해를 불러오지 않을까

하는 생각이 든다. 하지만 꼭 주차를 한 운전자에게만 뭐라고 하지 못하는 지금의 주차 공간은 어떻게든 해결 되야 할텐데..


(정보)프로그래밍 책에 관한 이야기

from Book 2007/03/25 20:10 view 21323

갑자기 책을 사고 싶을 때 어떤 책을 사지 하고 도서사이트를 뒤져보게 되는데

http://kldp.org/node/33777

에 프로그래머들이 읽어야 할 책들에 대한 글들이 많이 있다. 참고해보면 좋을 듯 하다.

Tag |