- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我有以下结构:
typedef struct _info{
DWORD myInfo;
BYTE *pInfo;
LPWSTR ExtData;
} Info;
NativeCall
表示这个结构体因此:
class Info is repr('CStruct') {
has int32 $.myInfo;
has Pointer[int8] $.pInfo ;
has Pointer[int16] $.ExtData;
}
$.pInfo
指向的数据?
最佳答案
这种表示对我来说似乎没问题……鉴于这个发明的 C 库:
(请不要选择我的 C foo - 它离题了)
#include <stdlib.h>
#include <stdio.h>
#include <string.h>
typedef unsigned long int DWORD;
typedef unsigned char BYTE;
typedef char * LPWSTR;
typedef struct _info{
DWORD myInfo;
BYTE *pInfo;
LPWSTR ExtData;
} Info;
Info* create_info();
void display_info();
void double_info(Info*);
Info*
create_info() {
DWORD init_myinfo = 2016;
BYTE init_pinfo = 37;
char init_ExtData[] = "Hello World";
Info *new_info = malloc(sizeof(Info));
if (new_info == NULL) {
printf( "Memory alloc failed\n" );
exit(1);
}
new_info->myInfo = init_myinfo;
BYTE *pinfo = malloc(sizeof(BYTE));
*pinfo = init_pinfo;
new_info->pInfo = pinfo;
char *ext_data = malloc(sizeof(init_ExtData));
strcpy(ext_data, init_ExtData);
new_info->ExtData = ext_data;
return new_info;
}
void
display_info(Info *inf) {
printf("myInfo: %lu\n", inf->myInfo);
printf("pInfo: %i\n", *inf->pInfo);
printf("ExtData: %s\n", inf->ExtData);
}
void
double_info(Info *inf) {
inf->myInfo *= 2;
if ( *(inf->pInfo) < 128 )
*(inf->pInfo) *= 2;
int extdata_len = strlen(inf->ExtData);
char *tmp_extdata = malloc(extdata_len * 2 + 2);
strncpy(tmp_extdata, inf->ExtData, extdata_len);
tmp_extdata[extdata_len] = '+';
strcpy(&tmp_extdata[extdata_len+1], inf->ExtData);
inf->ExtData = tmp_extdata;
}
那么你使用 NativeCall 的 perl6 结构定义或多或少是有效的:
#!/usr/bin/env perl6
use NativeCall;
class Info is repr('CStruct') {
has int32 $.myInfo;
has Pointer[int8] $.pInfo ;
has Pointer[Str] $.ExtData;
method Str {
qq:to/END HERE/;
myInfo: $!myInfo
pInfo: { $!pInfo.deref }
ExtData: { $!ExtData.deref }
END HERE
}
}
our sub create_info() returns Info is native('pinfo') { * }
our sub display_info(Info) is native('pinfo') { * }
our sub double_info(Info is rw) is native('pinfo') { * }
my Info $inf = create_info();
say 'Displaying $inf after calling create_info()';
display_info $inf;
double_info $inf;
say 'Displaying $inf after calling double_info()';
display_info $inf;
say 'Displaying $inf by calling attribute methods on Perl6 object';
say "myInfo: $inf.myInfo()";
say "pInfo: $inf.pInfo.deref()";
say "ExtData: $inf.ExtData.deref()";
say 'Displaying $inf by stringifying Perl6 object';
say "$inf";
exit 0;
这会产生一系列结果;
Displaying $inf after calling create_info()
myInfo: 2016
pInfo: 37
ExtData: Hello World
Displaying $inf after calling double_info()
myInfo: 4032
pInfo: 74
ExtData: Hello World+Hello World
Displaying $inf by calling attribute methods on Perl6 object
myInfo: 4032
pInfo: 74
ExtData: Hello World+Hello World
Displaying $inf by stringifying Perl6 object
myInfo: 4032
pInfo: 74
ExtData: Hello World+Hello World
或者,可以在 perl6 类中隐藏更多的“胶水”;
#!/usr/bin/env perl6
use NativeCall;
class Info is repr('CStruct') {
has int32 $.myInfo is rw ;
has Pointer[int8] $!pInfo ;
has Pointer[Str] $!ExtData ;
my sub create_info() returns Info is native('pinfo') { * }
my sub display_info(Info) is native('pinfo') { * }
my sub double_info(Info is rw) is native('pinfo') { * }
method new { create_info() }
method display { display_info(self) }
method double { double_info(self) }
method pInfo { $!pInfo.deref }
method ExtData { $!ExtData.deref }
method Str {
qq:to/END HERE/;
myInfo: { self.myInfo }
pInfo: { self.pInfo }
ExtData: { self.ExtData }
END HERE
}
}
my Info $inf .= new;
say 'Displaying $inf after calling .new';
$inf.display ;
$inf.double ;
say 'Displaying $inf after calling .double';
$inf.display ;
say 'Displaying $inf by calling attribute methods on Perl6 object';
say "myInfo: $inf.myInfo()";
say "pInfo: $inf.pInfo()";
say "ExtData: $inf.ExtData()";
$inf.myInfo = 12046 ;
say 'Displaying $inf by stringifying Perl6 object';
say "$inf";
exit 0;
......更干净的外观。它同样产生;
Displaying $inf after calling .new
myInfo: 2016
pInfo: 37
ExtData: Hello World
Displaying $inf after calling .double
myInfo: 4032
pInfo: 74
ExtData: Hello World+Hello World
Displaying $inf by calling attribute methods on Perl6 object
myInfo: 4032
pInfo: 74
ExtData: Hello World+Hello World
Displaying $inf by stringifying Perl6 object
myInfo: 12046
pInfo: 74
ExtData: Hello World+Hello World
笔记:
关于raku - 包含指针的 NativeCall 结构,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/35246529/
虽然总是可以使用 mixin 或方法覆盖来修改 Bool 强制转换,但默认情况下哪些值被认为是真值,哪些值被认为是假值? 注意:这个问题是 asked previously ,但不幸的是它太旧了,它的
也许我遗漏了一些东西,但我想知道这段代码是否有充分的理由 编译 role L { method do-l (Int, Int --> Int ) { ... } } class A does L
FAQ:在 Raku 中如何检查列表是否为空? 是否有比以下更惯用的方法: my @l = (); say @l.elems == 0; say @l == (); say @l.Bool; doc
FAQ:在 Raku 中,如何从列表中删除重复项以仅获取唯一值? my $arr = [1, 2, 3, 2, 3, 1, 1, 0]; # desired output [1, 2, 3, 0] 最
我使用 Raku 进行一些计算,因为它有很好的数字类型。但是,我在使用“.raku”时遇到问题 say (1/6+1/6).raku # 我们得到这个。然而, say (1/10+1/10).raku
常见问题解答:在 Raku 中,如何将字符串转换为十六进制的字节列表(即十六进制解码器) 目前,我有: say "I ❤ 🦋".encode.list.map(*.base(16)); # (49
在 1990 年代和 2000 年代,编程语言爱好者几乎没有讨论过分隔延续的话题。它最近重新成为编程语言讨论中的一个主要问题。 我希望有人至少可以权威地说出 Rakudo 背后的延续(与 Raku 相
我选择在 Perl 6 中重新设计我之前代码的一部分,在这种情况下是一个棋盘。前两个类运行良好(或者至少工作正常,我知道的很少,我无法确定它们的正确性) ,但我坚持第三。这是代码: #!/home/h
如何重现数组的每个元素 x 次? 例如 for my @a=;和 x=5 ,结果应该是这样的 (blu blu blu blu blu red red red red red) 我想出了这个 say
我正在尝试使用一个变量并在一个步骤中为其分配一个表达式: 给定的(示例)代码 my @l=; my $i=0; while $i ; my $i=0; say @l[$i =~ ($i+1) * 2]
我想连续打印偶数,但我不能。 use Terminal::ANSIColor; # Wanna print even numbers in red for { $_ %2 == 0 ?? say c
目前(截至 2020 年 8 月)Rakudo 不在编译时对函数的返回值进行类型检查;也就是说,它不提供函数满足其返回约束的静态保证。具体来说,以下两个函数都编译为 Raku: sub get-int
自从我上次更新我在 Raku 生态系统中的一个模块以来已经有一段时间了。我需要更新中央注册表文件/存储库还是会自动检测到更新? 最佳答案 修改版本号后,我等了一个小时左右,然后 zef可以安装模块 -
有人能告诉我如何在正在执行的 Raku 脚本中找到脚本的路径吗? 我正在 Raku 中寻找与此 Perl 代码等效的代码: $path=abs_path($0); 最佳答案 使用 $*PROGRAM见
Raku的正则表达式有两种交替形式:|和||。有什么区别 ? say 'foobar' ~~ / foo || foobar / # 「foo」 say 'foobar' ~~ / foo | fo
我故意避免使用术语 defined因为一个变量很可能有一个定义的值,但 .defined方法将返回 false(例如,失败)。 有什么方法可以确定变量是否已为其设置了值? my $foo; say $
我从/path/to/data 运行/home/foo/bar.p6 并显示“Segmentation fault (core dumped)” 我在/var/crash 或我的主目录或当前工作目录中
在 cli 上,在 linux 中,cp -p保留文件上修改/访问的时间戳。是否可以直接在 Raku 中执行相同操作? Rosetta 示例使用 Nativecall,它可以通过系统调用来完成,但看起
我想重用 token parameter来自 Perl6::Grammar在我的自定义俚语中添加“自定义参数”参数不带 cargo 培养 . 我的意思是说: my $main-grammar = $*
关闭。这个问题需要更多focused .它目前不接受答案。 想改善这个问题吗?更新问题,使其仅关注一个问题 editing this post . 去年关闭。 Improve this questio
我是一名优秀的程序员,十分优秀!