DELPHI盒子
!实时搜索: 盒子论坛 | 注册用户 | 修改信息 | 退出
检举帖 | 全文检索 | 关闭广告 | 捐赠
技术论坛
 用户名
 密  码
自动登陆(30天有效)
忘了密码
≡技术区≡
DELPHI技术
lazarus/fpc/Free Pascal
移动应用开发
Web应用开发
数据库专区
报表专区
网络通讯
开源项目
论坛精华贴
≡发布区≡
发布代码
发布控件
文档资料
经典工具
≡事务区≡
网站意见
盒子之家
招聘应聘
信息交换
论坛信息
最新加入: jeff1314
今日帖子: 9
在线用户: 2
导航: 论坛 -> DELPHI技术 斑竹:liumazi,sephil  
作者:
男 bear28 ★☆☆☆☆ -
盒子活跃会员
2017/3/29 12:05:34
标题:
E2010 Incompatible types: 'System.TArray<System.Byte>' and 'Pointer'? 浏览:2841
加入我的收藏
楼主: VCL安装在D10.1.2没问题,但安装在D10.2就发生以下的错误讯息,有方法解决吗

[dcc32 Error] AuditDataSet.pas(253): E2010 Incompatible types: 'System.TArray<System.Byte>' and 'Pointer'
----------------------------------------------
-
作者:
男 bear28 ( ) ★☆☆☆☆ -
盒子活跃会员
2017/3/29 12:19:12
1楼: erroe code - //error @Bmint

function TAuditDataSet.MoveToBookMarkFromDelta: Boolean;
var
  BmInt: Integer;
  bm: TBookMark;
begin
  result := False;
  BMInt := FOldValuesDataSet.FieldByName('BookMark').AsInteger; 
  if not BookmarkValid(@BMInt) then Exit;  //error @Bmint
  setlength(bm, sizeof(Integer));
  move(bmint, bm[1], sizeof(Integer));
  BookMark := BM;
  result := True;
end;
----------------------------------------------
-
作者:
男 luwakin (luwakin) ★☆☆☆☆ -
普通会员
2017/3/29 14:16:23
2楼: TAuditDataSet,什么控件?
----------------------------------------------
-
作者:
男 bjlg (蓝天) ★☆☆☆☆ -
盒子活跃会员
2017/3/29 17:54:14
3楼: 直接价格条件编译就行了
if not BookmarkValid(@BMInt) then Exit;  //error @Bmint
 去掉@
就可以了,10.1.2去掉不去掉都可以。
可能限制的严格了
加@是不规范是为了以前版本的
----------------------------------------------
http://delphi.icm.edu.pl/ftp/http://delphi-z.ru
作者:
男 bear28 ( ) ★☆☆☆☆ -
盒子活跃会员
2017/3/29 21:13:01
4楼: 已试过去掉@,编译发生以下的错误讯息

[dcc32 Error] AuditDataSet.pas(253): E2010 Incompatible types: 'System.TArray<System.Byte>' and 'Integer'
----------------------------------------------
-
作者:
男 bear28 ( ) ★☆☆☆☆ -
盒子活跃会员
2017/3/30 9:19:07
5楼: 已编译过去,就是将@BMInt改为IntegerToByte(BMInt)就可编译,想请问的是这样改正确吗,谢谢

function TAuditDataSet.MoveToBookMarkFromDelta: Boolean;
var
  BmInt: Integer;
  bm: TBookMark;
begin
  result := False;
  BMInt := FOldValuesDataSet.FieldByName('BookMark').AsInteger; 
  if not BookmarkValid(IntegerToByte(BMInt)) then Exit;  //error @Bmint
  setlength(bm, sizeof(Integer));
  move(bmint, bm[1], sizeof(Integer));
  BookMark := BM;
  result := True;
end;
----------------------------------------------
-
作者:
男 bjlg (蓝天) ★☆☆☆☆ -
盒子活跃会员
2017/3/30 11:34:32
6楼: 你可以测试一下,其实看一下BookmarkValid的里面的类型和你实际的类型!
----------------------------------------------
http://delphi.icm.edu.pl/ftp/http://delphi-z.ru
作者:
男 bear28 ( ) ★☆☆☆☆ -
盒子活跃会员
2017/3/30 13:46:58
7楼: BookmarkValid的里面的类型-System.Byte
----------------------------------------------
-
作者:
男 yangzh (喜羊羊) ★☆☆☆☆ -
盒子活跃会员
2018/3/20 17:55:29
8楼: [dcc32 Error] OfficePayMoveTroops.pas(105): E2010 Incompatible types: 'System.TArray<System.Byte>' and 'Pointer'
----------------------------------------------
DELPHI家园QQ群:186629229
作者:
男 yangzh (喜羊羊) ★☆☆☆☆ -
盒子活跃会员
2018/3/20 17:56:00
9楼: with DBGridEh1.DataSource.DataSet do
        for i := 0 to DBGridEh1.SelectedRows.Count - 1 do
        begin
          GotoBookmark(Pointer(DBGridEh1.SelectedRows.Items[i]));
          with ADOQuery1 do
          begin
          Close;
          SQL.Clear;
          SQL.Add('INSERT INTO OfficeSystem_PayMoveSalaryTmp');
          SQL.Add('(PeopleRecordCoding,cYearMonth)');
          SQL.Add('VALUES (:PeopleRecordCoding,:cYearMonth)');
          Parameters.ParamByName('PeopleRecordCoding').Value := ADODataSet1.FieldByName('PeopleRecordCoding').Value;
          Parameters.ParamByName('cYearMonth').Value := ADODataSet1.FieldByName('cYearMonth').Value;
          ExecSQL;
          end;
        end;
----------------------------------------------
DELPHI家园QQ群:186629229
作者:
男 yangzh (喜羊羊) ★☆☆☆☆ -
盒子活跃会员
2018/3/27 19:49:52
10楼: 我的也是这个问题,请高手指点:VCL安装在D10.1.2没问题,但安装在D10.2就发生以下的错误讯息,有方法解决吗

[dcc32 Error] OfficePayMoveTroops.pas(105): E2010 Incompatible types: 'System.TArray<System.Byte>' and 'Pointer'

源代码:
with DBGridEh1.DataSource.DataSet do
        for i := 0 to DBGridEh1.SelectedRows.Count - 1 do
        begin
          GotoBookmark(Pointer(DBGridEh1.SelectedRows.Items[i]));
          with ADOQuery1 do
          begin
          Close;
          SQL.Clear;
          SQL.Add('INSERT INTO OfficeSystem_PayMoveSalaryTmp');
          SQL.Add('(PeopleRecordCoding,cYearMonth)');
          SQL.Add('VALUES (:PeopleRecordCoding,:cYearMonth)');
          Parameters.ParamByName('PeopleRecordCoding').Value := ADODataSet1.FieldByName('PeopleRecordCoding').Value;
          Parameters.ParamByName('cYearMonth').Value := ADODataSet1.FieldByName('cYearMonth').Value;
          ExecSQL;
          end;
        end;
----------------------------------------------
DELPHI家园QQ群:186629229
作者:
男 richcomp (richcomp) ★☆☆☆☆ -
普通会员
2018/9/6 10:25:58
11楼: GotoBookmark(DBGridEh1.SelectedRows.Items[i]);
Pointer去掉可以编译通过,具体测试稍后发出
----------------------------------------------
-
信息
登陆以后才能回复
Copyright © 2CCC.Com 盒子论坛 v3.0.1 版权所有 页面执行896.4844毫秒 RSS