Вы можете установить границы программно ( здесь ), это будет выглядеть так
Drawable img = ActivityName.this.getContext().getResources().getDrawable(
R.drawable.blue_line);
img.setBounds(left, top, right, bottom);
button.setCompoundDrawables(img, null, null, null);
Изменить: проблема в том, что вы использовали короткое объявление переменной :=
, и вы только что сохранили созданное значение *DB
в локальной переменной, а не в глобальной.
Эта строка:
db, err := NewDB(dbinfo)
Создает 2 локальные переменные: db
и err
, и этот локальный db
не имеет ничего общего с вашей глобальной переменной db
. Ваша глобальная переменная останется nil
. Вы должны назначить созданную *DB
глобальной переменной. Не используйте короткое объявление переменной, но простое назначение , например:
var err error
db, err = NewDB(dbinfo)
if err != nil {
log.Fatal(err)
}
Далее следует исходный ответ.
Это тип указателя, у вас есть для его инициализации перед ее использованием. Нулевым значением для типов указателей является nil
.
Вам не нужно экспортировать его (это то, что начинается с заглавной буквы). Обратите внимание, что не имеет значения, что у вас есть несколько файлов, если они являются частью одного и того же пакета, они могут получить доступ к идентификаторам, определенным друг другом.
Хорошим решением было бы сделать это в пакете init()
, которая вызывается автоматически.
Обратите внимание, что sql.Open()
может просто подтвердить свои аргументы, не создавая соединение с базой данных. Чтобы проверить правильность имени источника данных, вызовите DB.Ping()
.
Например:
var db *sql.DB
func init() {
var err error
db, err = sql.Open("yourdrivername", "somesource")
if err != nil {
log.Fatal(err)
}
if err = db.Ping(); err != nil {
log.Fatal(err)
}
}
icza уже правильно ответила на вашу конкретную проблему, но стоит добавить дополнительное объяснение того, что вы делаете неправильно, поэтому понимаете, как не совершить ошибку в будущем. В Go синтаксис :=
для присваивания создает новые переменные с именами слева от :=
, возможно, затенением пакета или даже с параметрами функции / метода родительской области. В качестве примера:
package main
import "fmt"
var foo string = "global"
func main() {
fmt.Println(foo) // prints "global"
// using := creates a new function scope variable
// named foo that shadows the package scope foo
foo := "function scope"
fmt.Println(foo) // prints "function scope"
printGlobalFoo() // prints "global"
if true {
foo := "nested scope"
fmt.Println(foo) // prints "nested scope"
printGlobalFoo() // prints "global"
}
// the foo created inside the if goes out of scope when
// the code block is exited
fmt.Println(foo) // prints "function scope"
printGlobalFoo() // prints "global"
if true {
foo = "nested scope" // note just = not :=
}
fmt.Println(foo) // prints "nested scope"
printGlobalFoo() // prints "global"
setGlobalFoo()
printGlobalFoo() // prints "new value"
}
func printGlobalFoo() {
fmt.Println(foo)
}
func setGlobalFoo() {
foo = "new value" // note just = not :=
}
Примечание. Go не имеет возможности удалить или отключить переменную, поэтому, как только вы затеняете более широкие переменные области видимости (например, создав переменную области видимости функции с тем же именем, что и переменная области пакета), нет способа получить доступ к более высокой переменной области видимости в этом блоке кода.
Также имейте в виду, что :=
является сокращением для var foo =
. Оба действуют точно так же, однако :=
является допустимым синтаксисом внутри функции или метода, тогда как синтаксис var
действителен всюду.
:=
, и вы только что сохранили созданное значение*DB
в локальной переменной, а не в глобальной. Невозможно сказать, не видя своего источника, поэтому, пожалуйста, будьте добры и опубликуйте это. – icza 10 December 2015 в 07:56