我有以下来源:
int main() { 000J; }
Run Code Online (Sandbox Code Playgroud)
使用gcc 4.8.4编译时没有错误.我知道有L或U这样的后缀,但我没有找到关于J.的任何内容.
那它是做什么的?
我目前正在试验中发现的内核参数/proc/sys/vm,特别是dirty_ratio和dirty_background_ratio.
内核doc对两者都有以下解释:
dirty_background_ratio
包含作为包含可用页面和可回收页面的总可用内存的百分比,后台内核刷新线程将开始写出脏数据的页面数.
和
dirty_ratio
包含作为包含空闲页面和可回收页面的总可用内存的百分比,生成磁盘写入的进程本身将开始写出脏数据的页面数.
我的linux系统dirty_background_ratio是10并且dirty_ratio是20.我明白不同之处在于脏数据写的是谁.因此,如果我的已用内存达到10%,则内核开始写回来,永远不会达到20%.
我现在的问题是:具有更高的价值dirty_background_ratio和dirty_ratio任何意义,还是仅仅是"什么是较低的价值和谁拥有它"?
我目前正在Linux中进行一些网络编程,为此我为自己做了一些便携性的问题
typedef char int8;
typedef unsigned char uint8;
typedef short int16;
typedef unsigned short uint16;
typedef int int32;
typedef unsigned int uint32;
Run Code Online (Sandbox Code Playgroud)
现在我想要为常用的套接字函数编写一些包装函数.一个简短的例子是:
int32 rawSocketCreate(int* sockfd, int protocol) {
*sockfd = socket(AF_PACKET, SOCK_RAW, htons(protocol));
if (*sockfd == -1) {
printf("Error creating raw socket\n");
return -1;
}
return 0;
}
Run Code Online (Sandbox Code Playgroud)
我现在的问题是:对于我传递给库函数的参数,我应该继续使用标准数据类型还是使用我自己的?
rawSocketCreate(int* sockfd, int protocol)
/* OR */
rawSocketCreate(int32* sockfd, int32 protocol)
Run Code Online (Sandbox Code Playgroud)