什么与指针相关的东西在Delphi XE8的移动编译器中不起作用?

Sid*_*esh 5 delphi pointers llvm delphi-xe8

Embarcadero的docwiki页面基于LLVM的Delphi编译器列出了Delphi XE8中的几种语言更改.其中一颗子弹说:

基于LLVM的Delphi编译器不支持使用指针.

这在实践中究竟意味着什么?以前在Delphi XE7中使用哪些与指针相关的东西,在Delphi XE8中不再有效?我似乎无法在Embarcadero的网站上找到对此的深入解释.例如,据说包含更多信息的从桌面迁移Delphi代码到Mobile的页面没有提到"Pointer"这个词.

Dav*_*nan 5

基于LLVM的Delphi编译器不支持使用指针.

这必须是文档中的错误.只需看看RTL.它使用指针很厚.

比如,怎么样CompareMem.它的定义如下:

function CompareMem(P1, P2: Pointer; Length: Integer): Boolean;
Run Code Online (Sandbox Code Playgroud)

实现运行如下:

function CompareMem(P1, P2: Pointer; Length: Integer): Boolean;
{$IF defined(POSIX)}
begin
  if Length <= 0 then
    Result := True
  else
    Result := memcmp(P1^, P2^, Length) = 0;
end;
{$ELSEIF defined(PUREPASCAL)}
....
{$ENDIF !PUREPASCAL}
Run Code Online (Sandbox Code Playgroud)

POSIX代码由移动目标使用.

或者TObject看起来像这样:

type
  TObject = class
  public
    constructor Create;
    procedure Free;
    procedure DisposeOf; {$IFNDEF AUTOREFCOUNT} inline; {$ENDIF}
    class function InitInstance(Instance: Pointer): TObject {$IFDEF AUTOREFCOUNT} unsafe {$ENDIF};
    procedure CleanupInstance;
    function ClassType: TClass; inline;
    class function ClassName: string;
    class function ClassNameIs(const Name: string): Boolean;
    class function ClassParent: TClass;
    class function ClassInfo: Pointer; inline;
    class function InstanceSize: Integer; inline;
    class function InheritsFrom(AClass: TClass): Boolean;
    class function MethodAddress(const Name: _ShortStr): Pointer; overload;
    class function MethodAddress(const Name: string): Pointer; overload;
    class function MethodName(Address: Pointer): string;
    class function QualifiedClassName: string;
    function FieldAddress(const Name: _ShortStr): Pointer; overload;
    function FieldAddress(const Name: string): Pointer; overload;
    function GetInterface(const IID: TGUID; out Obj): Boolean;
    class function GetInterfaceEntry(const IID: TGUID): PInterfaceEntry;
    class function GetInterfaceTable: PInterfaceTable;
    class function UnitName: string;
    class function UnitScope: string;
{$IFDEF AUTOREFCOUNT}
    function __ObjAddRef: Integer; virtual;
    function __ObjRelease: Integer; virtual;
{$ENDIF}
    function Equals(Obj: TObject): Boolean; virtual;
    function GetHashCode: Integer; virtual;
    function ToString: string; virtual;
    function SafeCallException(ExceptObject: TObject;
      ExceptAddr: Pointer): HResult; virtual;
    procedure AfterConstruction; virtual;
    procedure BeforeDestruction; virtual;
    procedure Dispatch(var Message); virtual;
    procedure DefaultHandler(var Message); virtual;
    class function NewInstance: TObject {$IFDEF AUTOREFCOUNT} unsafe {$ENDIF}; virtual;
    procedure FreeInstance; virtual;
{$IFDEF AUTOREFCOUNT}
  protected
{$ENDIF}
    destructor Destroy; virtual;

{$IFDEF CPP_ABI_SUPPORT}
    procedure CPP_ABI_1; virtual;
    procedure CPP_ABI_2; virtual;
    procedure CPP_ABI_3; virtual;
{$ENDIF !CPP_ABI_SUPPORT}

  protected
    function GetDisposed: Boolean; inline;
    procedure CheckDisposed; {$IFNDEF AUTOREFCOUNT} inline; {$ENDIF}

{$IFDEF AUTOREFCOUNT}
  private const
    objDestroyingFlag = Integer($80000000);
    objDisposedFlag = Integer($40000000);
  protected
    [Volatile] FRefCount: Integer;
    class procedure __MarkDestroying(const Obj); static; inline;
    class function __SetDisposed(const Obj): Boolean; static; inline;
  public
    property RefCount: Integer read FRefCount;
{$ENDIF}
    property Disposed: Boolean read GetDisposed;
  end;
Run Code Online (Sandbox Code Playgroud)

很明显,这里的指针用于移动平台.

阅读有关该主题的Embarcadero白皮书:Delphi移动开发语言.它再次涵盖了多次使用指针,很明显它们是受支持的.现在,不鼓励使用指针也是如此,如果可以很容易地避免使用指针,那么我们鼓励你这样做.但这与指出编译器不支持指针的情况完全不同.

至少具有讽刺意味的是,Embarcadero正在传播他们自己产品的FUD.

  • 从pdf:`减少或删除指针使用,当我们朝着一些自动内存管理方向移动时,不鼓励直接使用指针.使用通用容器类而不是TList(内部基于指针)是Delphi RTL库正在进行的迁移的一个很好的例子,我们建议Delphi开发人员也在他们的代码中执行类似的转换. (6认同)
  • 我不能说ARC的引入给语言带来了很多好处.他们(EMB)自己的开发和开发人员之间的痛苦甚至可能是反作用.ARC模型被认为是未来的根类型语言的路径,其中所有变量都是对象. (2认同)