| 网站首页 | 业界新闻 | 小组 | 威客 | 人才 | 下载频道 | 博客 | 代码贴 | 在线编程 | 编程论坛
欢迎加入我们,一同切磋技术
用户名:   
 
密 码:  
共有 3391 人关注过本帖
标题:有没有办法,在C代码中声明,编辑的时候使用C99标准编译呢
取消只看楼主 加入收藏
kkbbggtt
Rank: 1
等 级:新手上路
帖 子:8
专家分:0
注 册:2012-8-7
结帖率:50%
收藏
已结贴  问题点数:10 回复次数:5 
有没有办法,在C代码中声明,编辑的时候使用C99标准编译呢
    我是在ubuntu10.04系统下做C语言开发,程序中使用到有关unicode的数据。
在命令行下敲gcc ... “-std=c99”... 编译时没有产生警告。
于是在Makefile中的生成目标文件那一部分也写了 gcc ... “-std=c99” ...,但是之后使用make编译时,产生了一屏幕警告,内容如下:
warning: universal character names are only valid in C++ and C99,请问这如何消除??
搜索更多相关主题的帖子: C语言 warning character 办法 
2012-09-06 11:38
kkbbggtt
Rank: 1
等 级:新手上路
帖 子:8
专家分:0
注 册:2012-8-7
收藏
得分:0 
为毛都没有回应呢- -!
2012-09-10 13:25
kkbbggtt
Rank: 1
等 级:新手上路
帖 子:8
专家分:0
注 册:2012-8-7
收藏
得分:0 
回复 3楼 TonyDeng
我也搞不清楚其中的关系,只是按照C99标准编译的话,不会出警告,否则警告一大屏幕,不太好看。。。
2012-09-10 14:58
kkbbggtt
Rank: 1
等 级:新手上路
帖 子:8
专家分:0
注 册:2012-8-7
收藏
得分:0 
回复 5楼 TonyDeng
大致如下:
情况一:    static char *array[] = {"\u1000", "\u1001", "\u1002" ...};
然后编译时,数组中有几个元素就出几个警告;
情况二:    if(0 != strncmp(str_in, "\u1000", strlen("\u1000"))) {
                        .....;
                  }
这样也会出警告。
警告是这样的:warning: universal character names are only valid in C++ and C99。
2012-09-10 15:13
kkbbggtt
Rank: 1
等 级:新手上路
帖 子:8
专家分:0
注 册:2012-8-7
收藏
得分:0 
回复 7楼 TonyDeng
我测试了下,定义方式更改为:
    static wchar_t array[] = {L'\u1000', L'\u1001', L'\u1002' ...};

编译文件时,使用:gcc main.c -o main命令,还是会出警告,警告与以前一致;
使用gcc "--std=c99" main.c -o main命令,则没有出现警告。

这是不是说明,c89标准不支持这个类型的数据呢?

还有,我前边的定义方式:static char *array[] = {"\u1000", "\u1001", "\u1002" ...}; 是因为后边需要大量的字符串比较和拼接操作,
这样的单字节字符串也是可以的吧- -!
2012-09-10 16:02
kkbbggtt
Rank: 1
等 级:新手上路
帖 子:8
专家分:0
注 册:2012-8-7
收藏
得分:0 
多谢大神!!!
不过我想知道有没有办法在代码中告诉编译器,编译时使用c99标准编译呢?
比如C++有个命名空间之类的东西如:using namespace std;编译时,会把cin、cout编译成std.cin、std.cout。
如果C语言代码中加上一句什么什么的,就可以控制编译器标准就太好了~~~
2012-09-10 16:28
快速回复:有没有办法,在C代码中声明,编辑的时候使用C99标准编译呢
数据加载中...
 
   



关于我们 | 广告合作 | 编程中国 | 清除Cookies | TOP | 手机版

编程中国 版权所有,并保留所有权利。
Powered by Discuz, Processed in 0.041904 second(s), 8 queries.
Copyright©2004-2024, BCCN.NET, All Rights Reserved