728x90



<code>

#apt-get install fcitx-hangul

#apt-get install fcitx-lib*

#apt-get install fonts-nanum*

#init 6

</code>


라이브러리를 전부다 설치한 이후에, 재시작을 통하여 라이브러리의 적용사항을 적용해준다.

데몬이 있는것인지 확인되지 않기 때문에, 폰트의 적용은 위와같이 재시작으로 이루어져야 한다.


#init 6  명령어가 맘에 들지 않는다면, #reboot 도 좋다.


좌측 Toolbar 의 최하단에 있는 메뉴를 눌러 input 을 검색하고 "입력기" 에 들어간다.

때에 따라 입력기 라고 출력되지 않고, input 이라 출력될 수도 있다.


Current configuration for the input method:

* Active configuration : default (normally missing)

* Normal automatic choice : fcitx (normally ibus or fcitx or uim)

* Override rule : zh_CN, fcitx:zh_TW, fcitx:zh_HK, fcitx:zh_SG, fcitx

* Current override choice (ko_KR)

* Current automatic choice: fcitx

* Number of valid choices : 2 (normally 1)

The override rule is defined in /etc/default/lm-config.

The configuration set by im-config is activated by re-starting X.

사용 중인 것이 기본/자동/동북아시아 언어 중 하나인 경우 자동 설정을 사용할 때 명확히 선택하지 않아도 좋습니다.

사용할 수 있는 입력기 : fcitx xim

모두 필요하지 않으면 하나의 입력기만 설치해주십시오.


대충 확인 누르고 넘어간다


입력기 설정 - fcitx 를 선택하고 확인을 누른다.



그리고 나서 다시 검색기에서 fcitx 를 검색하고 fcitx setting 에 들어가서 

+버튼을 누르고 Hangul 을 검색하고 추가한다.

+버튼을 누르고 Keyborad - english(United state) 를 추가하고 선택한다.



728x90

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

char *replaceAll(char *s, const char *olds, const char *news);


void main(void){
  char s[] = "봉숭아 학당! 봉숭아 학당! 봉숭아 학당! 봉숭아 학당!";
  char *s2;

  printf("원본: %s\n", s);

  s2 = replaceAll(s, "봉숭아", "맹구");

  // 에러가 있으면 NULL 을 리턴. 에러가 없으면 결과 출력
  (s2 != NULL) ? printf("치환: %s\n", s2) : fputs("Replace String Error...\n", stderr);
}




char *replaceAll(char *s, const char *olds, const char *news) {
  char *result, *sr;
  size_t i, count = 0;
  size_t oldlen = strlen(olds); if (oldlen < 1) return s;
  size_t newlen = strlen(news);


  if (newlen != oldlen) {
    for (i = 0; s[i] != '\0';) {
      if (memcmp(&s[i], olds, oldlen) == 0) count++, i += oldlen;
      else i++;
    }
  } else i = strlen(s);


  result = (char *) malloc(i + 1 + count * (newlen - oldlen));
  if (result == NULL) return NULL;


  sr = result;
  while (*s) {
    if (memcmp(s, olds, oldlen) == 0) {
      memcpy(sr, news, newlen);
      sr += newlen;
      s  += oldlen;
    } else *sr++ = *s++;
  }
  *sr = '\0';

  return result;
}

728x90

I created this small function just to practice C code. It's a simple random string generator.

#include <string.h>
#include <time.h>

char *randstring(int length) {    
    static int mySeed = 25011984;
    char *string = "abcdefghijklmnopqrstuvwxyzABCDEFGHIJKLMNOPQRSTUVWXYZ0123456789,.-#'?!";
    size_t stringLen = strlen(string);        
    char *randomString = NULL;

    srand(time(NULL) * length + ++mySeed);

    if (length < 1) {
        length = 1;
    }

    randomString = malloc(sizeof(char) * (length +1));

    if (randomString) {
        short key = 0;

        for (int n = 0;n < length;n++) {            
            key = rand() % stringLen;          
            randomString[n] = string[key];
        }

        randomString[length] = '\0';

        return randomString;        
    }
    else {
        printf("No memory");
        exit(1);
    }
}

The code seems to work ok. Any ideas, improvements or bugs?

I added the mySeed var so that if I call it twice with the same length it doesn't give me the same exact string.

EDIT:

I have changed the code to this:

char *randstring(size_t length) {

    static char charset[] = "abcdefghijklmnopqrstuvwxyzABCDEFGHIJKLMNOPQRSTUVWXYZ0123456789,.-#'?!";        
    char *randomString = NULL;

    if (length) {
        randomString = malloc(sizeof(char) * (length +1));

        if (randomString) {            
            for (int n = 0;n < length;n++) {            
                int key = rand() % (int)(sizeof(charset) -1);
                randomString[n] = charset[key];
            }

            randomString[length] = '\0';
        }
    }

    return randomString;
}

I know that in the sizeof(charset) you don't have to use the (). You only need them when using sizeof with types, but it's just out of habit.

Your function is nice but has a few issues, the main one being that it should not call srand.srand should be called elsewhere (eg in main) just once. This seeds the random number generator, which need only be done once.

