_GUN_SOURCE宏

问题描述:在编译程序时,提示一个错误和一个警告。

errorstorage size of tz isn’t know 其中tzstruct timezone类型的变量。

warningimplicit declaration of function lstat

 

使用man手册查了一下,发现tz需要加上sys/time.h头文件,lstat需要加上sys/lstat.h头文件,但这两个头文件都已经包含了,百思不得其解。

 

无意间搜到一种解决方案,在编译时加上-D_GNU_SOURCE(定义_GNU_SOURCE),于是照做,程序编译通过。继续了解了_GNU_SOURCE宏,发现它是在features.h中用于特性控制的一个功能测试宏,而上面提到的两个头文件sys/time.h, sys/stat.h都包含了features.h文件。

 

</user/include/features.h>

/* If _GNU_SOURCE was defined by the user, turn on all the other features.  */

#ifdef _GNU_SOURCE

# undef  _ISOC99_SOURCE

# define _ISOC99_SOURCE 1

# undef  _POSIX_SOURCE

# define _POSIX_SOURCE  1

# undef  _POSIX_C_SOURCE

# define _POSIX_C_SOURCE    200809L

# undef  _XOPEN_SOURCE

# define _XOPEN_SOURCE  700

# undef  _XOPEN_SOURCE_EXTENDED

# define _XOPEN_SOURCE_EXTENDED 1

# undef  _LARGEFILE64_SOURCE

# define _LARGEFILE64_SOURCE    1

# undef  _BSD_SOURCE

# define _BSD_SOURCE    1

# undef  _SVID_SOURCE

# define _SVID_SOURCE   1

# undef  _ATFILE_SOURCE

# define _ATFILE_SOURCE 1

#endif

 

其中_ISOC99_SOURCE, _POSIX_SOURCE, _XOPEN_SOURCE都是功能测试宏,用于指示是否包含对应标准的特性,而这些不同的特性源于过去20多年来进行的各种标准化工作(ANSI, ISO, POSIX, FIPS等),不同的标准支持实现了不同的特性,如系统时间的获取,stat结构是在ANSI标准中是不支持的,而定义了_GNU_SOURCE相当于开启了对所有特性的支持。

 

另外一个问题:在程序运行时,提示mmap出错,错误号22(Invalid argument)

我的工作目录是window桌面上的一个目录,通过虚拟机工具共享到linux里使用,mmap映射的文件也在这个目录中。

 

怀疑是虚拟机内存不足,看了下freemem,内存是足够的,把机器重启了,依然出现同样的问题。把代码拷到机房的机器(64bit),编译运行,工作正常。猜想被映射的文件不是系统下的文件导致映射失败,于是把被映射文件拷到家目录下,工作正常。原理我也解释不清楚,理论上能打开文件不就能进行内存映射么?

 

转载于:https://www.cnblogs.com/yunnotes/archive/2013/04/19/3032359.html

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
以下是对您提供的查询语句进行逐行解释的说明: 1. `SELECT S.KIGOU, CASE WHEN S.BANK IS NULL AND (instr(S.KOU_NO, '9') = 1 OR instr(S.KOU_NO, '9') = 0) THEN S.KOU_NO ELSE S.BANK END AS KOU_NO` - 查询语句的SELECT子句,选择了两个列:S.KIGOU和一个CASE表达式,将根据条件返回S.KOU_NO或S.BANK作为KOU_NO。 2. `FROM CS210_SEIBAN S, CS220_ROMDATA R` - 查询语句的FROM子句,指定了要查询的表,这里是CS210_SEIBAN表和CS220_ROMDATA表,使用别名S和R分别表示这两个表。 3. `WHERE S.CHU_NO = R.CHU_NO AND S.KIGOU = R.KIGOU AND S.TAN_GUN = R.TAN_GUN` - 查询语句的WHERE子句,指定了用于连接两个表的条件,这里是CS210_SEIBAN表和CS220_ROMDATA表中对应列的值相等。 4. `AND R.SYUBETU = 'PUS' AND S.TAN_GUN = '1'` - 查询语句的WHERE子句,指定了进一步的条件限制:CS220_ROMDATA表中SYUBETU列的值必须为'PUS',CS210_SEIBAN表中TAN_GUN列的值必须为'1'。 5. `AND ((S.BANK IS NOT NULL AND S.BANK = R.KOU_NO) OR (S.BANK IS NULL AND S.KOU_NO = R.KOU_NO))` - 查询语句的WHERE子句,指定了一个复杂的条件:要么S.BANK不为空且等于R.KOU_NO,要么S.BANK为空且S.KOU_NO等于R.KOU_NO。 6. `AND S.KOU_NO = '99999' AND S.CHU_NO = '1234567' AND R.STATUS = '4'` - 查询语句的WHERE子句,指定了进一步的条件限制:CS210_SEIBAN表中KOU_NO列的值必须为'99999',CHU_NO列的值必须为'1234567',CS220_ROMDATA表中STATUS列的值必须为'4'。 7. `AND S.DELETED_DATE IS NULL AND R.DELETED_DATE IS NULL` - 查询语句的WHERE子句,指定了进一步的条件限制:CS210_SEIBAN表中DELETED_DATE列和CS220_ROMDATA表中DELETED_DATE列的值都必须为空。 8. `ORDER BY R.ROM_DATE DESC FETCH FIRST 1 ROWS ONLY` - 查询语句的ORDER BY子句,按照CS220_ROMDATA表中的ROM_DATE列进行降序排序,并且只返回第一行结果。 希望以上解释能够帮助您理解该查询语句的逻辑和功能。如有疑问,请随时提出。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值