Chinaunix首页 | 论坛 | 博客
  • 博客访问: 548024
  • 博文数量: 119
  • 博客积分: 3391
  • 博客等级: 中校
  • 技术积分: 981
  • 用 户 组: 普通用户
  • 注册时间: 2009-03-12 11:49
文章分类

全部博文(119)

文章存档

2014年(3)

2013年(1)

2011年(18)

2010年(27)

2009年(70)

我的朋友

分类: C/C++

2011-08-17 21:33:42

setlocale
function
char * setlocale ( int category, const char * locale );

Set or retrieve locale

Sets locale information to be used by the current program, either changing the entire locale or parts of it. The function can also be used to retrieve the current locale's name by passing NULL as the value for locale.

Locales contain information on how to interpret and perform certain input/output and transformation operations taking into consideration location and language specific settings.

Most running environments have certain locale information set according to the user preferences or localization. But, independently of this system locale, on start, all C programs have the "C" locale set, which is a rather neutral locale with minimal locale information that allows the result of programs to be predictable. In order to use the default locale set in the environment, this function can be called with "" as thelocale parameter.

The locale set on start is the same as setlocale(LC_ALL,"C") would set.
The entire default locale can be set by calling setlocale(LC_ALL,""); 
The parts of the current locale affected by a call to this function are specified by parameter category.

ParameterscategoryPart of the locale affected. It is one of the following constant values defined as macros in <>:
namePart affected
LC_ALLThe entire locale.
LC_COLLATEAffects the behavior of  and .
LC_CTYPEAffects character handling functions (all functions of <>, except  and ), and the multibyte and wide character functions
LC_MONETARYAffects monetary formatting information returned by .
LC_NUMERICAffects the decimal-point character in formatted input/output operations and string formatting functions, as well as non-monetary information returned by .
LC_TIMEAffects the behavior of .
localeC string containing the name of a C locale. These are system specific, but at least the two following locales must exist:
locale namedescription
"C"Minimal "C" locale
""Environment's default locale
If the value of this parameter is NULL, the function does not make any change to the current locale, but the name of the current locale is returned by the function.

Return ValueOn success, A pointer to a C string identifying the locale currently set for the category. If category is LC_ALL and different parts of the locale are set to different values, the string returned gives this information in a format which may vary between compiler implementations.

If the function failed to set a new locale, this is not modified and a null pointer is returned.

Example
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
32
/* setlocale example */
#include
#include
#include

 int main ()

    time_t rawtime;
    struct tm * timeinfo;
    char buffer [80];

    struct lconv * lc;

    time ( &rawtime );
    timeinfo = localtime ( &rawtime );

    int twice=0;

    do {
       printf ("Locale is: %s\n", setlocale(LC_ALL,NULL) );

       strftime (buffer,80,"%c",timeinfo);
       printf ("Date is: %s\n",buffer);

       lc = localeconv ();
       printf ("Currency symbol is: %s\n-\n",lc->currency_symbol);
 
       setlocale (LC_ALL,"");
    } while (!twice++);

 return 0;
}


One of the possible outputs when the previous code is run is:
Locale is: C
Date is: 01/15/07 13:33:47
Currecy symbol is:
-
Locale is: English_United States.1252
Date is: 1/15/07 1:33:47 PM
Currency symbol is: $
-
阅读(1851) | 评论(0) | 转发(0) |
给主人留下些什么吧!~~