C 语言的位域提供了一种在结构中定义任意宽度字段的相当方便的方法(暂时不要考虑可移植性问题。)例如,这是一个带有几个字段和一个“标志”的简单结构:
#pragma pack(push,1)
struct my_chunk{
unsigned short fieldA: 16;
unsigned short fieldB: 15;
unsigned short fieldC: 1;
};
#pragma pop()
添加#pragma 语句将此结构打包成一个 32 位字(确保 my_chunk 指针的指针操作对齐,例如,同时节省空间)。
访问每个字段在语法上非常好:
struct my_chunk aChunk;
aChunk.fieldA = 3;
aChunk.fieldB = 2;
aChunk.fieldC = 1;
在没有语言帮助的情况下执行此操作的另一种方法相当丑陋,并且几乎转变成汇编程序。例如一种解决方案是为您要访问的每个字段设置位移宏:
#define FIELD_A 0xFF00
#define FIELD_B 0x00FE
#define FIELD_C 0x0001
#define get_field(p, f) ((*p)&f)
#define set_field(p, f, v) (*p) = (v<<f) + (*p)&(~f)
...
set_field(&my_chunk, FIELD_A, 12345);
.. 或大致类似的东西(更正式的,看看 this )
所以问题是,如果我想在 go 中“执行”位域,这样做的最佳做法是什么?
最佳答案
"There are no current plans for struct bitfields in Go."
您可以编写一个 Go 包来执行此操作;不需要汇编程序。
关于Go:位域和位打包,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/5793098/
在Railcasts上,我注意到一个非常有趣的功能“转到符号”窗口。它像Command-T一样工作,但显示当前文件中可用的类和方法。如何在vim中获取它? 最佳答案 尝试:helptags有各种程序和脚本可以生成标记文件。此外,标记文件格式非常简单,因此很容易将sed(1)或类似的脚本组合在一起,无论您使用何种语言,它们都可以生成标记文件。轻松获取标记文件(除了下载生成器之外)的关键在于格式化样式而不是实际解析语法。 关于ruby-on-rails-Textmate'Gotosymbol
目录一.大致如下常见问题:(1)找不到程序所依赖的Qt库version`Qt_5'notfound(requiredby(2)CouldnotLoadtheQtplatformplugin"xcb"in""eventhoughitwasfound(3)打包到在不同的linux系统下,或者打包到高版本的相同系统下,运行程序时,直接提示段错误即segmentationfault,或者Illegalinstruction(coredumped)非法指令(4)ldd应用程序或者库,查看运行所依赖的库时,直接报段错误二.问题逐个分析,得出解决方法:(1)找不到程序所依赖的Qt库version`Qt_5'
我有一个使用Qt4绑定(bind)的Ruby应用程序。我希望能够打包并发布它。我查看了其他应用程序,例如rake和puppet,以了解它们是如何打包的。rake和puppet都被打包为gems。当我意识到rake和puppet都是更多的系统级工具而不是用户级应用程序时,我开始走这条路。我也看过orca,但它只是windows。除了gem或orca,是否还有其他选项可用于打包RubyGUI应用程序?我想要跨平台的东西。 最佳答案 看看platformgem规范。您可以为您的代码支持的每个平台打包一个gem。Somegemsconsis
我对某些ruby行为感到困惑。看下面的代码:[127].pack("C")=="\x7f"#=>true这是有道理的。现在:[128].pack("C")#=>"\x80""\x80"#=>"\x80"[128].pack("C")=="\x80"#=>falsepackoption"C"代表8-bitunsigned(unsignedchar),应该可以存储128的值。两个字符串也打印相同的东西,那么为什么它们不相等呢?这与编码有关吗?我使用的是ruby2.0.0p247。 最佳答案 这是错误的,因为编码不同:[128].
自97年以来我一直在使用vi/vim进行各种快速编辑和管理任务,但最近才考虑使用它来替换Netbeans作为我选择的ruby编辑器。我发现一件事在Netbeans和Eclipse中非常有用的是Ctrl+Click“转到定义”功能,您可以在其中按住Ctrl键并单击一个类或方法,然后它将带您了解定义。现在,我玩过丰富的ctags和rails.vim,而且很接近,但没有雪茄。这就是我想要的:默认情况下在Netbeans和Eclipse中,您可以在本地rails中按住ctrl并单击本地方法或类项目,但你也可以ctrl+click定义在gems或用Ruby编写的系统库。以Netbeans为例
我有一个名为Maid的命令行实用程序我目前分发为aRubyGem.我还想将其作为.deb包分发tomakeiteasierforUbuntuuserstoinstall.现在,Ubuntu用户必须手动完成很多工作,尤其是对于不熟悉Ruby的人:sudoapt-getinstallrubysudoapt-getinstallrubygems#Makesure`ruby`and`gem`arein`$PATH`sudogeminstallmaidmaidversion#examplecommand理想情况下,我希望在全新的Ubuntu安装上安装一个命令:sudoapt-getinstall
我有一个Buildr扩展,我将其打包为一个gem。我有一组要添加到包中的脚本。目前,我将这些脚本存储为正在写入文件的大文本block。我更愿意拥有可以直接复制或读/写回的单个文件。我希望将这些文件打包到gem中。我在打包它们时没有问题(只需在rakeinstall之前将它们粘贴到文件系统中)但我不知道如何访问它们。是否有GemResources捆绑类型的东西? 最佳答案 基本上有两种方式,1)您可以使用__FILE__在您的gem中加载与Ruby文件相关的资源:defpath_to_resourcesFile.join(File.d
我正在开发一个部署为gem的Ruby应用程序。我想在gem中包含一个只读数据文件,但我不确定应该如何/在哪里打包关于一些背景知识,此应用程序处理MIDI规范,其中包括数百个常量值。例如,Controller“ChannelVolume”始终由值7标识。“Sustain”由64等标识。过去,人们将这些值作为一大组常量包含在他们的代码中。这很好,但对我来说,将它们包含在与语言无关的格式(例如yaml)中似乎更合适使用GEM_PATH定位yaml文件很丑陋,而且在非gem部署中使用库时也不起作用。谢谢你的帮助 最佳答案 我认为RubyGe
即使阅读了标准文档,我仍然无法理解Ruby的Array#pack是如何实现的和String#unpack完全有效。这是给我带来最大麻烦的示例:irb(main):001:0>chars=["61","62","63"]=>["61","62","63"]irb(main):002:0>chars.pack("H*")=>"a"irb(main):003:0>chars.pack("HHH")=>"```"我希望这两个操作返回相同的输出:“abc”。他们每个人都以不同的方式“失败”(并不是真正的失败,因为我可能预料到了错误的事情)。那么两个问题:这些输出背后的逻辑是什么?我怎样才能达到我
我有一颗rubywebapp使用lilypond根据用户输入生成乐谱。我想将主机移至heroku(我最近在几个项目中使用了heroku,并且非常喜欢它,而且我的流量足够低,可以免费在heroku上托管它,至少有一段时间)。然而,heroku的dyno架构不允许你通过ssh进入并安装你想要的任何包......相反,你给它一个gemslist,它会为你安装gems。因此,如果我要部署到heroku,我将需要将lilypond打包为gem。我已经发布了一些纯rubygem,但没有处理native扩展或预编译二进制文件或类似的东西。是否可以将一些预编译的二进制文件打包到gem中?理想情况下