类似于关系数据库的模型的类或结构?

时间:2015-04-25 17:10:33

标签: ios class swift struct reference

有问题的申请建立如下:

  • 用户选择作业
  • 该职位可以有很多组成部分
  • 每个组件可以有许多lineitems。

我不清楚这应该如何构建 - 这应该是类还是结构?看到一次只处理一份工作,我相信工作应该是一个班级。但是,当某个对象类型有多个时,我不清楚如何形成它们,比如组件和lineitem对象。

该应用程序由ViewControllers和TableViewControllers组成。所有数据都是从JSON中的服务器获取的,并根据需要填充到适当的视图中。以下是当前设置的对象类型:

工作对象:

require_once('TwitterAPIExchange.php');

/** Set access tokens here - see: https://dev.twitter.com/apps/ **/
$settings = array(
    'oauth_access_token' => "***",
    'oauth_access_token_secret' => "***",
    'consumer_key' => "***",
    'consumer_secret' => "***"
);

    $url = 'https://api.twitter.com/1.1/account/update_profile_image.json';
    $requestMethod = 'POST';

    $postfields = array(
        'image' => '',
        'include_entities' => 'false',
        'skip_status' => 'false'
    );

    $twitter = new TwitterAPIExchange($settings);
    echo $twitter->buildOauth($url, $requestMethod)
                 ->setPostfields($postfields)
                 ->performRequest();

像这样的组件:

// Job Object
//
public struct Job {
    static var globalId : String?
    static var name : String?
    static var status : String?
    static var client = Client()
    static var components = Array<Component>()
    // etc..
}

最后,一个lineitem:

// JobComponent Object
//
public struct Component {
    var name:String? = ""
    var fmRecordId : String?
    var startTS:NSDate?
    var endTS:NSDate?
    var notes:String? = ""
    var items = Array<Lineitem>()
    // etc...
}

所有这些对象都是在// Lineitem Object // public struct Lineitem { var fmRecordId = String() var itemName = String() var itemNumber = String() // etc... } 被称为&#34; PL&#34;内构建的。

当用户选择lineitem并编辑它的值时,这些值在编辑它们的VC之外是不可用的,因为VC没有引用传递的lineitem,它只是复制它。组件也是如此。

我找到的解决方法是使用Job结构public class并始终修改组件和lineitems,如PL.Job.self =数组中所需的索引:

  • i访问组件
  • PL.Job.components[i]访问该组件中的特定项目。

然而,这并不能很好地扩展。

所需的行为是能够将引用传递给对象的特定实例,而不是传递PL.Job.components[i].items[i]对象中这些对象的索引路径。

我很清楚目前的结构存在问题,但有人可以指出我正确的方向吗?

1 个答案:

答案 0 :(得分:1)

有几点:

  • 您只能通过引用传递类实例。如果您希望能够将引用传递给特定的LineItemComponentJob,并且您希望能够对该对象进行任何有效的更改,那么您需要将它们定义为类而不是结构。结构类型的实例始终按值传递,而不是引用。当传递一个值类型时,它会被复制,这意味着你创建了一个全新的对象副本,并且改变副本对原始文件没有影响。

  • 您的Job结构只有静态属性 - 即整个应用程序中只会有一个globalIdnamestatus等。如果您想拥有多个Job实例,那么这些实例不应该是静态属性。你说一次只能处理一个Job,所以也许这是故意的。无论哪种方式,仍然经常更喜欢创建具有这些属性的Job类的实例。如果您决定在内存中保留对多个作业的引用,或者允许用户在不同作业之间进行选择,或在作业之间切换等,它肯定会为您提供更大的灵活性。例如,您可能希望允许用户切换到他们之前处理的Job,而不必破坏他们现在正在处理的Job

但我认为主要的一点是,如果您希望能够通过引用传递它们,则需要将对象定义为类。如果修改通过引用传递的对象,则对同一对象的所有其他引用将显示相同的更改(因为,毕竟它们只是对同一对象的引用)。这不适用于值类型,如结构。