A minor issue is that string is badly named - charset might be better. It should be const and you then need not call strlen to find its length sizeof charset -1 is enough. For me, randomString is an unnecessarily long name.

On failing to allocate memory for the string, I would prefer to see a NULL return than an exit. If you want an error message, use perror, but perhaps in the caller, not here. I would be inclined to avoid the possibility of such an error but passing in the buffer and its length instead of allocating.

Some minor points: sizeof(char) is 1 by definition and using short for key is pointless - just use int. Also key should be defined where it is used and I would leave a space after the ; in the for loop definition.

Note also that using rand() % n assumes that the modulo division is random - that is not what rand promises.

Here is how I might do it:

static char *rand_string(char *str, size_t size)
{
    const char charset[] = "abcdefghijklmnopqrstuvwxyzABCDEFGHIJK...";
    if (size) {
        --size;
        for (size_t n = 0; n < size; n++) {
            int key = rand() % (int) (sizeof charset - 1);
            str[n] = charset[key];
        }
        str[size] = '\0';
    }
    return str;
}

Edit July 31 23:07UTC

Why would I write the function to take a buffer instead of allocating the string inside the function?

Returning dynamically allocated strings works fine. And if the memory is later freed there is no problem. But writing this sort of function is a great way to leak memory, for example if the caller doesn't know the memory must be freed or forgets to free memory, or even if he frees it in the main path but forgets to free it in other paths etc.

Memory leaks in a desktop applications might not be fatal, but leaks in an embedded system will lead eventually to failure. This can be serious, depending upon the system involved. In many embedded systems, dynamic allocation is often not allowed or is at least best avoided.

Although it certainly is common not to know the size of strings or buffers at compile time, the opposite is also often true. It is often possible to write code with fixed buffer sizes. I always prefer this option if possible so I would be reluctant to use your allocating function. Perhaps it is better to add a wrapper to a non-allocating function for those cases where you really must allocate dynamically (for example when the random string has to outlive the calling context):

char* rand_string_alloc(size_t size)
{
     char *s = malloc(size + 1);
     if (s) {
         rand_string(s, size);
     }
     return s;
}
  • note that you don't need to return any result because the str parameter is mutable – Quonux Jul 30 '13 at 20:09
  • 1
    That is true but many standard library functions do this too. It can make life easier, eg in printf("%s\n", rand_string(buf, sizeof buf)); – William Morris Jul 30 '13 at 20:12 
  • your right, if you speak of easy life you grab c++,java,go,python,haskell,ruby or d unless your really need the last 100%-20% performance or your forced to use c – Quonux Jul 30 '13 at 20:17 
  • 1
    The questioner is asking specifically about C, not C++, not Java, not go, python etc. Thanks for your input. – William Morris Jul 31 '13 at 0:50
  • @WilliamMorris Could you provide some more insight on why you pass the buffer and not just create the buffer in the string with malloc and return it? Is it because this way it would be easier to free the memory? Is it not possible to free the returned pointer? Thanks. – AntonioCS Jul 31 '13 at 20:56 


'LINUX' 카테고리의 다른 글

How to change broken language -korean  (0) 2019.03.03
C and CPP replace string for function  (0) 2018.07.12
mysql_close segmentation fault (core dumped)  (0) 2018.06.26
Mod_Security2 Ajax Blocking Problem  (0) 2018.06.25
Curl in C usage  (0) 2018.06.24
728x90
MYSQL       *connection=NULL, conn;
MYSQL_RES *sql_result;
MYSQL_ROW sql_row;
int query_stat;

char name[12];
char address[80];
char tel[12];
char query[255];

mysql_init(&conn);

connection = mysql_real_connect(&conn, DB_HOST,
DB_USER, DB_PASS,
DB_NAME, 3306,
(char *)NULL, 0);

위와같이 MYSQL 형 conn 은 MYSQL 형 Socket 을 생성하기 때문에, 연결된 소켓을 connection 에 넘기면 mysql_close 시에 segmentation fault 가 난다.


#include <my_global.h>
#include <mysql.h>

int main(int argc, char **argv)
{  
  MYSQL *con = mysql_init(NULL);

  if (con == NULL) 
  {
      fprintf(stderr, "%s\n", mysql_error(con));
      exit(1);
  }

  if (mysql_real_connect(con, "localhost", "root", "root_pswd", 
          NULL, 0, NULL, 0) == NULL) 
  {
      fprintf(stderr, "%s\n", mysql_error(con));
      mysql_close(con);
      exit(1);
  }  

  if (mysql_query(con, "CREATE DATABASE testdb")) 
  {
      fprintf(stderr, "%s\n", mysql_error(con));
      mysql_close(con);
      exit(1);
  }

  mysql_close(con);
  exit(0);
}

이와 같이 conn 은 1개여야 한다. 절대로 connection 같은것을 만들어 넘기지 않도록 한다.

'LINUX' 카테고리의 다른 글

C and CPP replace string for function  (0) 2018.07.12
Random String generator in C  (0) 2018.07.04
Mod_Security2 Ajax Blocking Problem  (0) 2018.06.25
Curl in C usage  (0) 2018.06.24
Dynamic Library and Static Library  (0) 2018.06.24

+ Recent posts